简单的生活,更少的期待,更多的付出。

spring boot junit

Spring boot 使用JUnit测试,可以导入测试相关包spring-boot-starter-test,pom文件中添加如下

1
<dependency>
2
    <groupId>org.springframework.boot</groupId>
3
    <artifactId>spring-boot-starter-test</artifactId>
4
    <!--  <version>${spring.boot.version}</version> -->
5
    <scope>test</scope>
6
</dependency>

使用JUnit

1
@RunWith(SpringJUnit4ClassRunner.class) // SpringJUnit支持,由此引入Spring-Test框架支持! 
2
@SpringApplicationConfiguration(classes = App.class) // 指定我们SpringBoot工程的Application启动类
3
4
//Web项目加如下注解
5
@WebAppConfiguration // 由于是Web项目,Junit需要模拟ServletContext,因此我们需要给我们的测试类加上@WebAppConfiguration

基本JUnit注解

1. @BeforeClass
//在所有测试方法前执行一次,一般在其中写上整体初始化的代码 

2. @AfterClass
//在所有测试方法后执行一次,一般在其中写上销毁和释放资源的代码 

3. @Before
//在每个测试方法前执行,一般用来初始化方法(比如我们在测试别的方法时,类中与其他测试方法共享的值已经被改变,为了保证测试结果的有效性,我们会在@Before注解的方法中重置数据)

4. @After
//在每个测试方法后执行,在方法执行完成后要做的事情 

5. @Test(timeout = 1000)
// 测试方法执行超过1000毫秒后算超时,测试将失败 

6. @Test(expected = Exception.class)
// 测试方法期望得到的异常类,如果方法执行没有抛出指定的异常,则测试失败 

7. @Ignore(“not ready yet”) 
   @Test
// 执行测试时将忽略掉此方法,如果用于修饰类,则忽略整个类 

8. @RunWith 
在JUnit中有很多个Runner,他们负责调用你的测试代码,每一个Runner都有各自的特殊功能,你要根据需要选择不同的Runner来运行你的测试代码。 
如果我们只是简单的做普通Java测试,不涉及Spring Web项目,你可以省略@RunWith注解,这样系统会自动使用默认Runner来运行你的代码。

参数化测试

@RunWith(Parameterized.class)注解类,@Parameters注解方法。
1
@Parameters
2
public static Collection<?> data(){
3
    // Object 数组中值的顺序注意要和上面的构造方法ParameterTest的参数对应
4
    return Arrays.asList(new Object[][]{
5
        {"小明2", true},
6
        {"坏", false},
7
        {"莉莉", false},
8
    });
9
}

套件测试

@RunWith(Suite.class) 
@SuiteClasses({ATest.class, BTest.class, CTest.class}) 

使用Junit测试HTTP的API接口

1
@RunWith(SpringJUnit4ClassRunner.class)
2
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class)
3
//@WebAppConfiguration // 使用@WebIntegrationTest注解需要将@WebAppConfiguration注释掉
4
@WebIntegrationTest("server.port:0")// 使用0表示端口号随机,也可以具体指定如8888这样的固定端口
5
public class HelloControllerTest {
6
7
    private String dateReg;
8
    private Pattern pattern;
9
    private RestTemplate template = new TestRestTemplate();
10
    @Value("${local.server.port}")// 注入端口号
11
    private int port;
12
13
    @Test
14
    public void test3(){
15
        String url = "http://localhost:"+port+"/myspringboot/hello/info";
16
        MultiValueMap<String, Object> map = new LinkedMultiValueMap<String, Object>(); 
17
        map.add("name", "Tom");  
18
        map.add("name1", "Lily");
19
        String result = template.postForObject(url, map, String.class);
20
        System.out.println(result);
21
        assertNotNull(result);
22
        assertThat(result, Matchers.containsString("Tom"));
23
    }
24
25
}

捕获输出

使用 OutputCapture 来捕获指定方法开始执行以后的所有输出,包括System.out输出和Log日志。
OutputCapture 需要使用@Rule注解,并且实例化的对象需要使用public修饰,如下代码:

1
@RunWith(SpringJUnit4ClassRunner.class)
2
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class)
3
//@WebAppConfiguration // 使用@WebIntegrationTest注解需要将@WebAppConfiguration注释掉
4
@WebIntegrationTest("server.port:0")// 使用0表示端口号随机,也可以具体指定如8888这样的固定端口
5
public class HelloControllerTest {
6
7
    @Value("${local.server.port}")// 注入端口号
8
    private int port;
9
10
    private static final Logger logger = LoggerFactory.getLogger(StudentController.class);
11
12
    @Rule
13
    // 这里注意,使用@Rule注解必须要用public
14
    public OutputCapture capture = new OutputCapture();
15
16
    @Test
17
    public void test4(){
18
        System.out.println("HelloWorld");
19
        logger.info("logo日志也会被capture捕获测试输出");
20
        assertThat(capture.toString(), Matchers.containsString("World"));
21
    }
22
}

更加详细的Spring Boot Junit单元测试,可以参考这篇博文

-------------本文结束感谢您的阅读-------------
谢谢大爷打赏,常来玩啊