All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jayway.restassured.config.ObjectMapperConfig Maven / Gradle / Ivy

/*
 * Copyright 2013 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.jayway.restassured.config;

import com.jayway.restassured.internal.mapper.ObjectMapperType;
import com.jayway.restassured.mapper.ObjectMapper;
import com.jayway.restassured.mapper.factory.*;
import org.apache.commons.lang3.Validate;

/**
 * Allows you to specify configuration for the object mapping functionality.
 */
public class ObjectMapperConfig implements Config {

    private final ObjectMapper defaultObjectMapper;
    private final ObjectMapperType defaultObjectMapperType;
    private final GsonObjectMapperFactory gsonObjectMapperFactory;
    private final Jackson1ObjectMapperFactory jackson1ObjectMapperFactory;
    private final Jackson2ObjectMapperFactory jackson2ObjectMapperFactory;
    private final JAXBObjectMapperFactory jaxbObjectMapperFactory;
    private final boolean isUserConfigured;

    /**
     * Default object mapper configuration that uses no explicit object mapper. An object mapper
     * will be found automatically in classpath if available. For more details see documentation.
     * 

* Also default object mapper factories will be used. */ public ObjectMapperConfig() { defaultObjectMapper = null; defaultObjectMapperType = null; gsonObjectMapperFactory = new DefaultGsonObjectMapperFactory(); jackson1ObjectMapperFactory = new DefaultJackson1ObjectMapperFactory(); jackson2ObjectMapperFactory = new DefaultJackson2ObjectMapperFactory(); jaxbObjectMapperFactory = new DefaultJAXBObjectMapperFactory(); isUserConfigured = false; } /** * Creates an object mapper configuration that uses the specified object mapper as default. * * @param defaultObjectMapperType The object mapper to use. If null then classpath scanning will be used. */ public ObjectMapperConfig(ObjectMapperType defaultObjectMapperType) { this(null, defaultObjectMapperType, new DefaultGsonObjectMapperFactory(), new DefaultJackson1ObjectMapperFactory(), new DefaultJackson2ObjectMapperFactory(), new DefaultJAXBObjectMapperFactory(), true); } /** * Creates an object mapper configuration that uses the specified object mapper as default. * * @param defaultObjectMapper The object mapper to use. If null then classpath scanning will be used. */ public ObjectMapperConfig(ObjectMapper defaultObjectMapper) { this(defaultObjectMapper, null, new DefaultGsonObjectMapperFactory(), new DefaultJackson1ObjectMapperFactory(), new DefaultJackson2ObjectMapperFactory(), new DefaultJAXBObjectMapperFactory(), true); } private ObjectMapperConfig(ObjectMapper defaultObjectMapper, ObjectMapperType defaultObjectMapperType, GsonObjectMapperFactory gsonObjectMapperFactory, Jackson1ObjectMapperFactory jackson1ObjectMapperFactory, Jackson2ObjectMapperFactory jackson2ObjectMapperFactory, JAXBObjectMapperFactory jaxbObjectMapperFactory, boolean isUserConfigured) { Validate.notNull(gsonObjectMapperFactory, GsonObjectMapperFactory.class.getSimpleName() + " cannot be null"); Validate.notNull(jackson1ObjectMapperFactory, Jackson1ObjectMapperFactory.class.getSimpleName() + " cannot be null"); Validate.notNull(jackson2ObjectMapperFactory, Jackson2ObjectMapperFactory.class.getSimpleName() + " cannot be null"); Validate.notNull(jaxbObjectMapperFactory, JAXBObjectMapperFactory.class.getSimpleName() + " cannot be null"); this.defaultObjectMapperType = defaultObjectMapperType; this.defaultObjectMapper = defaultObjectMapper; this.gsonObjectMapperFactory = gsonObjectMapperFactory; this.jackson1ObjectMapperFactory = jackson1ObjectMapperFactory; this.jackson2ObjectMapperFactory = jackson2ObjectMapperFactory; this.jaxbObjectMapperFactory = jaxbObjectMapperFactory; this.isUserConfigured = isUserConfigured; } public ObjectMapperType defaultObjectMapperType() { return defaultObjectMapperType; } public boolean hasDefaultObjectMapperType() { return defaultObjectMapperType != null; } /** * Creates an object mapper configuration that uses the specified object mapper as default. * * @param defaultObjectMapperType The object mapper to use. If null then classpath scanning will be used. */ public ObjectMapperConfig defaultObjectMapperType(ObjectMapperType defaultObjectMapperType) { return new ObjectMapperConfig(defaultObjectMapper, defaultObjectMapperType, gsonObjectMapperFactory, jackson1ObjectMapperFactory, jackson2ObjectMapperFactory, jaxbObjectMapperFactory, true); } public ObjectMapper defaultObjectMapper() { return defaultObjectMapper; } public boolean hasDefaultObjectMapper() { return defaultObjectMapper != null; } /** * Creates an object mapper configuration that uses the specified object mapper as default. * * @param defaultObjectMapper The object mapper to use. If null then classpath scanning will be used. */ public ObjectMapperConfig defaultObjectMapper(ObjectMapper defaultObjectMapper) { return new ObjectMapperConfig(defaultObjectMapper); } public GsonObjectMapperFactory gsonObjectMapperFactory() { return gsonObjectMapperFactory; } /** * Specify a custom Gson object mapper factory. * * @param gsonObjectMapperFactory The object mapper factory */ public ObjectMapperConfig gsonObjectMapperFactory(GsonObjectMapperFactory gsonObjectMapperFactory) { return new ObjectMapperConfig(defaultObjectMapper, defaultObjectMapperType, gsonObjectMapperFactory, jackson1ObjectMapperFactory, jackson2ObjectMapperFactory, jaxbObjectMapperFactory, true); } public Jackson1ObjectMapperFactory jackson1ObjectMapperFactory() { return jackson1ObjectMapperFactory; } /** * Specify a custom Jackson 1.0 object mapper factory. * * @param jackson1ObjectMapperFactory The object mapper factory */ public ObjectMapperConfig jackson1ObjectMapperFactory(Jackson1ObjectMapperFactory jackson1ObjectMapperFactory) { return new ObjectMapperConfig(defaultObjectMapper, defaultObjectMapperType, gsonObjectMapperFactory, jackson1ObjectMapperFactory, jackson2ObjectMapperFactory, jaxbObjectMapperFactory, true); } public Jackson2ObjectMapperFactory jackson2ObjectMapperFactory() { return jackson2ObjectMapperFactory; } /** * Specify a custom Jackson 1.0 object mapper factory. * * @param jackson2ObjectMapperFactory The object mapper factory */ public ObjectMapperConfig jackson2ObjectMapperFactory(Jackson2ObjectMapperFactory jackson2ObjectMapperFactory) { return new ObjectMapperConfig(defaultObjectMapper, defaultObjectMapperType, gsonObjectMapperFactory, jackson1ObjectMapperFactory, jackson2ObjectMapperFactory, jaxbObjectMapperFactory, true); } public JAXBObjectMapperFactory jaxbObjectMapperFactory() { return jaxbObjectMapperFactory; } /** * Specify a custom JAXB object mapper factory. * * @param jaxbObjectMapperFactory The object mapper factory */ public ObjectMapperConfig jaxbObjectMapperFactory(JAXBObjectMapperFactory jaxbObjectMapperFactory) { return new ObjectMapperConfig(defaultObjectMapper, defaultObjectMapperType, gsonObjectMapperFactory, jackson1ObjectMapperFactory, jackson2ObjectMapperFactory, jaxbObjectMapperFactory, true); } /** * @return A static way to create a new ObjectMapperConfig instance without calling "new" explicitly. Mainly for syntactic sugar. */ public static ObjectMapperConfig objectMapperConfig() { return new ObjectMapperConfig(); } /** * Syntactic sugar. * * @return The same object mapper config instance. */ public ObjectMapperConfig and() { return this; } public boolean isUserConfigured() { return isUserConfigured; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy