JUnit-어설 션 사용

역설

모든 어설 션은 Assert 클래스에 있습니다.

public class Assert extends java.lang.Object

이 클래스는 테스트 작성에 유용한 어설 션 메서드 집합을 제공합니다. 실패한 주장 만 기록됩니다. Assert 클래스의 중요한 방법은 다음과 같습니다.

Sr. 아니. 방법 및 설명
1

void assertEquals(boolean expected, boolean actual)

두 개의 기본 요소 / 객체가 동일한 지 확인합니다.

2

void assertTrue(boolean condition)

조건이 참인지 확인합니다.

void assertFalse(boolean condition)

조건이 거짓인지 확인합니다.

4

void assertNotNull(Object object)

개체가 null이 아닌지 확인합니다.

5

void assertNull(Object object)

개체가 null인지 확인합니다.

6

void assertSame(object1, object2)

assertSame () 메서드는 두 개체 참조가 동일한 개체를 가리키는 지 테스트합니다.

7

void assertNotSame(object1, object2)

assertNotSame () 메서드는 두 개체 참조가 동일한 개체를 가리 키지 않는지 테스트합니다.

8

void assertArrayEquals(expectedArray, resultArray);

assertArrayEquals () 메서드는 두 배열이 서로 같은지 테스트합니다.

위에서 언급 한 방법 중 일부를 예제에서 사용해 보겠습니다. 다음과 같은 Java 클래스 파일을 만듭니다.TestAssertions.java C : \> JUNIT_WORKSPACE.

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

다음으로, Java 클래스 파일을 만듭니다. TestRunner.java C : \> JUNIT_WORKSPACE에서 테스트 케이스를 실행합니다.

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를 사용하여 테스트 케이스 및 테스트 실행기 클래스를 컴파일하십시오.

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

이제 제공된 테스트 케이스 클래스에 정의 된 테스트 케이스를 실행하는 테스트 실행기를 실행하십시오.

C:\JUNIT_WORKSPACE>java TestRunner

출력을 확인하십시오.

true

주석

주석은 코드에 추가하고 메서드 나 클래스에 적용 할 수있는 메타 태그와 같습니다. JUnit의 이러한 주석은 테스트 방법에 대한 다음 정보를 제공합니다.

  • 테스트 메소드 전후에 실행할 메소드.
  • 모든 방법의 전후에 실행되는 방법
  • 실행 중에 무시 될 메서드 또는 클래스

다음 표는 JUnit에서 주석 목록과 그 의미를 제공합니다.

Sr. 아니. 주석 및 설명
1

@Test

Test 어노테이션은 JUnit에 첨부 된 public void 메소드가 테스트 케이스로 실행될 수 있음을 알려줍니다.

2

@Before

여러 테스트를 실행하려면 유사한 개체를 만들어야합니다. @Before를 사용하여 public void 메서드에 주석을 추가하면 해당 메서드가 각 Test 메서드 전에 실행됩니다.

@After

Before 메서드에서 외부 리소스를 할당하는 경우 테스트 실행 후 해제해야합니다. @After를 사용하여 public void 메서드에 주석을 추가하면 해당 메서드가 Test 메서드 이후에 실행됩니다.

4

@BeforeClass

@BeforeClass를 사용하여 public static void 메서드에 주석을 추가하면 클래스의 테스트 메서드보다 먼저 실행됩니다.

5

@AfterClass

모든 테스트가 완료된 후 메서드가 수행됩니다. 이것은 정리 활동을 수행하는 데 사용할 수 있습니다.

6

@Ignore

Ignore 주석은 테스트를 무시하는 데 사용되며 해당 테스트는 실행되지 않습니다.

다음과 같은 Java 클래스 파일을 만듭니다. JunitAnnotation.java C : \> JUNIT_WORKSPACE에서 주석을 테스트합니다.

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

다음으로, Java 클래스 파일을 만듭니다. TestRunner.java C : \> JUNIT_WORKSPACE에서 주석을 실행합니다.

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를 사용하여 테스트 케이스 및 테스트 실행기 클래스를 컴파일하십시오.

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

이제 제공된 테스트 케이스 클래스에 정의 된 테스트 케이스를 실행하는 테스트 실행기를 실행하십시오.

C:\JUNIT_WORKSPACE>java TestRunner

출력을 확인하십시오.

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