JUnit – 时间测试
云少十二、JUnit – 时间测试
Junit 提供了一个暂停的方便选项。如果一个测试用例比起指定的毫秒数花费了更多的时间,那么 Junit 将自动将它标记为失败。timeout 参数和 @Test 注释一起使用。现在让我们看看活动中的 @test(timeout)。
创建一个类
- 创建一个在 C:\JUNIT_WORKSPACE 中叫做 MessageUtil.java 的 java 类来测试。
- 在 printMessage() 方法内添加一个无限 while 循环。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
|
public class MessageUtil {
private String message;
public MessageUtil(String message){ this.message = message; }
public void printMessage(){ System.out.println(message); while(true); }
public String salutationMessage(){ message = "Hi!" + message; System.out.println(message); return message; } }
|
创建 Test Case 类
- 创建一个叫做 TestJunit.java 的 java 测试类。
- 给 testPrintMessage() 测试用例添加 1000 的暂停时间。
在 C:\JUNIT_WORKSPACE 中创建一个文件名为 TestJunit.java 的 java 类。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| 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()); } }
|
创建 Test Runner 类
在 C:\JUNIT_WORKSPACE 中创建一个文件名为 TestRunner.java 的 java 类来执行测试样例。
1 2 3 4 5 6 7 8 9 10 11 12 13
| 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,Test case 和 Test Runner 类。
1
| C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
|
现在运行 Test Runner,它将运行由提供的 Test Case 类中所定义的测试用例。
1
| C:\JUNIT_WORKSPACE>java TestRunner
|
验证输出。testPrintMessage() 测试用例将标记单元测试失败。
1 2 3 4 5 6
| Inside testPrintMessage() Robert Inside testSalutationMessage() Hi!Robert testPrintMessage(TestJunit): test timed out after 1000 milliseconds false
|