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

de.alpharogroup.evaluate.object.evaluators.SilentEqualsHashCodeAndToStringEvaluator Maven / Gradle / Ivy

/**
 * The MIT License
 *
 * Copyright (C) 2015 Asterios Raptis
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
 * associated documentation files (the "Software"), to deal in the Software without restriction,
 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all copies or
 * substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
 * NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
package de.alpharogroup.evaluate.object.evaluators;

import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.function.Function;

import lombok.experimental.UtilityClass;

/**
 * The class {@link SilentEqualsHashCodeAndToStringEvaluator} evaluates classes in a silent manner
 */
@UtilityClass
public final class SilentEqualsHashCodeAndToStringEvaluator
{

	/**
	 * Evaluates all the contract conditions for the methods {@link Object#equals(Object)},
	 * {@link Object#hashCode()} and {@link Object#toString()} from the given {@link Class}.
	 *
	 * @param 
	 *            the generic type
	 * @param cls
	 *            the class
	 * @return true, if all contract conditions for the methods {@link Object#equals(Object)},
	 *         {@link Object#hashCode()} and {@link Object#toString()} is given otherwise false
	 */
	public static  boolean evaluateEqualsHashcodeAndToStringQuietly(Class cls)
	{
		boolean evaluated;
		try
		{
			evaluated = EqualsHashCodeAndToStringEvaluator.evaluateEqualsHashcodeAndToString(cls);
		}
		catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException
			| InstantiationException | IOException | ClassNotFoundException e)
		{
			evaluated = false;
		}
		return evaluated;
	}

	/**
	 * Evaluates all the contract conditions for the methods {@link Object#equals(Object)},
	 * {@link Object#hashCode()} and {@link Object#toString()} from the given {@link Class}.
	 *
	 * @param 
	 *            the generic type
	 * @param cls
	 *            the class
	 * @param function
	 *            the function that can create random objects
	 * @return true, if all contract conditions for the methods {@link Object#equals(Object)},
	 *         {@link Object#hashCode()} and {@link Object#toString()} is given otherwise false
	 */
	public static  boolean evaluateEqualsHashcodeAndToStringQuietly(Class cls,
		Function, T> function)
	{
		boolean evaluated;
		try
		{
			evaluated = EqualsHashCodeAndToStringEvaluator.evaluateEqualsHashcodeAndToString(cls,
				function);
		}
		catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException
			| InstantiationException | IOException | ClassNotFoundException e)
		{
			evaluated = false;
		}
		return evaluated;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy