前言
由于JUnit的Assert是公认的烂API,所以不推荐使用,目前推荐使用的是AssertJ。
AssertJ网站: http://joel-costigliola.github.io/assertj/
github上examples 地址 https://github.com/joel-costigliola/assertj-examples
附件中assertj-examples-octo-assertj-core-1.5.0是官方examples
整理一些常用的例子如下
对字符串断言
Java代码
- @Test
- public void testString() {
- String str = null;
- // 断言null或为空字符串
- assertThat(str).isNullOrEmpty();
- // 断言空字符串
- assertThat("").isEmpty();
- // 断言字符串相等 断言忽略大小写判断字符串相等
- assertThat("Frodo").isEqualTo("Frodo").isEqualToIgnoringCase("frodo");
- // 断言开始字符串 结束字符穿 字符串长度
- assertThat("Frodo").startsWith("Fro").endsWith("do").hasSize(5);
- // 断言包含字符串 不包含字符串
- assertThat("Frodo").contains("rod").doesNotContain("fro");
- // 断言字符串只出现过一次
- assertThat("Frodo").containsOnlyOnce("do");
- // 判断正则匹配
- assertThat("Frodo").matches("..o.o").doesNotMatch(".*d");
- }
对数字断言
Java代码
- @Test
- public void testNumber() {
- Integer num = null;
- // 断言空
- assertThat(num).isNull();
- // 断言相等
- assertThat(42).isEqualTo(42);
- // 断言大于 大于等于
- assertThat(42).isGreaterThan(38).isGreaterThanOrEqualTo(38);
- // 断言小于 小于等于
- assertThat(42).isLessThan(58).isLessThanOrEqualTo(58);
- // 断言0
- assertThat(0).isZero();
- // 断言正数 非负数
- assertThat(1).isPositive().isNotNegative();
- // 断言负数 非正数
- assertThat(-1).isNegative().isNotPositive();
- }
对日期断言
Java代码
- @Test
- public void testDate() {
- // 断言与指定日期相同 不相同 在指定日期之后 在指定日期之钱
- assertThat(Dates.parse("2014-02-01")).isEqualTo("2014-02-01").isNotEqualTo("2014-01-01")
- .isAfter("2014-01-01").isBefore(parse("2014-03-01"));
- // 断言 2014 在指定年份之前 在指定年份之后
- assertThat(DateTime.now().toDate()).isBeforeYear(2020).isAfterYear(2013);
- // 断言时间再指定范围内 不在指定范围内
- assertThat(parse("2014-02-01")).isBetween("2014-01-01", "2014-03-01").isNotBetween(
- parse("2014-02-02"), parse("2014-02-28"));
- // 断言两时间相差100毫秒
- Date d1 = new Date();
- Date d2 = new Date(d1.getTime() + 100);
- assertThat(d1).isCloseTo(d2, 100);
- // sets dates differing more and more from date1
- Date date1 = Dates.parseDatetimeWithMs("2003-01-01T01:00:00.000");
- Date date2 = parseDatetimeWithMs("2003-01-01T01:00:00.555");
- Date date3 = parseDatetimeWithMs("2003-01-01T01:00:55.555");
- Date date4 = parseDatetimeWithMs("2003-01-01T01:55:55.555");
- Date date5 = parseDatetimeWithMs("2003-01-01T05:55:55.555");
- // 断言 日期忽略毫秒,与给定的日期相等
- assertThat(date1).isEqualToIgnoringMillis(date2);
- // 断言 日期与给定的日期具有相同的年月日时分秒
- assertThat(date1).isInSameSecondAs(date2);
- // 断言 日期忽略秒,与给定的日期时间相等
- assertThat(date1).isEqualToIgnoringSeconds(date3);
- // 断言 日期与给定的日期具有相同的年月日时分
- assertThat(date1).isInSameMinuteAs(date3);
- // 断言 日期忽略分,与给定的日期时间相等
- assertThat(date1).isEqualToIgnoringMinutes(date4);
- // 断言 日期与给定的日期具有相同的年月日时
- assertThat(date1).isInSameHourAs(date4);
- // 断言 日期忽略小时,与给定的日期时间相等
- assertThat(date1).isEqualToIgnoringHours(date5);
- // 断言 日期与给定的日期具有相同的年月日
- assertThat(date1).isInSameDayAs(date5);
- }
对List断言
Java代码
- @Test
- public void testList() {
- // 断言 列表是空的
- assertThat(newArrayList()).isEmpty();
- // 断言 列表的开始 结束元素
- assertThat(newArrayList(1, 2, 3)).startsWith(1).endsWith(3);
- // 断言 列表包含元素 并且是排序的
- assertThat(newArrayList(1, 2, 3)).contains(1, atIndex(0)).contains(2, atIndex(1)).contains(3)
- .isSorted();
- // 断言 被包含与给定列表
- assertThat(newArrayList(3, 1, 2)).isSubsetOf(newArrayList(1, 2, 3, 4));
- // 断言 存在唯一元素
- assertThat(Lists.newArrayList("a", "b", "c")).containsOnlyOnce("a");
- }
对Map断言
Java代码
- @Test
- public void testMap() {
- Map<String, Object> foo = Maps.newHashMap();
- foo.put("A", 1);
- foo.put("B", 2);
- foo.put("C", 3);
- // 断言 map 不为空 size
- assertThat(foo).isNotEmpty().hasSize(3);
- // 断言 map 包含元素
- assertThat(foo).contains(entry("A", 1), entry("B", 2));
- // 断言 map 包含key
- assertThat(foo).containsKeys("A", "B", "C");
- // 断言 map 包含value
- assertThat(foo).containsValue(3);
- }
对Class断言
Java代码
- @Test
- public void testClass() {
- // 断言 是注解
- assertThat(Magical.class).isAnnotation();
- // 断言 不是注解
- assertThat(Ring.class).isNotAnnotation();
- // 断言 存在注解
- assertThat(Ring.class).hasAnnotation(Magical.class);
- // 断言 不是借口
- assertThat(Ring.class).isNotInterface();
- // 断言 是否为指定Class实例
- assertThat("string").isInstanceOf(String.class);
- // 断言 类是给定类的父类
- assertThat(Person.class).isAssignableFrom(Employee.class);
- }
- @Magical
- public enum Ring {
- oneRing, vilya, nenya, narya, dwarfRing, manRing;
- }
- @Target(ElementType.TYPE)
- @Retention(RetentionPolicy.RUNTIME)
- public @interface Magical {}
- public class Person {}
- public class Employee extends Person {}
使用fail方法
Java代码
- @Test
- public void testFail() {
- try {
- fail("在不检查任何条件的情况下使断言失败。显示一则消息");
- } catch (AssertionError ae) {
- logger.info("可以通过catch捕获该Error");
- }
- try {
- failBecauseExceptionWasNotThrown(ServiceException.class);
- } catch (AssertionError ae) {
- logger.info("可以通过catch捕获该Error");
- }
- }
除此之外,还提供包括Exception、Iterable、JodaTime、Guava等等很多的断言支持。