Spring Boot 单元测试(五)自定义测试顺序

​​​​​​​

目录

一、内置排序方式

1. 方法名字母数字排序

2. 按照@DisplayName排序

3. 按照方法名排序

4. 按照@Order排序

5. 随机排序

二、自定义排序

三、设置默认排序


Spring Boot 通过 JUnit5 提供的@TestMethodOrder注解控制测试执行顺序,共有五种内置的排序方式。

一、内置排序方式

1. 方法名字母数字排序

将测试类上@TestMethodOrder注解参数值设置为MethodOrderer.Alphanumeric.class,自 JUnit 5.7 版本开始标记为DEPRECATED,建议使用MethodOrderer.MethodName.class代替。

2. 按照@DisplayName排序

将测试类上@TestMethodOrder注解参数值设置为MethodOrderer.DisplayName.class

package com.example.demo;

import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(MethodOrderer.DisplayName.class)
public class UnitTest {

    @Test
    @DisplayName("The second test")
    public void test1() {
        System.out.println("Test 1");
    }

    @Test
    @DisplayName("The third test")
    public void test2() {
        System.out.println("Test 2");
    }

    @Test
    @DisplayName("The first test")
    public void test3() {
        System.out.println("Test 3");
    }
}

测试输出:

Test 3
Test 1
Test 2

3. 按照方法名排序

将测试类上@TestMethodOrder注解参数值设置为MethodOrderer.MethodName.class

package com.example.demo;

import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(MethodOrderer.MethodName.class)
public class UnitTest {

    @Test
    public void testC() {
        System.out.println("Test C");
    }

    @Test
    public void testX() {
        System.out.println("Test X");
    }

    @Test
    public void testA() {
        System.out.println("Test A");
    }

    @Test
    public void test0() {
        System.out.println("Test 0");
    }

    @Test
    public void testB() {
        System.out.println("Test B");
    }
}

测试输出:

Test 0
Test A
Test B
Test C
Test X

4. 按照@Order排序

  1. 将测试类上@TestMethodOrder注解参数值设置为MethodOrderer.OrderAnnotation.class
  2. 为测试方法添加@Order(X)注解,参数值X是整数,整数越小越先执行。
package com.example.demo;

import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class UnitTest {

    @Test
    @Order(1)
    public void test1() {
        System.out.println("Test 1");
    }

    @Test
    @Order(2)
    public void test2() {
        System.out.println("Test 2");
    }

    @Test
    @Order(3)
    public void test3() {
        System.out.println("Test 3");
    }

    @Test
    @Order(0)
    public void test0() {
        System.out.println("Test 0");
    }
}

测试输出:

Test 0
Test 1
Test 2
Test 3

5. 随机排序

将测试类上@TestMethodOrder注解参数值设置为MethodOrderer.Random.class

package com.example.demo;

import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(MethodOrderer.Random.class)
public class UnitTest {

    @Test
    public void test1() {
        System.out.println("Test 1");
    }

    @Test
    public void test2() {
        System.out.println("Test 2");
    }

    @Test
    public void test3() {
        System.out.println("Test 3");
    }

    @Test
    public void test0() {
        System.out.println("Test 0");
    }
}

每次测试输出结果可能不同。

二、自定义排序

自定义排序必须实现MethodOrderer接口。

package com.example.demo;

import org.junit.jupiter.api.MethodDescriptor;
import org.junit.jupiter.api.MethodOrderer;
import org.junit.jupiter.api.MethodOrdererContext;

public class CustomOrder implements MethodOrderer {

    @Override
    public void orderMethods(MethodOrdererContext context) {
        context.getMethodDescriptors().sort(
                (MethodDescriptor x, MethodDescriptor y) -> y.getMethod().getName()
                        .compareToIgnoreCase(x.getMethod().getName()));
    }
}

指定@TestMethodOrder注解参数为自定义排序类。

package com.example.demo;

import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder;

@TestMethodOrder(CustomOrder.class)
public class UnitTest {

    @Test
    public void testC() {
        System.out.println("Test C");
    }

    @Test
    public void testX() {
        System.out.println("Test X");
    }

    @Test
    public void testA() {
        System.out.println("Test A");
    }
}

测试输出结果和自定义排序匹配(方法名称倒序)。

Test X
Test C
Test A

三、设置默认排序

package com.example.demo;

import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;

public class UnitTest {

    @Test
    @DisplayName("Test 3")
    public void testC() {
        System.out.println("Test C");
    }

    @Test
    @DisplayName("Test 2")
    public void testX() {
        System.out.println("Test X");
    }

    @Test
    @DisplayName("Test 1")
    public void testA() {
        System.out.println("Test A");
    }
}

以上测试如果不设置默认排序,输出结果为:

Test A
Test C
Test X

如果要设置默认排序,需要在src/test/resources目录下新增junit-platform.properties文件,文件内容为:

junit.jupiter.testmethod.order.default = org.junit.jupiter.api.MethodOrderer$DisplayName

再次执行测试,输出结果为:

Test A
Test X
Test C

注意:按照此方法设置的默认排序只对不带@TestMethodOrder注解的测试生效,且junit-platform.properties文件中指定的类必须实现MethodOrderer接口。


作者:又语
链接:https://juejin.cn/post/7041886698464083998
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot自定义 Filter 主要分为以下几个步骤: 1. 创建一个类并实现 javax.servlet.Filter 接口; 2. 在类上添加 @Component 注解将其注册为一个 Spring Bean; 3. 重写 Filter 接口的 doFilter 方法,并在其中编写过滤逻辑; 4. 在配置类中通过 FilterRegistrationBean 对象将自定义 Filter 注册到 Spring Boot 应用中。 下面是一个示例代码: ```java @Component public class CustomFilter implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤逻辑 chain.doFilter(request, response); } } ``` 在上述代码中,我们创建了一个名为 CustomFilter 的类并实现了 Filter 接口。在 doFilter 方法中,我们可以编写自己的过滤逻辑。 接下来,在 Spring Boot 的配置类中注册自定义 Filter: ```java @Configuration public class WebConfig { @Bean public FilterRegistrationBean<CustomFilter> filterRegistrationBean() { FilterRegistrationBean<CustomFilter> registrationBean = new FilterRegistrationBean<>(); registrationBean.setFilter(new CustomFilter()); registrationBean.addUrlPatterns("/*"); // 设置过滤路径 registrationBean.setName("CustomFilter"); // 设置 Filter 名称 registrationBean.setOrder(1); // 设置 Filter 执行顺序 return registrationBean; } } ``` 在上述代码中,我们创建了一个名为 WebConfig 的配置类,并在其中创建了一个名为 filterRegistrationBean 的方法,并使用 @Bean 注解将其声明为一个 Spring Bean。在该方法中,我们通过 FilterRegistrationBean 对象将自定义 Filter 注册到 Spring Boot 应用中,并设置了过滤路径、Filter 名称以及执行顺序。 最后,启动 Spring Boot 应用程序并访问注册了自定义 Filter 的路径,即可看到自定义 Filter 生效的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值