Junit 超时测试

超时测试

1.什么是超时测试?

看被测试方法是否在规定的时间内执行完

除了要保证结果争取还要保证在规定的时间内执行完
就像考试那样 不仅要求结果正确还得在规定的时间内写完

被测试方法执行时间>规定时间⇒测试不通过

被测试方法执行时间<规定时间⇒测试通过

2.超时测试的两种方式

  • 使用@Test(timeout=规定时间)

针对某个方法 哪个方法要就写那个方法上面

  • 使用@Rule注解和Timeout对象

针对整个类中的所有方法 只要写一次 对所有方法起作用

3.准备被测试类

javascript 复制代码
package com.jaylan.example.time_out_test;
// 超时测试被测试代码
public class Addtion {
    
     public int add(int x,int y)
     {
	 int result=0;
	 try {
//	     等待5000毫秒 (5s)后执行 
	     //该方法最少要执行 5000毫秒
	     Thread.sleep(5000);
	     //两数相加
	   result=x+y;
	} catch (Exception e) {
	    
	    e.printStackTrace();
	}
	 return result;
	 
     }

}

4.使用@Test(timeout=规定执行时间)进行超时测试

  • 编写测试方法并给每个方法规定执行时间

设置执行时间模板

javascript 复制代码
@Test(timeout=规定执行时间)
测试方法{
  方法体
}

规定执行时间写在参数中 单位是毫秒

javascript 复制代码
package com.jaylan.example.time_out_test;

import static org.junit.Assert.*;

import org.junit.Test;

public class AddtionTest {

    //超时测试 使用@Test(timeout=规定方法执行时间)
    @Test(timeout=6000)
    //规定 要在6000毫秒内执行完毕    能通过
    public void test01() {
	Addtion addtion=new Addtion();
	// 
	assertEquals(2, addtion.add(1, 1));
    }
    @Test(timeout=4000)
    //规定 要在4000毫秒内执行完毕   不能通过(因为 最少执行5000毫秒)
    public void test02() {
	Addtion addtion=new Addtion();
	// 
	assertEquals(2, addtion.add(1, 1));
    }

}
  • 代码执行结果

5.使用@Rule 进行超时测试

  • 导入相关类库
javascript 复制代码
import org.junit.rules.*;//Timeout对象所在类库
import org.junit.Rule;//@Rule注解
  • 创建Timeout对象并设置执行时间
javascript 复制代码
@Rule
public Timeout timeOut=new Timeout(规定执行时间);

!!!Timeout对象必须为public修饰

规定执行时间是Timeout的参数

  • 编写测试方法
javascript 复制代码
@Test //执行时间<6000毫秒 通过
    public void test01() {
	Addtion addtion=new Addtion();
	assertEquals(2, addtion.add(1, 1));
    }
    @Test //执行时间<6000毫秒 通过
    public void test02() {
	Addtion addtion=new Addtion();
	assertEquals(4, addtion.add(2, 2));
    }
  • 完整代码
javascript 复制代码
package com.jaylan.example.time_out_test;
import static org.junit.Assert.*;
import org.junit.Test;
//导入Rule相关类库
import org.junit.rules.*;
import org.junit.Rule;
//使用 @Roule 进行 超时测试
public class AddtionTest2 {

    @Rule
    public Timeout timeOut=new Timeout(6000);
    //创建 规定时间对象  所有执行作用于类中所有执行方法
    //每个方法都必须在 6000毫内执行完毕
  
    @Test //执行时间<6000毫秒 通过
    public void test01() {
	Addtion addtion=new Addtion();
	assertEquals(2, addtion.add(1, 1));
    }
    @Test //执行时间<6000毫秒 通过
    public void test02() {
	Addtion addtion=new Addtion();
	assertEquals(4, addtion.add(2, 2));
    }

}
  • 执行结果

两测试方法都在预期时间内执行完毕测试通过

5.小结

  • 使用@Test(timeout规定执行时间) 只能针对一个测试方法
  • @Test(timeout规定执行时间) 要写在 要进行超时测试的方法上 哪个方法要写哪个上面
  • 使用@Rule 时 则对整个测试类中所有方法有效
  • @Test(time=规定执行时间)针对的是某个方法 而@Rule则对整个类中所有方法都起作用
  • @Rule要创建Timeout对象 且必须为public修饰
  • 两种超时测试的方法 中时间的单位都是毫秒 1000毫秒=1秒
相关推荐
寒秋丶35 分钟前
Milvus:Json字段详解(十)
数据库·人工智能·python·ai·milvus·向量数据库·rag
ManageEngineITSM4 小时前
技术的秩序:IT资产与配置管理的现代重构
大数据·运维·数据库·重构·工单系统
档案宝档案管理7 小时前
档案宝:企业合同档案管理的“安全保险箱”与“效率加速器”
大数据·数据库·人工智能·安全·档案·档案管理
wangjialelele7 小时前
mysql库操作二
数据库·mysql
Chloeis Syntax7 小时前
MySQL初阶学习日记(1)--- 数据库的基本操作
数据库·学习·mysql
千里镜宵烛7 小时前
深入 Lua 元表与元方法
junit
workflower8 小时前
FDD(Feature Driven Development)特征驱动开发
大数据·数据库·驱动开发·需求分析·个人开发
韩立学长8 小时前
基于Springboot的旧物公益捐赠管理系统3726v22v(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
苦学编程的谢9 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存