org.junit.jupiter.api.TestInstance Maven / Gradle / Ivy
Show all versions of junit-jupiter-api Show documentation
/*
* Copyright 2015-2017 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.STABLE;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.apiguardian.api.API;
/**
* {@code @TestInstance} is a type-level annotation that is used to configure
* the {@linkplain Lifecycle lifecycle} of test instances for the annotated
* test class or test interface.
*
* If {@code @TestInstance} is not declared on a test class or implemented
* test interface, the lifecycle mode will implicitly default to
* {@link Lifecycle#PER_METHOD PER_METHOD}. Note, however, that an explicit
* lifecycle mode is inherited within a test class hierarchy. In
* addition, the default lifecycle mode may be set via the
* {@code junit.jupiter.testinstance.lifecycle.default} configuration
* parameter which can be supplied via the {@code Launcher} API or via a
* JVM system property. Consult the User Guide for further information.
*
*
Use Cases
* Setting the test instance lifecycle mode to {@link Lifecycle#PER_CLASS
* PER_CLASS} enables the following features.
*
* - Shared test instance state between test methods in a given test class
* as well as between non-static {@link BeforeAll @BeforeAll} and
* {@link AfterAll @AfterAll} methods in the test class.
* - Declaration of {@link BeforeAll @BeforeAll} and {@link AfterAll @AfterAll}
* methods in {@link Nested @Nested} test classes.
* - Declaration of {@link BeforeAll @BeforeAll} and {@link AfterAll @AfterAll}
* on interface {@code default} methods.
* - Simplified declaration of {@link BeforeAll @BeforeAll} and
* {@link AfterAll @AfterAll} methods in test classes implemented with the Kotlin
* programming language.
*
*
* {@code @TestInstance} may also be used as a meta-annotation in order to
* create a custom composed annotation that inherits the semantics
* of {@code @TestInstance}.
*
* @since 5.0
*/
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
@API(status = STABLE, since = "5.0")
public @interface TestInstance {
/**
* Enumeration of test instance lifecycle modes.
*
* @see #PER_METHOD
* @see #PER_CLASS
*/
enum Lifecycle {
/**
* When using this mode, a new test instance will be created once per test class.
*
* @see #PER_METHOD
*/
PER_CLASS,
/**
* When using this mode, a new test instance will be created for each test method
* or test factory method.
*
*
This mode is analogous to the behavior found in JUnit versions 1 through 4.
*
* @see #PER_CLASS
*/
PER_METHOD;
}
/**
* The test instance lifecycle mode to use.
*/
Lifecycle value();
}