JUnit - 使用斷言

2022-07-26 13:40 更新

斷言

所有的斷言都包含在 Assert 類中

public class Assert extends java.lang.Object

這個類提供了很多有用的斷言方法來編寫測試用例。只有失敗的斷言才會被記錄。Assert 類中的一些有用的方法列式如下:

序號 方法和描述
1 void assertEquals(boolean expected, boolean actual)
檢查兩個變量或者等式是否平衡
2 void assertTrue(boolean condition)
檢查條件為真
3 void assertFalse(boolean condition)
檢查條件為假
4 void assertNotNull(Object object)
檢查對象不為空
5 void assertNull(Object object)
檢查對象為空
6 void assertSame(Object expected, Object actual)
assertSame() 方法檢查兩個相關(guān)對象是否指向同一個對象
7 void assertNotSame(Object expected, Object actual)
assertNotSame() 方法檢查兩個相關(guān)對象是否不指向同一個對象
8 void assertArrayEquals(expectedArray, resultArray)
assertArrayEquals() 方法檢查兩個數(shù)組是否相等

下面我們在例子中試驗一下上面提到的各種方法。在 C:\ > JUNIT_WORKSPACE 路徑下創(chuàng)建一個文件名為 TestAssertions.java 的類

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

public class TestAssertions {

   @Test
   public void testAssertions() {
      //test data
      String str1 = new String ("abc");
      String str2 = new String ("abc");
      String str3 = null;
      String str4 = "abc";
      String str5 = "abc";
      int val1 = 5;
      int val2 = 6;
      String[] expectedArray = {"one", "two", "three"};
      String[] resultArray =  {"one", "two", "three"};

      //Check that two objects are equal
      assertEquals(str1, str2);

      //Check that a condition is true
      assertTrue (val1 < val2);

      //Check that a condition is false
      assertFalse(val1 > val2);

      //Check that an object isn't null
      assertNotNull(str1);

      //Check that an object is null
      assertNull(str3);

      //Check if two object references point to the same object
      assertSame(str4,str5);

      //Check if two object references not point to the same object
      assertNotSame(str1,str3);

      //Check whether two arrays are equal to each other.
      assertArrayEquals(expectedArray, resultArray);
   }
}

接下來,我們在 C:\ > JUNIT_WORKSPACE 路徑下創(chuàng)建一個文件名為 TestRunner.java 的類來執(zhí)行測試用例

import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;

public class TestRunner2 {
   public static void main(String[] args) {
      Result result = JUnitCore.runClasses(TestAssertions.class);
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
      System.out.println(result.wasSuccessful());
   }
} 

用 javac 編譯 Test case 和 Test Runner 類

C:\JUNIT_WORKSPACE>javac TestAssertions.java TestRunner.java

現(xiàn)在運行將會運行 Test Case 類中定義和提供的測試案例的 Test Runner

C:\JUNIT_WORKSPACE>java TestRunner

檢查運行結(jié)果

true

注解

注解就好像你可以在你的代碼中添加并且在方法或者類中應用的元標簽。JUnit 中的這些注解為我們提供了測試方法的相關(guān)信息,哪些方法將會在測試方法前后應用,哪些方法將會在所有方法前后應用,哪些方法將會在執(zhí)行中被忽略。
JUnit 中的注解的列表以及他們的含義:

序號 注解和描述
1 @Test
這個注解說明依附在 JUnit 的 public void 方法可以作為一個測試案例。
2 @Before
有些測試在運行前需要創(chuàng)造幾個相似的對象。在 public void 方法加該注解是因為該方法需要在 test 方法前運行。
3 @After
如果你將外部資源在 Before 方法中分配,那么你需要在測試運行后釋放他們。在 public void 方法加該注解是因為該方法需要在 test 方法后運行。
4 @BeforeClass
在 public void 方法加該注解是因為該方法需要在類中所有方法前運行。
5 @AfterClass
它將會使方法在所有測試結(jié)束后執(zhí)行。這個可以用來進行清理活動。
6 @Ignore
這個注解是用來忽略有關(guān)不需要執(zhí)行的測試的。

C:\ > JUNIT_WORKSPACE 路徑下創(chuàng)建一個文件名為 JunitAnnotation.java 的類來測試注解

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;

public class JunitAnnotation {

   //execute before class
   @BeforeClass
   public static void beforeClass() {
      System.out.println("in before class");
   }

   //execute after class
   @AfterClass
   public static void  afterClass() {
      System.out.println("in after class");
   }

   //execute before test
   @Before
   public void before() {
      System.out.println("in before");
   }

   //execute after test
   @After
   public void after() {
      System.out.println("in after");
   }

   //test case
   @Test
   public void test() {
      System.out.println("in test");
   }

   //test case ignore and will not execute
   @Ignore
   public void ignoreTest() {
      System.out.println("in ignore test");
   }
}

接下來,我們在 C:\ > JUNIT_WORKSPACE 路徑下創(chuàng)建一個文件名為 TestRunner.java 的類來執(zhí)行注解

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(JunitAnnotation.class);
      for (Failure failure : result.getFailures()) {
         System.out.println(failure.toString());
      }
      System.out.println(result.wasSuccessful());
   }
} 

用 javac 編譯 Test case 和 Test Runner 類

C:\JUNIT_WORKSPACE>javac TestAssertions.java TestRunner.java

現(xiàn)在運行將會運行 Test Case 類中定義和提供的測試案例的 Test Runner

C:\JUNIT_WORKSPACE>java TestRunner

檢查運行結(jié)果

in before class
in before
in test
in after
in after class
true


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號