JUnit提供了一个方便的Timeout选项.如果测试用例花费的时间超过指定的毫秒数,则JUnit会自动将其标记为失败. 超时参数与@Test注释一起使用.让我们看看@Test(超时)的实际效果.
创建一个类
创建一个要测试的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()); }}
创建测试运行器类
创建一个名为
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
现在运行测试Runner,它将运行在提供的Test Case类中定义的测试用例.
C:\ JUNIT_WORKSPACE> java TestRunner
验证输出. testPrintMessage()测试用例将标记单元测试失败.
Inside testPrintMessage()RobertInside testSalutationMessage()Hi!RoberttestPrintMessage(TestJunit): test timed out after 1000 millisecondsfalse