Junit框架使用--JUnit常用断言及注解

--------------------- 本文来自 xjanting 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/smxjant/article/details/78206435?utm_source=copy

软件测试方法:等价类划分法https://www.cnblogs.com/whylaughing/p/5821812.html

一、核心——断言

断言是编写测试用例的核心实现方式,即期望值是多少,测试的结果是多少,以此来判断测试是否通过。

1. 断言核心方法

assertArrayEquals(expecteds, actuals) 查看两个数组是否相等。
assertEquals(expected, actual) 查看两个对象是否相等。类似于字符串比较使用的equals()方法
assertNotEquals(first, second) 查看两个对象是否不相等。
assertNull(object) 查看对象是否为空。
assertNotNull(object) 查看对象是否不为空。
assertSame(expected, actual) 查看两个对象的引用是否相等。类似于使用“==”比较两个对象
assertNotSame(unexpected, actual) 查看两个对象的引用是否不相等。类似于使用“!=”比较两个对象
assertTrue(condition) 查看运行结果是否为true。
assertFalse(condition) 查看运行结果是否为false。
assertThat(actual, matcher) 查看实际值是否满足指定的条件
fail() 让测试失败

二、核心——注解

1. 说明

@Before 初始化方法
@After 释放资源
@Test 测试方法,在这里可以测试期望异常和超时时间
@Ignore 忽略的测试方法
@BeforeClass 针对所有测试,只执行一次,且必须为static void
@AfterClass 针对所有测试,只执行一次,且必须为static void
@RunWith 指定测试类使用某个运行器
@Parameters 指定测试类的测试数据集合
@Rule 允许灵活添加或重新定义测试类中的每个测试方法的行为
@FixMethodOrder 指定测试方法的执行顺序

2. 执行顺序

一个测试类单元测试的执行顺序为:

@BeforeClass –> @Before –> @Test –> @After –> @AfterClass

每一个测试方法的调用顺序为:

@Before –> @Test –> @After

如果需要是用assertThat需要在项目中引入junit4的jar包.(匹配器和断言方法在junit4的jar包中都能找到,引入就可以了)

下面是常用断言的代码

复制代码

 1 import static org.hamcrest.MatcherAssert.*;

 2 import static org.hamcrest.CoreMatchers.*;   
 4  import java.util.ArrayList;
 5  import java.util.HashMap;
 6  import java.util.List;
 7  import java.util.Map;
 8   
 9  import org.junit.Before;
10  import org.junit.Test;
11   
12  import com.lyh.share.model.User;
13   
14  public class UserDaoTest {
15           
16          private User test1;
17          private User test2;
18           
19          @Before
20          public void init(){
21                  test1 = new User();
22                  test1.setUsername("tt1");
23                  test1.setPassword("123");
24                  test1.setShares(50);
25                  test2 = new User();
26                  test2.setUsername("tt2");
27                  test2.setPassword("321");
28                  test2.setShares(20);
29          }
30           
31          @Test
32          public void findUser(){
33                   
34                  /**数值匹配**/
35                  //测试变量是否大于指定值
36                  assertThat(test1.getShares(), greaterThan(50));
37                  //测试变量是否小于指定值
38                  assertThat(test1.getShares(), lessThan(100));
39                  //测试变量是否大于等于指定值
40                  assertThat(test1.getShares(), greaterThanOrEqualTo(50));
41                  //测试变量是否小于等于指定值
42                  assertThat(test1.getShares(), lessThanOrEqualTo(100));
43                   
44                  //测试所有条件必须成立
45                  assertThat(test1.getShares(), allOf(greaterThan(50),lessThan(100)));
46                  //测试只要有一个条件成立
47                  assertThat(test1.getShares(), anyOf(greaterThanOrEqualTo(50), lessThanOrEqualTo(100)));
48                  //测试无论什么条件成立(还没明白这个到底是什么意思)
49                  assertThat(test1.getShares(), anything());
50                  //测试变量值等于指定值
51                  assertThat(test1.getShares(), is(100));
52                  //测试变量不等于指定值
53                  assertThat(test1.getShares(), not(50));
54                   
55                  /**字符串匹配**/
56                  String url = "http://www.taobao.com";
57                  //测试变量是否包含指定字符
58                  assertThat(url, containsString("taobao"));
59                  //测试变量是否已指定字符串开头
60                  assertThat(url, startsWith("http://"));
61                  //测试变量是否以指定字符串结尾
62                  assertThat(url, endsWith(".com"));
63                  //测试变量是否等于指定字符串
64                  assertThat(url, equalTo("http://www.taobao.com"));
65                  //测试变量再忽略大小写的情况下是否等于指定字符串
66                  assertThat(url, equalToIgnoringCase("http://www.taobao.com"));
67                  //测试变量再忽略头尾任意空格的情况下是否等于指定字符串
68                  assertThat(url, equalToIgnoringWhiteSpace("http://www.taobao.com"));
69                   
70                   
71                  /**集合匹配**/
72                   
73                  List<User> user = new ArrayList<User>();
74                  user.add(test1);
75                  user.add(test2);
76                   
77                  //测试集合中是否还有指定元素
78                  assertThat(user, hasItem(test1));
79                  assertThat(user, hasItem(test2));
80   
81                  /**Map匹配**/
82                  Map<String,User> userMap = new HashMap<String,User>();
83                  userMap.put(test1.getUsername(), test1);
84                  userMap.put(test2.getUsername(), test2);
85                   
86                  //测试map中是否还有指定键值对
87                  assertThat(userMap, hasEntry(test1.getUsername(), test1));
88                  //测试map中是否还有指定键
89                  assertThat(userMap, hasKey(test2.getUsername()));
90                  //测试map中是否还有指定值
91                  assertThat(userMap, hasValue(test2));
92          }
93           
94  }

复制代码

㈠ 一般匹配符

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

猜你喜欢

转载自blog.csdn.net/qq_38984851/article/details/82907213