断言(assertions)机制

断言(assertions)机制

  • 断言(assertions)是测试方法中的核心部分,用来对测试需要满足的条件进行验证。这些断言方法都是 org.junit.jupiter.api.Assertions 的静态方法。JUnit 5 内置的断言可以分成如下几个类别:
    检查业务逻辑返回的数据是否合理。
  • 所有的测试运行结束以后,会有一个详细的测试报告;

1、简单断言

用来对单个值进行简单的验证。如:
在这里插入图片描述

/**
     *断言:前面断言失败,后面的代码都不会执行
     */
    @DisplayName("测试简单断言")
    @Test
    void testSimpleAssertions(){
    
    
        int cal = cal(2, 3);
        assertEquals(5,cal ,"业务逻辑失败");

        Object o = new Object();
        Object o1 = new Object();
        assertSame(o,o1,"两个对象不一样");
    }

2、数组断言

通过 assertArrayEquals 方法来判断两个对象或原始类型的数组是否相等

	 @Test
    @DisplayName("array assertion")
    public void array() {
    
    
        assertArrayEquals(new int[]{
    
    2, 2}, new int[] {
    
    1, 2},"数组内容不相等");
    }

3、组合断言

assertAll 方法接受多个 org.junit.jupiter.api.Executable 函数式接口的实例作为要验证的断言,可以通过 lambda 表达式很容易的提供这些断言

	@Test
    @DisplayName("组合断言")
    void all() {
    
    
        //所有断言全部需要成功
        assertAll("test",
                () -> assertTrue(true && true),
                () -> assertEquals(1, 2));
    }

4、异常断言

在JUnit4时期,想要测试方法的异常情况时,需要用@Rule注解的ExpectedException变量还是比较麻烦的。而JUnit5提供了一种新的断言方式Assertions.assertThrows() ,配合函数式编程就可以进行使用。

	@Test
    @DisplayName("异常断言")
    //断言业务逻辑一定出现异常
    public void exceptionTest() {
    
    
        assertThrows(ArithmeticException.class,() ->{
    
    int i =1/0;},"业务逻辑居然正常运行?");
    }

5、超时断言

Junit5还提供了Assertions.assertTimeout() 为测试方法设置了超时时间

	@Test
    @DisplayName("超时断言")
    public void timeoutTest() {
    
    
        //如果测试方法时间超过1s将会异常
        Assertions.assertTimeout(Duration.ofMillis(1000), () -> Thread.sleep(500));
    }

6、快速失败

通过 fail 方法直接使得测试失败

	@Test
    @DisplayName("快速断言")
    public void shouldFail() {
    
    
        fail("测试失败");
    }

猜你喜欢

转载自blog.csdn.net/weixin_51600120/article/details/114951924