简介
- 测试过程中如果某条测试用例执行过程中阻塞,就会发生超时问题。
- 阻塞其他用例的执行。
- 对于某些用例,如果用例执行时间过长,那么本身就是 bug。
使用场景
- 使用 JUnit5 自带的超时处理。当测试用例执行时间超过设置的执行时间,那么用例结果为执行失败。
@Timeout注解
- 使用
@Timeout(5)
注解配置超时时间
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Timeout;
import static java.lang.Thread.sleep;
class TimeoutExampleTest {
@Test
@Timeout(7)
void timeoutDemo1() throws InterruptedException {
sleep(10000);
System.out.println(“超时用例1”);
}
@Test
void timeoutDemo2(){
System.out.println(“超时用例2”);
}
}
@Timeout注解
- 可以结合注解
@BeforeEach
与@AfterEach
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Timeout;
import static java.lang.Thread.sleep;
class TimeoutExampleTest {
@AfterEach
@Timeout(3)
void teardown() throws InterruptedException {
sleep(40000);
System.out.println(“结束测试”);
}
@BeforeEach
@Timeout(3)
void setup() throws InterruptedException {
sleep(40000);
System.out.println(“开始测试”);
}
@Test
void timeoutDemo2(){
System.out.println(“超时用例2”);
}
}
时间单位配置表
配置时间单位
package com.hogwarts.JUnit5;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.Timeout;
import java.util.concurrent.TimeUnit;
public class TimeoutExampleTest {
// 如果超过5秒则执行失败
@BeforeEach
@Timeout(5)
void setUp() {
}
// 通过value参数配置数量,通过unit参数配置时间单位
@Test
@Timeout(value = 100, unit = TimeUnit.MILLISECONDS)
void failsIfExecutionTimeExceeds100Milliseconds() {
}
}