com.applitools.utils.ArgumentGuard Maven / Gradle / Ivy
package com.applitools.utils;
import java.util.Arrays;
/**
* Argument validation utilities.
*/
public class ArgumentGuard {
private ArgumentGuard() {
}
/**
* Fails if the input parameter is null.
*
* @param param The input parameter
* @param paramName The input parameter name
*/
public static void notNull(Object param, String paramName)
throws IllegalArgumentException {
if (null == param) {
throw new IllegalArgumentException(paramName + " is null");
}
}
/**
* Fails if the input iterable contains null elements.
*
* @param The type parameter
* @param param The input parameter
* @param paramName The input parameter name
*/
public static void notContainsNull(Iterable param, String paramName) throws IllegalArgumentException {
notNull(param, paramName);
for (T element : param) {
if (element == null) {
throw new IllegalArgumentException(paramName + " has null elements");
}
}
}
/**
* Fails if the input array has contains elements.
*
* @param The type parameter
* @param param The input parameter
* @param paramName The input parameter name
*/
public static void notContainsNull(T[] param, String paramName) throws IllegalArgumentException {
notNull(param, paramName);
notContainsNull(Arrays.asList(param), paramName);
}
/**
* Fails if the input parameter equals the input value.
*
* @param param The input parameter
* @param value The input value
* @param paramName The input parameter name
*/
public static void notEqual(Object param, Object value, String paramName) {
if (param == value || (param != null && param.equals(value))) {
throw new IllegalArgumentException(paramName + " == " + value);
}
}
/**
* Fails if the input parameter string is null or empty.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
public static void notNullOrEmpty(String param, String paramName)
throws IllegalArgumentException {
notNull(param, paramName);
if (param.length() == 0) {
throw new IllegalArgumentException(paramName + " is empty");
}
}
/**
* Fails if the input parameter is not null.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
@SuppressWarnings("UnusedDeclaration")
public static void isNull(Object param, String paramName)
throws IllegalArgumentException {
if (null != param) {
throw new IllegalArgumentException(paramName + " is not null");
}
}
/**
* Fails if the input integer parameter is negative.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
public static void greaterThanOrEqualToZero(long param, String paramName)
throws IllegalArgumentException {
if (0 > param) {
throw new IllegalArgumentException(paramName + " < 0");
}
}
/**
* Fails if the input integer parameter is smaller than 1.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
public static void greaterThanZero(long param, String paramName)
throws IllegalArgumentException {
if (0 >= param) {
throw new IllegalArgumentException(paramName + " < 1");
}
}
/**
* Fails if the input integer parameter is below or equal to 0.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
public static void greaterThanZero(double param, String paramName)
throws IllegalArgumentException {
if (0 >= param) {
throw new IllegalArgumentException(paramName + " < 1");
}
}
/**
* Fails if the input integer parameter is equal to 0.
*
* @param param The input parameter.
* @param paramName The input parameter name.
*/
@SuppressWarnings("UnusedDeclaration")
public static void notZero(long param, String paramName)
throws IllegalArgumentException {
if (0 == param) {
throw new IllegalArgumentException(paramName + " == 0");
}
}
/**
* Fails if isValid is false.
*
* @param isValid Whether the current state is valid.
* @param errMsg A description of the error.
*/
public static void isValidState(boolean isValid, String errMsg)
throws IllegalStateException {
if (!isValid) {
throw new IllegalStateException(errMsg);
}
}
/**
* Fails if param is not of the expected type.
*
* @param param The input parameter
* @param paramExpectedClass The expected type.
* @param paramName The input parameter name.
*/
@SuppressWarnings("unchecked")
public static void notOfType(Object param, Class paramExpectedClass, String paramName)
throws IllegalArgumentException {
if (!(paramExpectedClass.isAssignableFrom(param.getClass()))) {
throw new IllegalArgumentException(paramName + " is must be a " + paramExpectedClass);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy