jck28-lucio-junit5超时处理

简介

  • 测试过程中如果某条测试用例执行过程中阻塞,就会发生超时问题。
    • 阻塞其他用例的执行。
    • 对于某些用例,如果用例执行时间过长,那么本身就是 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”);
}
}

时间单位配置表

image

配置时间单位

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() {
}
}