SpringBoot测试——高级配置

本文介绍了SpringBoot在测试时如何加载专用属性,包括使用@SpringBootTest的properties和args参数,以及如何加载测试专用配置。此外,还详细讲解了如何模拟Web环境,包括启动Web环境的不同方式,发起虚拟请求,以及匹配响应的状态、响应体和响应头,为开发者提供了一套完整的SpringBoot测试解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

在这里插入图片描述



一、SpringBoot加载测试专用属性

加载测试范围的临时属性,应用于小范围测试环境


1.@SpringBootTest注解的properties参数


  • 在启动测试环境时,可以通过properties参数设置测试环境专用的属性
/**
 * @author .29.
 * @create 2023-04-01 20:28
 */
//properties属性,可以为当前测试用添加临时的属性配置
@SpringBootTest(properties = "test.prop=testValueByProperties")
public class PropertiesAndArgsTest {

    @Value("${test.prop}")
    private String msg;

    @Test
    public void testProperties(){
        System.out.println(msg);
    }
}

在这里插入图片描述


  • 对应的application.yml配置文件内容:
test:
  prop: 

优势:比多环境开发中的测试环境影响范围小,仅在当前测试类有效。



2.@SpringBootTest注解的args参数


  • 在启动测试环境时,可以通过args参数设置测试环境专用的传入属性
/**
 * @author .29.
 * @create 2023-04-01 20:28
 */

//args属性,可以为当前测试用例添加临时的命令行参数
@SpringBootTest(args = {"--test.prop=testValueByArgs"})
public class PropertiesAndArgsTest {

    @Value("${test.prop}")
    private String msg;

    @Test
    public void testProperties(){
        System.out.println(msg);
    }
}

在这里插入图片描述


  • 对应的application.yml配置文件内容:
test:
  prop: 




二、SpringBoot加载测试专用配置

加载测试范围配置,应用于小范围测试环境


  • 专用的配置:
/**
 * @author .29.
 * @create 2023-04-01 21:27
 */
//专用的配置
@Configuration
public class MsgConfig {
    @Bean
    public String msg(){
        return "test @Import get msg";
    }
}


  • 使用@Import注解,可以加载当前测试类专用的配置:
/**
 * @author .29.
 * @create 2023-04-01 21:30
 */
@SpringBootTest
@Import(MsgConfig.class)
public class ConfigurationTest {
    @Autowired
    private String msg;

    @Test
    public void testConfiguration(){
        System.out.println(msg);
    }
}

成功加载到专用配置中的内容:

在这里插入图片描述




三、SpringBoot 模拟测试Web环境

Web环境模拟测试

  1. 设置测试端口
  2. 模拟测试启动
  3. 模拟测试匹配(各组成部分消息均可匹配)

1.启动Web环境的不同方式


  • @SpringBootTest注解的webEnvironment属性 提供了启动Web环境的选择:

在这里插入图片描述



  • 默认 webEnvironment = SpringBootTest.WebEnvironment.NONE:不启动Web服务器



  • webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT:使用默认端口在测试类启动Web服务器
/**
 * @author .29.
 * @create 2023-04-01 21:39
 */
//webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT:默认端口在测试类启动Web服务器
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
public class WebTest {
    @Test
    public void test(){

    }
}

在这里插入图片描述



  • webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT:使用随机端口在测试类启动Web服务器
/**
 * @author .29.
 * @create 2023-04-01 21:39
 */

//webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT: 随机端口 在测试类启动Web服务器
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class WebTest {
    @Test
    public void test(){

    }
}

在这里插入图片描述



2.发起虚拟请求


  • 控制层组件:
/**
 * @author .29.
 * @create 2023-04-01 22:38
 */
@RestController
@RequestMapping("/books")
public class BookController {
    @GetMapping
    public String get(){
        System.out.println("get() is running ...");
        return "Springboot";
    }
}

  • 发起MVC虚拟调用,模拟发起请求
/**
 * @author .29.
 * @create 2023-04-01 21:39
 */

@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
//@AutoConfigureMockMvc注解:开启MVC虚拟调用
@AutoConfigureMockMvc
public class WebTest {
    @Test  //@Autowired注解,注入虚拟MVC调用对象
    public void testWeb(@Autowired MockMvc mockMvc) throws Exception {
        //创建虚拟请求,当前访问/books
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        //执行对应的请求
        mockMvc.perform(builder);
    }
}

成功发起虚拟请求
在这里插入图片描述



3.匹配响应的执行状态


  • 虚拟请求状态匹配:
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
//开启MVC虚拟调用
@AutoConfigureMockMvc
public class WebTest {
    @Test
    public void testStatus(@Autowired MockMvc mockMvc) throws Exception {
        //创建虚拟请求,当前访问/books (这里故意写错,模拟匹配失败)
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books1");
        //执行对应的请求
        ResultActions actions = mockMvc.perform(builder);

        //设定预期值 与真实值进行比较,成功测试通过,失败测试失败
        //定义本次调用的预期值
        StatusResultMatchers status = MockMvcResultMatchers.status();
        //预计本次调用是成功的:状态200
        ResultMatcher ok = status.isOk();
        //添加预期值到本次调用过程中,与真实执行结果进行匹配
        actions.andExpect(ok);
    }
}

