JUnit - 时间测试
-
简述
JUnit 提供了一个方便的超时选项。如果测试用例花费的时间超过指定的毫秒数,则 JUnit 会自动将其标记为失败。这timeout参数与@Test 注释一起使用。让我们看看@Test(timeout) 的作用。 -
创建一个类
创建一个要测试的java类,比如说, MessageUtil.java 在 C:\>JUNIT_WORKSPACE 中。在 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. 将超时 1000 添加到 testPrintMessage() 测试用例。创建一个名为的java类文件 TestJunit.java 在 C:\>JUNIT_WORKSPACE 中。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()); } }
-
创建测试运行程序类
创建一个名为的java类文件 TestRunner.java 在 C:\>JUNIT_WORKSPACE 中执行测试用例。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 类。C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java
现在运行 Test Runner,它将运行在提供的测试用例类中定义的测试用例。C:\JUNIT_WORKSPACE>java TestRunner
验证输出。testPrintMessage() 测试用例将标记单元测试失败。Inside testPrintMessage() Robert Inside testSalutationMessage() Hi!Robert testPrintMessage(TestJunit): test timed out after 1000 milliseconds false