JUnit 单元测试断言推荐 AssertJ

前言

    由于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

 

整理一些常用的例子如下

 

对字符串断言

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

 

对数字断言

    @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();
    }

 

 对日期断言

@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断言

    @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断言

    @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断言

    @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方法

    @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等等很多的断言支持。

 

永久链接: http://sgq0085.iteye.com/blog/2030609

你可能感兴趣的:(JUnit,assert,unit test,断言,AssertJ)