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

ext.test4j.objenesis.ObjenesisBase Maven / Gradle / Ivy

There is a newer version: 2.5.0
Show newest version
/**
 * Copyright 2006-2009 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 ext.test4j.objenesis;

import java.util.HashMap;
import java.util.Map;

import ext.test4j.objenesis.instantiator.ObjectInstantiator;
import ext.test4j.objenesis.strategy.InstantiatorStrategy;

/**
 * Base class to extend if you want to have a class providing your own default
 * strategy. Can also be instantiated directly.
 * 
 * @author Henri Tremblay
 */
@SuppressWarnings({ "rawtypes", "unchecked" })
public class ObjenesisBase implements Objenesis {

	/** Strategy used by this Objenesi implementation to create classes */
	protected final InstantiatorStrategy strategy;

	/** Strategy cache. Key = Class, Value = InstantiatorStrategy */
	protected Map cache;

	/**
	 * Constructor allowing to pick a strategy and using cache
	 * 
	 * @param strategy
	 *            Strategy to use
	 */
	public ObjenesisBase(InstantiatorStrategy strategy) {
		this(strategy, true);
	}

	/**
	 * Flexible constructor allowing to pick the strategy and if caching should
	 * be used
	 * 
	 * @param strategy
	 *            Strategy to use
	 * @param useCache
	 *            If {@link ObjectInstantiator}s should be cached
	 */
	public ObjenesisBase(InstantiatorStrategy strategy, boolean useCache) {
		if (strategy == null) {
			throw new IllegalArgumentException("A strategy can't be null");
		}
		this.strategy = strategy;
		this.cache = useCache ? new HashMap() : null;
	}

	public String toString() {
		return getClass().getName() + " using " + strategy.getClass().getName()
				+ (cache == null ? " without" : " with") + " caching";
	}

	/**
	 * Will create a new object without any constructor being called
	 * 
	 * @param clazz
	 *            Class to instantiate
	 * @return New instance of clazz
	 */
	public Object newInstance(Class clazz) {
		return getInstantiatorOf(clazz).newInstance();
	}

	/**
	 * Will pick the best instantiator for the provided class. If you need to
	 * create a lot of instances from the same class, it is way more efficient
	 * to create them from the same ObjectInstantiator than calling
	 * {@link #newInstance(Class)}.
	 * 
	 * @param clazz
	 *            Class to instantiate
	 * @return Instantiator dedicated to the class
	 */
	public synchronized ObjectInstantiator getInstantiatorOf(Class clazz) {
		if (cache == null) {
			return strategy.newInstantiatorOf(clazz);
		}
		ObjectInstantiator instantiator = (ObjectInstantiator) cache.get(clazz.getName());
		if (instantiator == null) {
			instantiator = strategy.newInstantiatorOf(clazz);
			cache.put(clazz.getName(), instantiator);
		}
		return instantiator;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy