Junit 超时测试

时间:2024-03-09 22:43:33

超时测试

1.什么是超时测试?

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

除了要保证结果争取还要保证在规定的时间内执行完

就像考试那样 不仅要求结果正确还得在规定的时间内写完

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

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

2.超时测试的两种方式

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

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

  • 使用@Rule注解和Timeout对象

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

3.准备被测试类

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=规定执行时间)进行超时测试

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

设置执行时间模板

@Test(timeout=规定执行时间)
测试方法{
  方法体
}

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

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));
    }

}
  • 代码执行结果

image.png

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

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

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

规定执行时间是Timeout的参数

  • 编写测试方法
@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));
    }
  • 完整代码
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));
    }

}
  • 执行结果

image.png

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

5.小结

  • 使用@Test(timeout规定执行时间) 只能针对一个测试方法
  • @Test(timeout规定执行时间) 要写在 要进行超时测试的方法上 哪个方法要写哪个上面
  • 使用@Rule 时 则对整个测试类中所有方法有效
  • @Test(time=规定执行时间)针对的是某个方法 而@Rule则对整个类中所有方法都起作用
  • @Rule要创建Timeout对象 且必须为public修饰
  • 两种超时测试的方法 中时间的单位都是毫秒 1000毫秒=1秒