JUnit使用声明
断言
所有的断言都在Assert类中。
public class Assert extends java.lang.Object
这个类提供了一组断言方法,对编写测试有用。只记录失败的断言。Assert类的一些重要方法如下 -
Sr.No. | 方法和说明 |
---|---|
1 | **void assertEquals(boolean expected,布尔实际值)** 检查两个基元/对象是否相等。 |
2 | **void assertTrue(布尔条件)** 检查条件是否成立。 |
3 | **void assertFalse(布尔条件)** 检查条件是否为假。 |
4 | **void assertNotNull(Object object)** 检查一个对象是否为空。 |
五 | **void assertNull(Object object)** 检查一个对象是否为空。 |
6 | **void assertSame(object1,object2)** assertSame()方法测试两个对象引用是否指向同一个对象。 |
7 | **void assertNotSame(object1,object2)** assertNotSame()方法测试两个对象引用是否不指向同一个对象。 |
8 | **void assertArrayEquals(expectedArray,resultArray);** assertArrayEquals()方法将测试两个数组是否彼此相等。 |
在示例中,我们使用一些上述方法。在C:> JUNIT_WORKSPACE中创建一个名为 TestAssertions.java 的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中创建一个名为 TestRunner.java 的java类文件来执行测试用例。
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
现在运行Test Runner,它将运行提供的Test Case类中定义的测试用例。
C:\JUNIT_WORKSPACE>java TestRunner
验证输出。
true
注解
注释就像元标签一样,您可以将其添加到代码中,并将其应用于方法或类中。JUnit中的这些注释提供了有关测试方法的以下信息 -
- 哪些方法将在测试方法之前和之后运行。
- 哪些方法在所有方法之前和之后运行,以及。
- 在执行过程中哪些方法或类将被忽略。
下表提供了JUnit中的注释列表及其含义 -
Sr.No. | 注释和说明 |
---|---|
1 | **@测试** Test注解告诉JUnit它所连接的public void方法可以作为测试用例运行。 |
2 | **@之前** 几个测试需要在运行之前创建类似的对象。使用@Before注释一个公共无效方法会导致该方法在每个Test方法之前运行。 |
3 | **@后** 如果您在Before方法中分配外部资源,则需要在测试运行后释放它们。使用@After注释一个公共无效方法会导致该方法在Test方法之后运行。 |
4 | **@课前** 使用@BeforeClass注释公共静态void方法会导致它在该类中的任何测试方法之前运行一次。 |
五 | **@下课以后** 这将在所有测试完成后执行该方法。这可以用来执行清理活动。 |
6 | **@忽视** Ignore注释用于忽略测试,并且该测试不会执行。 |
在C:> JUNIT_WORKSPACE中创建一个名为 JunitAnnotation.java 的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中创建一个名为 TestRunner.java 的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(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
现在运行Test Runner,它将运行提供的Test Case类中定义的测试用例。
C:\JUNIT_WORKSPACE>java TestRunner
验证输出。
in before class
in before
in test
in after
in after class
true