
org.junit.jupiter.params.provider.EnumArgumentsProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of junit-jupiter-params Show documentation
Show all versions of junit-jupiter-params Show documentation
Module "junit-jupiter-params" of JUnit 5.
/*
* Copyright 2015-2025 the original author or authors.
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License v2.0 which
* accompanies this distribution and is available at
*
* https://www.eclipse.org/legal/epl-v20.html
*/
package org.junit.jupiter.params.provider;
import static java.util.Arrays.stream;
import static java.util.stream.Collectors.toSet;
import java.lang.reflect.Method;
import java.util.EnumSet;
import java.util.Set;
import java.util.stream.Stream;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.platform.commons.util.Preconditions;
/**
* @since 5.0
*/
class EnumArgumentsProvider extends AnnotationBasedArgumentsProvider {
@Override
protected Stream extends Arguments> provideArguments(ExtensionContext context, EnumSource enumSource) {
Set extends Enum>> constants = getEnumConstants(context, enumSource);
EnumSource.Mode mode = enumSource.mode();
String[] declaredConstantNames = enumSource.names();
if (declaredConstantNames.length > 0) {
Set uniqueNames = stream(declaredConstantNames).collect(toSet());
Preconditions.condition(uniqueNames.size() == declaredConstantNames.length,
() -> "Duplicate enum constant name(s) found in " + enumSource);
mode.validate(enumSource, constants, uniqueNames);
constants.removeIf(constant -> !mode.select(constant, uniqueNames));
}
return constants.stream().map(Arguments::of);
}
private > Set extends E> getEnumConstants(ExtensionContext context, EnumSource enumSource) {
Class enumClass = determineEnumClass(context, enumSource);
E[] constants = enumClass.getEnumConstants();
if (constants.length == 0) {
Preconditions.condition(enumSource.from().isEmpty() && enumSource.to().isEmpty(),
"No enum constant in " + enumClass.getSimpleName() + ", but 'from' or 'to' is not empty.");
return EnumSet.noneOf(enumClass);
}
E from = enumSource.from().isEmpty() ? constants[0] : Enum.valueOf(enumClass, enumSource.from());
E to = enumSource.to().isEmpty() ? constants[constants.length - 1] : Enum.valueOf(enumClass, enumSource.to());
Preconditions.condition(from.compareTo(to) <= 0,
() -> String.format(
"Invalid enum range: 'from' (%s) must come before 'to' (%s) in the natural order of enum constants.",
from, to));
return EnumSet.range(from, to);
}
@SuppressWarnings({ "unchecked", "rawtypes" })
private > Class determineEnumClass(ExtensionContext context, EnumSource enumSource) {
Class enumClass = enumSource.value();
if (enumClass.equals(NullEnum.class)) {
Method method = context.getRequiredTestMethod();
Class>[] parameterTypes = method.getParameterTypes();
Preconditions.condition(parameterTypes.length > 0,
() -> "Test method must declare at least one parameter: " + method.toGenericString());
Preconditions.condition(Enum.class.isAssignableFrom(parameterTypes[0]),
() -> "First parameter must reference an Enum type (alternatively, use the annotation's 'value' attribute to specify the type explicitly): "
+ method.toGenericString());
enumClass = parameterTypes[0];
}
return enumClass;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy