目录
- 目录
- 测试上下文
- 实例
- 系列导航
测试上下文
@TestTemplate方法只能在注册至少一个TestTemplateInvocationContextProvider时执行。
每个这样的提供者都负责提供TestTemplateInvocationContext实例流。
每个上下文可以指定一个自定义显示名称和一个附加扩展列表,这些扩展只用于@TestTemplate方法的下一次调用。
实例
下面的示例展示了如何编写测试模板以及如何注册和实现TestTemplateInvocationContextProvider。
- MyTestTemplateInvocationContextProvider.java
public class MyTestTemplateInvocationContextProvider implements TestTemplateInvocationContextProvider {
@Overridepublic boolean supportsTestTemplate(ExtensionContext context) {return true;}@Overridepublic Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {return Stream.of(invocationContext("foo"), invocationContext("bar"));}private TestTemplateInvocationContext invocationContext(String parameter) {return new TestTemplateInvocationContext() {@Overridepublic String getDisplayName(int invocationIndex) {return parameter;}@Overridepublic List<Extension> getAdditionalExtensions() {return Collections.singletonList(new ParameterResolver() {@Overridepublic boolean supportsParameter(ParameterContext parameterContext,ExtensionContext extensionContext) {return parameterContext.getParameter().getType().equals(String.class);}@Overridepublic Object resolveParameter(ParameterContext parameterContext,ExtensionContext extensionContext) {return parameter;}});}};}
}
- testTemplate()
@TestTemplate
@ExtendWith(MyTestTemplateInvocationContextProvider.class)
void testTemplate(String parameter) {assertEquals(3, parameter.length());
}
- 执行说明
在本例中,将调用两次测试模板。
调用的显示名称将是调用上下文指定的“foo”和“bar”。每个调用都注册一个自定义参数解析器,用于解析方法参数。
使用 ConsoleLaunche
时的输出如下:
└─ testTemplate(String) ?├─ foo ?└─ bar ?
TestTemplateInvocationContextProvider扩展API主要用于实现不同类型的测试,这些测试依赖于重复调用类似测试的方法,
尽管是在不同的上下文中—例如,使用不同的参数,以不同的方式准备测试类实例,或者多次不修改上下文。
系列导航
系列导航