教程 > junit 教程 > 阅读:33

junit 基本用法——迹忆客-ag捕鱼王app官网

现在我们将应用简单的例子来一步一步教你如何使用 junit。

junit的一些注意事项:

  • 测试方法必须使用 @test 修饰
  • 测试方法必须使用 public void 进行修饰,不能带参数
  • 一般使用单元测试会新建一个 test 目录存放测试代码,在生产部署的时候只需要将 test 目录下代码删除即可
  • 测试代码的包应该和被测试代码包结构保持一致
  • 测试单元中的每个方法必须可以独立测试,方法间不能有任何依赖
  • 测试类一般使用 test 作为类名的后缀
  • 测试方法使一般用 test 作为方法名的前缀

测试失败说明:

  • failure: 一般是由于测试结果和预期结果不一致引发的,表示测试的这个点发现了问题
  • error: 是由代码异常引起的,它可以产生于测试代码本身的错误,也可以是被测试代码中隐藏的 bug

一些常用注解:

  • @test:将一个普通方法修饰成一个测试方法 @test(excepted=xx.class): xx.class 表示异常类,表示测试的方法抛出此异常时,认为是正常的测试通过的 @test(timeout = 毫秒数) :测试方法执行时间是否符合预期
  • @beforeclass: 会在所有的方法执行前被执行,static 方法 (全局只会执行一次,而且是第一个运行)
  • @afterclass:会在所有的方法执行之后进行执行,static 方法 (全局只会执行一次,而且是最后一个运行)
  • @before:会在每一个测试方法被运行前执行一次
  • @after:会在每一个测试方法运行后被执行一次
  • @ignore:所修饰的测试方法会被测试运行器忽略
  • @runwith:可以更改测试运行器 org.junit.runner.runner
  • parameters:参数化注解

创建一个类

c:\ > junit_workspace 路径下创建一个名为 messageutil.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;
   }   
}  

创建 test case 类

  • 创建一个名为 testjunit.java 的测试类。
  • 向测试类中添加名为 testprintmessage() 的方法。
  • 向方法中添加 annotaion @test
  • 执行测试条件并且应用 junit 的 assertequals api 来检查。

c:\ > junit_workspace路径下创建一个文件名为 testjunit.java 的类

testjunit.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());
   }
}

创建 test runner 类

  • 创建一个 testrunner
  • 运用 junit 的 junitcore 类的 runclasses 方法来运行上述测试类的测试案例
  • 获取在 result object 中运行的测试案例的结果
  • 获取 result object 的 getfailures() 方法中的失败结果
  • 获取 result object 的 wassuccessful() 方法中的成功结果

c:\ > junit_workspace 路径下创建一个文件名为 testrunner.java 的类来执行测试案例

testrunner.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 编译 messageutiltest casetest runner 类。

c:\junit_workspace>javac messageutil.java testjunit.java testrunner.java

现在运行 test runner ,它可以运行在所提供的 test case 类中定义的测试案例。

c:\junit_workspace>java testrunner

检查运行结果

hello world
true

现在更新 c:\ > junit_workspace 路径下的 testjunit,并且检测失败。改变消息字符串。

testjunit

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() {
      message = "new word";
      assertequals(message,messageutil.printmessage());
   }
}

让我们保持其他类不变,再次尝试运行相同的 test runner

test runner

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());
   }
}

现在运行在 test case 类中提供的即将运行测试案例的 test runner

c:\junit_workspace>java testrunner

检查运行结果

hello world
testprintmessage(testjunit): expected:<[new wor]d> but was:<[hello worl]d>
false

查看笔记

扫码一下
查看教程更方便
网站地图