- JUnit 教程
- JUnit - 主页
- JUnit - 概述
- JUnit - 环境设置
- JUnit - 测试框架
- JUnit - 基本用法
- JUnit-API
- JUnit - 编写测试
- JUnit - 使用断言
- JUnit - 执行过程
- JUnit - 执行测试
- JUnit - 套件测试
- JUnit - 忽略测试
- JUnit - 时间测试
- JUnit - 异常测试
- JUnit - 参数化测试
- JUnit - 使用 Ant 插件
- JUnit - 插入 Eclipse
- JUnit - 扩展
- JUnit 有用资源
- JUnit - 问题与解答
- JUnit - 快速指南
- JUnit - 有用的资源
- JUnit - 讨论
JUnit - 时间测试
JUnit 提供了一个方便的超时选项。如果测试用例花费的时间超过指定的毫秒数,那么 JUnit 会自动将其标记为失败。超时参数与@Test注释一起使用。让我们看看 @Test(timeout) 的实际效果。
创建一个类
创建一个要测试的java类,例如C:\>JUNIT_WORKSPACE中的MessageUtil.java 。
在 printMessage() 方法中添加无限 while 循环。
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public void printMessage(){
System.out.println(message);
while(true);
}
// add "Hi!" to the message
public String salutationMessage(){
message = "Hi!" + message;
System.out.println(message);
return message;
}
}
创建测试用例类
创建一个 java 测试类,例如TestJunit.java。向 testPrintMessage() 测试用例添加超时 1000。
在 C:\>JUNIT_WORKSPACE 中创建名为TestJunit.java的 java 类文件。
import org.junit.Test;
import org.junit.Ignore;
import static org.junit.Assert.assertEquals;
public class TestJunit {
String message = "Robert";
MessageUtil messageUtil = new MessageUtil(message);
@Test(timeout = 1000)
public void testPrintMessage() {
System.out.println("Inside testPrintMessage()");
messageUtil.printMessage();
}
@Test
public void testSalutationMessage() {
System.out.println("Inside testSalutationMessage()");
message = "Hi!" + "Robert";
assertEquals(message,messageUtil.salutationMessage());
}
}
创建测试运行器类
在 C:\>JUNIT_WORKSPACE 中创建一个名为TestRunner.java的 java 类文件来执行测试用例。
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
public class TestRunner {
public static void main(String[] args) {
Result result = JUnitCore.runClasses(TestJunit.class);
for (Failure failure : result.getFailures()) {
System.out.println(failure.toString());
}
System.out.println(result.wasSuccessful());
}
}
使用 javac 编译 MessageUtil、测试用例和测试运行器类。
C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
现在运行测试运行程序,它将运行提供的测试用例类中定义的测试用例。
C:\JUNIT_WORKSPACE>java TestRunner
验证输出。testPrintMessage() 测试用例将标记单元测试失败。
Inside testPrintMessage() Robert Inside testSalutationMessage() Hi!Robert testPrintMessage(TestJunit): test timed out after 1000 milliseconds false