霍格沃兹测试开发

JUnit5 超时处理

ceshiren.com

霍格沃兹测试学社

简介

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

时间单位配置表

时间 配置内容
42毫秒 @Timeout(value = 42, unit = MILLISECONDS)
42秒 @Timeout(value = 42, unit = SECONDS)
42分 @Timeout(value = 42, unit = MINUTES)
42小时 @Timeout(value = 42, unit = HOURS)
42天 @Timeout(value = 42, unit = DAYS)

配置时间单位

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