匹配失败时,输出匹配错误原因:

在这里插入图片描述



4.匹配响应体


/**
 * @author .29.
 * @create 2023-04-01 21:39
 */

@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
//开启MVC虚拟调用
@AutoConfigureMockMvc
public class WebTest {
    
    @Test
    public void testBody(@Autowired MockMvc mockMvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions actions = mockMvc.perform(builder);

        //设定预期值 与真实值进行比较,成功测试通过,失败测试失败
        //定义本次调用的预期值
        ContentResultMatchers content = MockMvcResultMatchers.content();
        //预计请求体为控制层组件的返回值"Springboot 测试类启动web环境 发送虚拟请求"
        //如果请求体反馈JSON数据,string()改为json()
        ResultMatcher body = content.string("Springboot");
        //添加预期值到本次调用过程中,与真实执行结果进行匹配
        actions.andExpect(body);
    }
    
}



5.匹配响应头


    @Test
    public void testHeader(@Autowired MockMvc mockMvc) throws Exception {
        MockHttpServletRequestBuilder builder = MockMvcRequestBuilders.get("/books");
        ResultActions actions = mockMvc.perform(builder);

        //设定预期值 与真实值进行比较,成功测试通过,失败测试失败
        //定义本次调用的预期值
        HeaderResultMatchers header = MockMvcResultMatchers.header();
        //预计请求头的Content-Type 为 text/plain;charset=UTF-8
        ResultMatcher string = header.string("Content-Type", "text/plain;charset=UTF-8");
        //添加预期值到本次调用过程中,与真实执行结果进行匹配
        actions.andExpect(string);
    }
}


在这里插入图片描述

### Spring Boot 整合 Nacos 配置中心 示例教程 #### 1. 添加 Maven 依赖 为了使 Spring Boot 项目能够与 Nacos 进行交互,需要引入 `spring-cloud-starter-alibaba-nacos-config` 和其他必要的依赖。 ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2021.1</version> </dependency> <!-- 如果还需要使用 Nacos 的服务发现功能 --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2021.1</version> </dependency> ``` 以上依赖版本应根据实际使用的 Spring Cloud 版本进行调整[^1]。 --- #### 2. 创建 Bootstrap 文件并配置连接参数 在 Spring Boot 中,`bootstrap.yml` 或 `bootstrap.properties` 是用于加载早期配置的文件。它会先于 `application.yml` 被加载,因此适合放置 Nacos 配置中心的相关参数。 以下是典型的 `bootstrap.yml` 配置: ```yaml spring: application: name: demo-service # 应用名称 cloud: nacos: config: server-addr: localhost:8848 # Nacos服务器地址 file-extension: yaml # 配置文件格式,默认为properties shared-configs: # 共享配置 - data-id: common-config.yaml refresh: true # 开启动态刷新 discovery: server-addr: localhost:8848 # 可选:如果需要服务注册与发现 ``` 通过上述配置Spring Boot 将会在启动时自动从指定的 Nacos 地址获取对应的配置数据[^2]。 --- #### 3. 启动类添加注解 为了让 Spring Boot 自动感知到 Nacos 并完成配置同步,需在项目的主启动类上添加特定注解。 ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import com.alibaba.cloud.nacos.NacosDiscoveryProperties; @SpringBootApplication @NacosPropertySource(dataId = "demo-service", autoRefreshed = true) // 动态刷新支持 public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` 此部分代码确保了应用能够在运行期间实时监听来自 Nacos 的配置变化,并触发相应的更新逻辑[^3]。 --- #### 4. 测试动态刷新机制 假设我们在 Nacos 控制台创建了一个名为 `common-config.yaml` 的配置文件,其中定义了一些全局变量: ```yaml app.name: My Application logging.level.root: DEBUG ``` 随后可以在业务代码中注入这些属性值: ```java import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class ConfigController { @Value("${app.name}") private String appName; @GetMapping("/config") public String getConfig() { return "App Name: " + appName; } } ``` 访问 `/config` 接口即可验证配置是否生效。修改 Nacos 上的内容后无需重启服务即能立即看到最新效果[^2]。 --- #### 5. 处理高级场景——共享配置 对于多个微服务共用的部分配置(如 Redis 参数),可以通过 `shared-configs` 来实现统一管理。例如: ```yaml spring: cloud: nacos: config: shared-configs: - data-id: redis-config.yaml group: DEFAULT_GROUP refresh: true ``` 这样所有的服务都可以继承该公共配置而不需要重复声明。 --- #### 总结 通过上述步骤,可以顺利完成 Spring Boot 与 Nacos 配置中心的整合工作。整个过程涉及到了 Maven 依赖导入、Bootstrap 文件编写以及动态刷新的支持等多个方面[^4]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.29.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值