JUnit4单元测试

JUnit4单元测试

JUnit4注解

@Test

a.@Test(expect=XXException.class)表示期望抛出的异常,出现异常则测试通过
b.@Test(timeout=xx)测试是否在xx毫秒内执行
-测试方法必须使用public void修饰,且不能带有参数

@Test
public void testAdd(){
}

@BeforeClass

会在所有方法执行之前执行
- 静态方法,只执行一次,一般用于初始化

@BeforeClass
public static void setUpBeforeClass() throws Exception {
}

@Before

会在每个被@Before修饰的测试方法运行前执行一次

@Before
public void setUp() throws Exception {
}

@After

会在每个被@After修饰的测试方法运行后执行一次

@After
public void tearDown() throws Exception {
}

@AfterClass

会在所有方法执行之后执行
- 静态方法,只执行一次

@AfterClass
public static void tearDownAfterClass() throws Exception {
}

@Ignore

测试时会忽略此方法
- 一般用于修饰未完成的方法,测试时不会被执行

@Ignore
public void testIgnore(){
    fail("测试方法未完成!");
}

JUnit4运行器

Suite

  • Suite运行器用于一次性执行多个测试类中的所有@Test修饰的测试方法
@RunWith(Suite.class)//指定运行器
@SuiteClasses({CalculatorTest.class,CalculatorTest1.class})
public class SuiteTest {
/**
 * 这个类不需要包含其他方法,只用于测试套件的入口类
 */
}

Parameterized

  • Parameterized运行器用于一次性测试多组数据
@RunWith(Parameterized.class)
public class ParameterizedTest { 
    private int input1;
    private int input2;
    private int result;

    public ParameterizedTest(int input1,int input2,int result)
    {
        this.input1=input1;
        this.input2=input2;
        this.result=result;
    }

    @Parameters
    public static Collection getParams(){
        return Arrays.asList(new Object[][]{
            {1,2,3},
            {3,4,7},
            {5,6,11}
        });
    }

    @Test
    public void testAdd(){
        Calculator c = new Calculator();
        assertEquals(result, c.add(input1, input2));
    }
}
  • @Parameterized的方法用于获取测试数据集,必须用public static修饰,返回的是数据的集合
  • 构造函数用于传递测试数据集

Categories

  • Categories运行器用于将方法进行分类测试

Theories

  • Theories运行器用于测试有输入参数的方法
@RunWith(Theories.class)
public class TheoryTest {
@DataPoints
public static String[] name = {"张三","李四"};
@DataPoints
public static int age[] = {18,23};

@Theory
     public void testOut(String name , int age){
    System.out.println(String.format("%s 的年龄是 %s" ,name,age));
}}
  • @DataPoints用于创建传入的参数集,一般用public static修饰
    输出的结果为:
张三 的年龄是 18
张三 的年龄是 23
李四 的年龄是 18
李四 的年龄是 23

Assert

  • assertTure/False([String message,]boolean condition);
    判断是否为true或者false,否则输出错误信息
  • assertNull/NotNull([String message,]Object obj);
    判断对象是否为空/非空,否则输出错误信息
  • assertSame/NotSame([String message,]Object expected,Object actual);
    判断两个对象是否指向同一地址,否则输出错误信息
  • assertEquals([String message,]Object expected,Object actual);
    判断两个参数是否相等,不相等输出错误信息

AssertThat

一般匹配符

1、allOf
匹配符表明如果接下来的所有条件必须都成立测试才通过,相当于“与”(&&)
assertThat( testedNumber, allOf( greaterThan(8), lessThan(16) ) );
2、anyOf
匹配符表明如果接下来的所有条件只要有一个成立则测试通过,相当于“或”(||)
assertThat( testedNumber, anyOf( greaterThan(16), lessThan(8) ) );
3、anything
匹配符表明无论什么条件,永远为true
assertThat( testedNumber, anything() );
4、is
匹配符表明如果前面待测的object等于后面给出的object,则测试通过
assertThat( testedString, is( “developerWorks” ) );
5、not
匹配符和is匹配符正好相反,表明如果前面待测的object不等于后面给出的object,则测试通过
assertThat( testedString, not( “developerWorks” ) );

字符串相关匹配符

1、containsString
匹配符表明如果测试的字符串testedString 包含 子字符串”developerWorks”则测试通过
assertThat( testedString, containsString( “developerWorks” ) );
2、endsWith
匹配符表明如果测试的字符串testedString以子字符串”developerWorks”结尾则测试通过
assertThat( testedString, endsWith( “developerWorks” ) );
3、startsWith
匹配符表明如果测试的字符串testedString以子字符串”developerWorks”开始则测试通过
assertThat( testedString, startsWith( “developerWorks” ) );
4、equalTo
匹配符表明如果测试的testedValue等于expectedValue则测试通过,equalTo可以测试数值之间,字符串
之间和对象之间是否相等,相当于Object的equals方法
assertThat( testedValue, equalTo( expectedValue ) );
5、equalToIgnoringCase
匹配符表明如果测试的字符串testedString在忽略大小写的情况下等于”developerWorks”则测试通过
assertThat( testedString, equalToIgnoringCase( “developerWorks” ) );
6、equalToIgnoringWhiteSpace
匹配符表明如果测试的字符串testedString在忽略头尾的任意个空格的情况下等于”developerWorks”则测试通过,注意:字符串中的空格不能被忽略
assertThat( testedString, equalToIgnoringWhiteSpace( “developerWorks” ) );

数值相关匹配符

1、closeTo
匹配符表明如果所测试的浮点型数testedDouble在20.0±0.5范围之内则测试通过
assertThat( testedDouble, closeTo( 20.0, 0.5 ) );
2、greaterThan
匹配符表明如果所测试的数值testedNumber大于16.0则测试通过
assertThat( testedNumber, greaterThan(16.0) );
3、lessThan
匹配符表明如果所测试的数值testedNumber小于16.0则测试通过
assertThat( testedNumber, lessThan (16.0) );
4、greaterThanOrEqualTo
匹配符表明如果所测试的数值testedNumber大于等于16.0则测试通过
assertThat( testedNumber, greaterThanOrEqualTo (16.0) );
5、lessThanOrEqualTo
匹配符表明如果所测试的数值testedNumber小于等于16.0则测试通过
assertThat( testedNumber, lessThanOrEqualTo (16.0) );

collection相关匹配符

1、hasEntry
匹配符表明如果测试的Map对象mapObject含有一个键值为”key”对应元素值为”value”的Entry项则测试通过
assertThat( mapObject, hasEntry( “key”, “value” ) );
2、hasItem
匹配符表明如果测试的迭代对象iterableObject含有元素“element”项则测试通过
assertThat( iterableObject, hasItem ( “element” ) );
3、hasKey
匹配符表明如果测试的Map对象mapObject含有键值“key”则测试通过
assertThat( mapObject, hasKey ( “key” ) );
4、hasValue
匹配符表明如果测试的Map对象mapObject含有元素值“value”则测试通过
assertThat( mapObject, hasValue ( “key” ) );

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值