JUnit中使用Hamcrest测试框架的assertThat断言【4.4新特性】

1.JUnit4.4引入了Hamcrest框架,Hamcest提供了一套匹配符Matcher,这些匹配符更接近自然语言,可读性高,更加灵活;
2.使用全新的断言语法:assertThat,结合Hamcest提供的匹配符,只用这一个方法,就可以实现所有的测试;
3.assertThat语法如下:
    assertThat(T actual, Matcher<T> matcher);
    assertThat(String reason, T actual, Matcher<T> matcher);
    其中actual为需要测试的变量,matcher为使用Hamcrest的匹配符来表达变量actual期望值的声明;
4.注意事项:
    a.必须导入JUnit4.4之后的版本才能使用assertThat方法;
    b.不需要继承TestCase类,但是需要测试方法前必须加“@Test”。
实例:
T.java:

package cn.edu.ahau.mgc.junit4;
02.   
03. import java.util.List;
04. import java.util.ArrayList;
05. import java.util.HashMap;
06. import java.util.Map;
07.   
08. public class T {
09.       
10.     public int add(int a, int b) {
11.           
12.         return a + b;
13.    }
14.       
15.     public double div(double a, double b) {
16.           
17.         return a / b;
18.    }
19.       
20.     public String getName(String name) {
21.           
22.         return name;
23.    }
24.       
25.     public List<String> getList(String item) {
26.           
27.         List<String> l = new ArrayList<String>();
28.        l.add(item);
29.         return l;
30.    }
31.       
32.     public Map<String, String> getMap(String key, String value) {
33.           
34.         Map<String, String> m = new HashMap<String, String>();
35.        m.put(key, value);
36.         return m;
37.    }
38.   
39.}
 
TTest.java:
 
01. package cn.edu.ahau.mgc.junit4.test;
02.   
03. import java.util.List;
04. import java.util.Map;
05.   
06. import org.junit.Test;
07. import static org.junit.Assert.*;
08. import cn.edu.ahau.mgc.junit4.T;
09. import static org.hamcrest.Matchers.*;
10.   
11. public class TTest {
12.   
13.    @Test
14.     public void testAdd() {
15.           
16.        //一般匹配符
17.         int s = new T().add(11);
18.        //allOf:所有条件必须都成立,测试才通过
19.        assertThat(s, allOf(greaterThan(1), lessThan(3)));
20.        //anyOf:只要有一个条件成立,测试就通过
21.        assertThat(s, anyOf(greaterThan(1), lessThan(1)));
22.        //anything:无论什么条件,测试都通过
23.        assertThat(s, anything());
24.        //is:变量的值等于指定值时,测试通过
25.        assertThat(s, is(2));
26.        //not:和is相反,变量的值不等于指定值时,测试通过
27.        assertThat(s, not(1));
28.           
29.        //数值匹配符
30.         double d = new T().div(103);
31.        //closeTo:浮点型变量的值在3.0±0.5范围内,测试通过
32.        assertThat(d, closeTo(3.00.5));
33.        //greaterThan:变量的值大于指定值时,测试通过
34.        assertThat(d, greaterThan(3.0));
35.        //lessThan:变量的值小于指定值时,测试通过
36.        assertThat(d, lessThan(3.5));
37.        //greaterThanOrEuqalTo:变量的值大于等于指定值时,测试通过
38.        assertThat(d, greaterThanOrEqualTo(3.3));
39.        //lessThanOrEqualTo:变量的值小于等于指定值时,测试通过
40.        assertThat(d, lessThanOrEqualTo(3.4));
41.           
42.        //字符串匹配符
43.         String n = new T().getName("Magci");
44.        //containsString:字符串变量中包含指定字符串时,测试通过
45.        assertThat(n, containsString("ci"));
46.        //startsWith:字符串变量以指定字符串开头时,测试通过
47.        assertThat(n, startsWith("Ma"));
48.        //endsWith:字符串变量以指定字符串结尾时,测试通过
49.        assertThat(n, endsWith("i"));
50.        //euqalTo:字符串变量等于指定字符串时,测试通过
51.        assertThat(n, equalTo("Magci"));
52.        //equalToIgnoringCase:字符串变量在忽略大小写的情况下等于指定字符串时,测试通过
53.        assertThat(n, equalToIgnoringCase("magci"));
54.        //equalToIgnoringWhiteSpace:字符串变量在忽略头尾任意空格的情况下等于指定字符串时,测试通过
55.        assertThat(n, equalToIgnoringWhiteSpace(" Magci   "));
56.           
57.        //集合匹配符
58.         List<String> l = new T().getList("Magci");
59.        //hasItem:Iterable变量中含有指定元素时,测试通过
60.        assertThat(l, hasItem("Magci"));
61.           
62.         Map<String, String> m = new T().getMap("mgc""Magci");
63.        //hasEntry:Map变量中含有指定键值对时,测试通过
64.        assertThat(m, hasEntry("mgc""Magci"));
65.        //hasKey:Map变量中含有指定键时,测试通过
66.        assertThat(m, hasKey("mgc"));
67.        //hasValue:Map变量中含有指定值时,测试通过
68.        assertThat(m, hasValue("Magci"));
69.    }
70.   
71.}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值