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