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秒
相关推荐
肘击鸣的百k路4 分钟前
日志和MVCC的详解
数据库·oracle
小小药8 分钟前
011-spring-整合三方框架的命名空间原理(重要)
java·数据库·spring
m0_7482509314 分钟前
Text2SQL(NL2sql)对话数据库:设计、实现细节与挑战
数据库
m0_748235071 小时前
MySQL——操作
数据库·mysql·oracle
飞翔沫沫情1 小时前
《快速部署Mysql-slave 容器,实现高效主从同步》
数据库·docker·mysql主从同步
SelectDB技术团队1 小时前
一文了解多云原生的现代化实时数仓 SelectDB Cloud
大数据·数据库·数据仓库·云原生·云计算
木卫二号Coding2 小时前
docker-开源nocodb,使用已有数据库
数据库·docker·开源
StarRocks_labs2 小时前
StarRocks 存算分离在得物的降本增效实践
数据库·数据仓库·湖仓
敲代码敲到头发茂密3 小时前
基于 LangChain 实现数据库问答机器人
数据库·人工智能·语言模型·langchain·机器人
一入程序无退路3 小时前
c语言传参数路径太长,导致无法获取参数
linux·c语言·数据库