Junit5 注解
所有支持的注解都在包 org.junit.jupiter.api
下;
使用@Test、@TestTemplate、@RepeatedTest、@BeforeAll、@AfterAll、@BeforeEach或@AfterEach注释的方法不能返回值。
@Test
表示方法是测试方法。与JUnit 4的@Test注释不同,这个注释不声明任何属性,因为JUnit Jupiter中的测试扩展基于它们自己的专用注释进行操作。 这些方法是继承的,除非它们被重写。
@ParameterizedTest
表示方法是参数化测试。这些方法是继承的,除非它们被重写。
@RepeatedTest
表示方法是重复测试的测试模板。这些方法是继承的,除非它们被重写。
@TestFactory
表示方法是动态测试的测试工厂。这些方法是继承的,除非它们被重写。
@TestInstance
用于为带注释的测试类配置测试实例生命周期。这些方法是继承的,除非它们被重写。
@TestTemplate
表示方法是为测试用例设计的模板,根据注册提供程序返回的调用上下文的数量进行多次调用。这些方法是继承的,除非它们被重写。
@DisplayName
声明测试类或测试方法的自定义显示名称。这样的注解不是继承来的。
@BeforeEach
表示在当前类中每个@Test、@RepeatedTest、@ParameterizedTest或@TestFactory方法之前执行注释的方法;类似于JUnit 4的@Before。
这些方法是继承的,除非它们被重写。
@AfterEach
表示在当前类中的每个@Test、@RepeatedTest、@ParameterizedTest或@TestFactory方法之后,都应该执行带注释的方法;类似于JUnit 4的@After。
这些方法是继承的,除非它们被重写。
@BeforeAll
表示应在当前类中的所有@Test、@RepeatedTest、@ParameterizedTest和@TestFactory方法之前执行带注释的方法;类似于JUnit 4的@BeforeClass。
这些方法是继承的(除非它们被隐藏或覆盖),并且必须是静态的(除非使用“每个类”测试实例生命周期)。
@AfterAll
表示在当前类中,所有@Test、@RepeatedTest、@ParameterizedTest和@TestFactory方法都应该执行注释的方法;类似于JUnit 4的@AfterClass。
这些方法是继承的(除非它们被隐藏或覆盖),并且必须是静态的(除非使用“每个类”测试实例生命周期)。
@Nested
表示带注释的类是一个嵌套的、非静态的测试类。@BeforeAll和@AfterAll方法不能直接在 @Nested 测试类中使用,除非使用“每个类”测试实例生命周期。
这样的注解不是继承来的。
@Tag
用于在类或方法级别声明过滤测试的标记;类似于TestNG中的测试组或JUnit 4中的类别。
此类注释在类级别继承,但在方法级别继承。
@Disabled
用于禁用测试类或测试方法;类似于JUnit 4的@Ignore。
这样的注解不是继承来的。
@ExtendWith
用于注册自定义扩展。这些注释是继承。
元注释,注释
JUnit Jupiter注解可以用作元注解。这意味着您可以定义自己的组合注释,它将自动继承其元注释的语义。
例如,您可以创建一个名为 @Fast
的自定义组合注释,
如下所示,而不是在整个代码库中复制和粘贴@Tag(“fast”)(请参阅标记和过滤)。然后可以使用@Fast作为@Tag(“fast”)的drop-in替代。
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.junit.jupiter.api.Tag;
@Target({ ElementType.TYPE, ElementType.METHOD })
@Retention(RetentionPolicy.RUNTIME)
@Tag("fast")
public @interface Fast {
}