JUnit - 执行测试



测试用例将使用 JUnitCore 类执行。JUnitCore 是一个用于运行测试的门面。它支持运行 JUnit 4 测试、JUnit 3.8.x 测试以及混合使用的情况。若要从命令行运行测试,请运行 java org.junit.runner.JUnitCore <TestClass>。对于一次性测试运行,使用静态方法 runClasses(Class[])。

以下是 org.junit.runner.JUnitCore 类的声明

public class JUnitCore extends java.lang.Object

在此,我们将了解如何借助 JUnitCore 执行测试。

创建类

在 C:\>JUNIT_WORKSPACE 中创建一个要测试的 Java 类,比如 MessageUtil.java

/*
* 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 String printMessage(){
      System.out.println(message);
      return message;
   }   
	
}  

创建测试用例类

  • 创建一个 Java 测试类,比如 TestJunit.java。

  • 向测试类添加一个名为 testPrintMessage() 的测试方法。

  • 向方法 testPrintMessage() 添加注释 @Test。

  • 实施测试条件并使用 JUnit 的 assertEquals API 检查条件。

在 C:\>JUNIT_WORKSPACE 中创建一个名为 TestJunit.java 的 Java 类文件。

import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class TestJunit {
	
   String message = "Hello World";	
   MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {
      assertEquals(message,messageUtil.printMessage());
   }
}

创建测试运行器类

现在,在 C:\>JUNIT_WORKSPACE 中创建一个名为 TestRunner.java 的 Java 类文件来执行测试用例。它导入 JUnitCore 类,并使用接收测试类名为其参数的 runClasses() 方法。

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 编译测试用例类和测试运行器类。

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

现在,运行测试运行器,它将运行在提供的测试用例类中定义的测试用例。

C:\JUNIT_WORKSPACE>java TestRunner

验证输出。

Hello World
true
广告
© . All rights reserved.