- 0x01 下载和导入
- 0x02 Junit4注解
- 0x21 常用注解
- 0x22 执行顺序
- 0x04 常用API
- 0x41 Assert类
- 0x42 TestCase
- 0x44 TestResult
- 0x48 TestSuite
- 0x08 参数化测试
0x01 下载和导入
从官网上下载jnit.jar和hamcrest-core.jar两个包,并且导入到IntellijIDE中。后续使用maven,就不用那么麻烦
导包时需要注意,有一个是需要静态导入
0x02 Junit4注解
-
常用注解
@BeforeClass
注解
被@BeforeClass注解的方法会是:只被执行一次运行junit测试类时第一个被执行的方法
这样的方法被用作执行计算代价很大的任务,如打开数据库连接。被@BeforeClass 注解的方法应该是静态的(即 static类型的).@AfterClass
注解
被@AfterClass注解的方法应是:只被执行一次运行junit测试类是最后一个被执行的方法
该类型的方法被用作执行类似关闭数据库连接的任务。被@AfterClass 注解的方法应该是静态的(即 static类型的).@Before
注解
被@Before 注解的方法应是:junit测试类中的任意一个测试方法执行 前 都会执行此方法
该类型的方法可以被用来为测试方法初始化所需的资源。@After
注解
被@After注解的方法应是:junit测试类中的任意一个测试方法执行后 都会执行此方法, 即使被@Test 或 @Before修饰的测试方法抛出异常
该类型的方法被用来关闭由@Before注解修饰的测试方法打开的资源。@Test
注解
被@Test注解的测试方法包含了真正的测试代码,并且会被Junit应用为要测试的方法。@Test注解有两个可选的参数:expected 表示此测试方法执行后应该抛出的异常,(值是异常名)
timeout 检测测试方法的执行时间@Ignore
这个注释是用来忽略有关不需要执行的测试的。如果是测试类被加上该注释,则类中所有的测试方法都会被跳过。@Timeout
如果测试方法的执行时间大于指定的超时参数,测试方法将抛出异常,测试结果为失败。指定的超时参数是以毫秒记.
-
执行顺序
上面的注解是按照一个流程来执行的,如下@BeforeClass
@before
@test
@after
@AfterClass 代码
-
执行结果
0x04 用API
-
0x41 Assert类
Junit 4 断言方法允许检查测试方法的期望结果值和真实返回值
|方法|描述|
|----|----|
|assertNull(java.lang.Object object)|检查对象是否为空
|assertNotNull(java.lang.Object object)|检查对象是否不为空
|assertEquals(long expected, long actual)|检查long类型的值是否相等
|assertEquals(double expected, double actual, double delta)|检查指定精度的double值是否相等
|assertFalse(boolean condition)|检查条件是否为假
|assertTrue(boolean condition)|检查条件是否为真
|assertSame(java.lang.Object expected, java.lang.Object actual)|检查两个对象引用是否引用同一对象(即对象是否相等)
|assertNotSame(java.lang.Object unexpected, java.lang.Object actual)|检查两个对象引用是否不引用统一对象(即对象不等) -
代码
-
执行结果
全部通过
0x42 TestCase
0x44 TestResult
-
0x48 TestSuite套件测试
测试套件意味着捆绑几个单元测试用例并且一起执行他们
当运行时,所有包含在@SuiteClasses注解内的所有测试类都会被执行。- 注解
@RunWith(Suite.class)
@SuiteClasses(TestClass1.class, TestClass2.class)
- 注解