JUnit - 時間測試



JUnit 提供了一個超時的便捷選項。如果測試用例的時間超出了指定的毫秒數,則 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());
   }
}

建立測試執行器類

在 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
廣告