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