/*
 * Copyright 2015-2020 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.engine.descriptor;

import static java.util.Collections.emptyList;
import static org.apiguardian.api.API.Status.INTERNAL;
import static org.junit.jupiter.engine.descriptor.DisplayNameUtils.createDisplayNameSupplierForClass;

import java.util.LinkedHashSet;
import java.util.List;
import java.util.Optional;
import java.util.Set;

import org.apiguardian.api.API;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.TestInstances;
import org.junit.jupiter.engine.config.JupiterConfiguration;
import org.junit.jupiter.engine.execution.JupiterEngineExecutionContext;
import org.junit.jupiter.engine.extension.ExtensionRegistrar;
import org.junit.jupiter.engine.extension.ExtensionRegistry;
import org.junit.platform.engine.TestDescriptor;
import org.junit.platform.engine.TestTag;
import org.junit.platform.engine.UniqueId;
import org.junit.platform.engine.support.hierarchical.ThrowableCollector;

TestDescriptor for tests based on Java classes.

Default Display Names

The default display name for a top-level or nested static test class is the fully qualified name of the class with the package name and leading dot (".") removed.

Since:5.0
/** * {@link TestDescriptor} for tests based on Java classes. * * <h3>Default Display Names</h3> * * <p>The default display name for a top-level or nested static test class is * the fully qualified name of the class with the package name and leading dot * (".") removed. * * @since 5.0 */
@API(status = INTERNAL, since = "5.0") public class ClassTestDescriptor extends ClassBasedTestDescriptor { public static final String SEGMENT_TYPE = "class"; public ClassTestDescriptor(UniqueId uniqueId, Class<?> testClass, JupiterConfiguration configuration) { super(uniqueId, testClass, createDisplayNameSupplierForClass(testClass, configuration), configuration); } // --- TestDescriptor ------------------------------------------------------ @Override public Set<TestTag> getTags() { // return modifiable copy return new LinkedHashSet<>(this.tags); } @Override public List<Class<?>> getEnclosingTestClasses() { return emptyList(); } // --- Node ---------------------------------------------------------------- @Override public ExecutionMode getExecutionMode() { return getExplicitExecutionMode().orElseGet( () -> JupiterTestDescriptor.toExecutionMode(configuration.getDefaultClassesExecutionMode())); } @Override protected TestInstances instantiateTestClass(JupiterEngineExecutionContext parentExecutionContext, ExtensionRegistry registry, ExtensionRegistrar registrar, ExtensionContext extensionContext, ThrowableCollector throwableCollector) { return instantiateTestClass(Optional.empty(), registry, extensionContext); } }