写点什么

软件测试学习笔记丨 JUnit5 超时处理

作者:测试人
  • 2024-06-24
    北京
  • 本文字数:975 字

    阅读完需:约 3 分钟

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/28016

简介

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

软件测试开发免费视频教程分享


发布于: 刚刚阅读数: 6
用户头像

测试人

关注

专注于软件测试开发 2022-08-29 加入

霍格沃兹测试开发学社,测试人社区:https://ceshiren.com/t/topic/22284

评论

发布
暂无评论
软件测试学习笔记丨JUnit5超时处理_软件测试_测试人_InfoQ写作社区