org.junit.jupiter.api.DisplayNameGenerator Maven / Gradle / Ivy
Show all versions of junit-jupiter-api Show documentation
/*
* Copyright 2015-2019 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
*
* http://www.eclipse.org/legal/epl-v20.html
*/
package org.junit.jupiter.api;
import static org.apiguardian.api.API.Status.EXPERIMENTAL;
import java.lang.reflect.Method;
import org.apiguardian.api.API;
import org.junit.platform.commons.util.ClassUtils;
import org.junit.platform.commons.util.Preconditions;
/**
* {@code DisplayNameGenerator} defines the SPI for generating display
* names programmatically.
*
* An implementation must provide an accessible no-arg constructor.
*
* @since 5.4
* @see DisplayName
* @see DisplayNameGeneration
*/
@API(status = EXPERIMENTAL, since = "5.4")
public interface DisplayNameGenerator {
/**
* Generate a display name for the given top-level or {@code static} nested test class.
*
* @param testClass the class generate a name for; never {@code null}
* @return the display name of the container; never {@code null} or blank
*/
String generateDisplayNameForClass(Class> testClass);
/**
* Generate a display name for the given {@link Nested @Nested} inner test class.
*
* @param nestedClass the class generate a name for; never {@code null}
* @return the display name of the container; never {@code null} or blank
*/
String generateDisplayNameForNestedClass(Class> nestedClass);
/**
* Generate a display name for the given method.
*
* @implNote The class instance passed as {@code testClass} may differ from
* the returned class by {@code testMethod.getDeclaringClass()}: e.g., when
* a test method is inherited from a super class.
*
* @param testClass the class the test method is invoked on; never {@code null}
* @param testMethod method to generate a display name for; never {@code null}
* @return the display name of the test; never {@code null} or blank
*/
String generateDisplayNameForMethod(Class> testClass, Method testMethod);
/**
* Compile a string representation from all simple parameter type names.
*
* @param method the method providing parameter types for the result; never {@code null}
* @return a string representation of all parameter types of the
* supplied method or {@code "()"} if the method has no parameters
*/
static String parameterTypesAsString(Method method) {
Preconditions.notNull(method, "Method must not be null");
return '(' + ClassUtils.nullSafeToString(Class::getSimpleName, method.getParameterTypes()) + ')';
}
/**
* Standard display name generator.
*
*
The implementation matches the published behaviour when Jupiter 5.0.0
* was released.
*/
class Standard implements DisplayNameGenerator {
@Override
public String generateDisplayNameForClass(Class> testClass) {
String name = testClass.getName();
int lastDot = name.lastIndexOf('.');
return name.substring(lastDot + 1);
}
@Override
public String generateDisplayNameForNestedClass(Class> nestedClass) {
return nestedClass.getSimpleName();
}
@Override
public String generateDisplayNameForMethod(Class> testClass, Method testMethod) {
return testMethod.getName() + parameterTypesAsString(testMethod);
}
}
/**
* Replace all underscore characters with spaces.
*
*
The {@code ReplaceUnderscores} generator replaces all underscore characters
* ({@code '_'}) found in class and method names with space characters: {@code ' '}.
*/
class ReplaceUnderscores extends Standard {
@Override
public String generateDisplayNameForClass(Class> testClass) {
return replaceUnderscores(super.generateDisplayNameForClass(testClass));
}
@Override
public String generateDisplayNameForNestedClass(Class> nestedClass) {
return replaceUnderscores(super.generateDisplayNameForNestedClass(nestedClass));
}
@Override
public String generateDisplayNameForMethod(Class> testClass, Method testMethod) {
// don't replace underscores in parameter type names
return replaceUnderscores(testMethod.getName()) + parameterTypesAsString(testMethod);
}
private String replaceUnderscores(String name) {
return name.replace('_', ' ');
}
}
}