JUnit – 时间测试

扫码关注公众号:Java 技术驿站

发送:vip
将链接复制到本浏览器,永久解锁本站全部文章

【公众号:Java 技术驿站】 【加作者微信交流技术,拉技术群】

JUnit - 时间测试

Junit 提供了一个暂停的方便选项。如果一个测试用例比起指定的毫秒数花费了更多的时间,那么 Junit 将自动将它标记为失败。timeout 参数和 @Test 注释一起使用。现在让我们看看活动中的 @test(timeout)。

创建一个类

  • 创建一个在 C:\JUNIT_WORKSPACE 中叫做 MessageUtil.java 的 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;
       }   
    } 

创建 Test Case 类

  • 创建一个叫做 TestJunit.java 的 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());
       }
    }

创建 Test Runner 类

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,Test case 和 Test Runner 类。

    C:\JUNIT_WORKSPACE>javac MessageUtil.java TestJunit.java TestRunner.java

现在运行 Test Runner,它将运行由提供的 Test Case 类中所定义的测试用例。

    C:\JUNIT_WORKSPACE>java TestRunner

验证输出。testPrintMessage() 测试用例将标记单元测试失败。

    Inside testPrintMessage()
    Robert
    Inside testSalutationMessage()
    Hi!Robert
    testPrintMessage(TestJunit): test timed out after 1000 milliseconds
    false

作者:w3cschool 来源:https://www.w3cschool.cn

赞(0) 打赏
版权归原创作者所有,任何形式的转载请联系博主:daming_90:Java 技术驿站 » JUnit – 时间测试

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