走进Java接口测试之读取配置文件

时间:2023-04-06 18:04:28

走进Java接口测试之读取配置文件

前言

但在大部分用例开发环境下,添加额外配置是无所避免的,比如自定义应用端口号、服务地址、数据库的配置等,都或多或少的需要一些外部的配置项等。

在前文中我们有详细介绍在接口测试框架中如何基于 SpringBoot 快速搭建多环境配置,本文将在原有的基础上介绍集成如何快速读取配置文件的值。

走进Java接口测试之多环境配置

配置文件简要说明

SpringBoot 默认的全局配置文件名为 application.propertiesapplication.yml (spring官方推荐使用的格式是 .yml 格式),程序启动时会自动加载此文件,无需手动引入。除此之外还有一个 bootstrap 的全局文件,它是在 application 配置文件之前加载,主要是用于在应用程序上下文的引导阶段,在后 SpringCloud时,主要是利用此特性,进行配置文件的动态修改,在此 我们演示 application.properties 配置。

Demo 演示

这次在多环境配置的 demo 的基础进行扩展。

自定义属性值

filter-dev.properties 配置文件增加自定义属性,比如:


1. host=http://127.0.0.1
2. port=8082

application-dev.properties 增加配置项:

1. Server.host=${host}
2. Server.port=${port}

新建配置实体类

我们可以通过两种方式配置绑定对象。

第一种方式:@Value() 方式 在类域属性上通过 @Value("${xxx}") 指定关联属性, SpringBoot 会自动加载。@Component 注解使其在启动时被自动扫描到。


1. package com.zuozewei.springboot.model;
2. 
3. import lombok.Data;
4. import org.springframework.beans.factory.annotation.Value;
5. import org.springframework.stereotype.Component;
6. 
7. /**
8.  * 描述:
9.  * 配置文件实体类
10.  *
11.  * @author zuozewei
12.  * @create 2019-12-20 16:15
13.  */
14. 
15. @Component
16. @Data
17. publicclassConfigurations1{
18. 
19. @Value("${Server.host}")
20. privateString host;
21. 
22. @Value("${Server.port}")
23. privateString port;
24. 
25. }

第二种方式:@ConfigurationProperties 属性

手动书写 @Value 注解还是比较繁重的工作,好在 SpringBoot 提供了更简洁的方式。@ConfigurationProperties(prefix = "Server")。prefix 指定了配置文件的前缀为 Server,并且按照属性名进行自动匹配。例如:Server.host属性值会自动加载到 privateStringhost 域中。


1. package com.zuozewei.springboot.model;
2. 
3. import lombok.Data;
4. import org.springframework.boot.context.properties.ConfigurationProperties;
5. import org.springframework.stereotype.Component;
6. 
7. /**
8.  * 描述:
9.  * 配置文件实体类
10.  *
11.  * @author zuozewei
12.  * @create 2019-12-20 16:15
13.  */
14. 
15. @Component
16. @Data
17. @ConfigurationProperties(prefix = "Server")
18. publicclassConfigurations2{
19. 
20. privateString host;
21. privateString port;
22. 
23. }

PS:locations 还能够指定自定义的配置文件位置,这里就不多说了。

  1. @ConfigurationProperties(prefix = "Server", locations = "classpath:xxxx.properties")

用例读取

编写测试用例,通过 @Autowired 注解注入 bean 调用。


1. package com.zuozewei.springboot.test;
2. 
3. import com.zuozewei.springboot.model.Configurations1;
4. import lombok.extern.slf4j.Slf4j;
5. import org.springframework.beans.factory.annotation.Autowired;
6. import org.springframework.boot.test.context.SpringBootTest;
7. import org.springframework.test.context.testng.AbstractTestNGSpringContextTests;
8. import org.testng.annotations.BeforeClass;
9. import org.testng.annotations.Test;
10. 
11. /**
12.  * 描述:
13.  * 演示测试用例1
14.  *
15.  * @author zuozewei
16.  * @create 2020-01-03 11:02
17.  */
18. 
19. @SpringBootTest
20. @Slf4j
21. publicclassTestCase1extendsAbstractTestNGSpringContextTests{
22. 
23. @Autowired
24. privateConfigurations1 configurations;
25. 
26. @BeforeClass
27. publicvoid beforeClass() {
28. String host = configurations.getHost();
29. String port = configurations.getPort();
30. String url = host +":"+ port;
31.         log.info("URL:"+ url );
32. }
33. 
34. @Test
35. publicvoid test(){
36.         log.info("TestCase run...");
37. }
38. 
39. }

注意:

  • SpringBoot 中读取配置文件不能放到 @BeforeSuite 注解,否则会导致 @Autowired 不能加载 Bean;
  • SpringBoot 中使用 TestNg 必须加上 @SpringBootTest,并且继承 AbstractTestNGSpringContextTests,如果不继承 AbstractTestNGSpringContextTests,会导致 @Autowired 不能加载 Bean。

测试验证

最好跑测看下结果,我们可以看到配置文件读取成功:走进Java接口测试之读取配置文件

小结

测试框架使用 SpingBoot 读取配置文件比我们传统方式要简单很多,上述我们主要介绍了过两种方式配置绑定对象:

  • @Value() 注解
  • @ConfigurationProperties 属性 最后在测试用例开发中,结合 @Autowired 注解注入 bean 调用读取即可。

希望本文对你有所启发。


示例代码:

https://github.com/7DGroup/Java-API-Test-Examples/tree/master/springboot-configuration-demo