此版本仍在开发中,尚不被认为是稳定的。对于最新的稳定版本,请使用 Spring Framework 6.2.10spring-doc.cadn.net.cn

单元测试

依赖注入应该使您的代码对容器的依赖程度低于它 与传统的 J2EE / Java EE 开发有关。构成应用程序的 POJO 应该可以在 JUnit 或 TestNG 测试中进行测试,对象通过使用new运算符,没有 Spring 或任何其他容器。您可以使用模拟对象(与其他有价值的测试技术结合使用)来单独测试代码。 如果您遵循 Spring 的架构建议,则生成的干净分层 代码库的组件化有助于简化单元测试。例如 您可以通过存根或模拟 DAO 或存储库接口来测试服务层对象, 在运行单元测试时无需访问持久性数据。spring-doc.cadn.net.cn

真正的单元测试通常运行得非常快,因为没有运行时基础设施 建立。强调真正的单元测试作为开发方法的一部分可以促进 您的生产力。您可能不需要测试章节的这一部分来帮助您编写 针对基于 IoC 的应用程序进行有效的单元测试。对于某些单元测试场景, 但是,Spring Framework 提供了模拟对象和测试支持类,这些类 本章中将对此进行描述。spring-doc.cadn.net.cn

模拟对象

Spring 包括许多专门用于模拟的包:spring-doc.cadn.net.cn

环境

org.springframework.mock.env包包含EnvironmentPropertySource抽象(参见 Bean 定义配置文件PropertySource抽象化).MockEnvironmentMockPropertySource对开发很有用 对依赖于特定于环境的属性的代码进行容器外测试。spring-doc.cadn.net.cn

Servlet API

org.springframework.mock.web包包含一套全面的 Servlet API 模拟对象,这些对象可用于测试 Web 上下文、控制器和过滤器。这些 模拟对象针对 Spring 的 Web MVC 框架,通常更多 比动态模拟对象(如 EasyMock)更方便使用。spring-doc.cadn.net.cn

从 Spring Framework 6.0 开始,中的模拟对象org.springframework.mock.web是 基于 Servlet 6.0 API。

MockMvc 基于模拟 Servlet API 对象构建,以提供集成测试 Spring MVC 的框架。参见 MockMvcspring-doc.cadn.net.cn

Spring Web 响应式

org.springframework.mock.http.server.reactive包包含模拟实现 之ServerHttpRequestServerHttpResponse用于 WebFlux 应用程序。这org.springframework.mock.web.server包包含一个模拟ServerWebExchange那 取决于那些模拟请求和响应对象。spring-doc.cadn.net.cn

MockServerHttpRequestMockServerHttpResponse从同一个摘要扩展 基类作为特定于服务器的实现,并与它们共享行为。为 例如,模拟请求一旦创建就不可变,但您可以使用mutate()方法 从ServerHttpRequest以创建修改后的实例。spring-doc.cadn.net.cn

为了让模拟响应正确实现写入协定并返回 写入完成句柄(即,Mono<Void>),它默认使用Fluxcache().then(),它缓冲数据并使其可用于测试中的断言。 应用程序可以设置自定义写入函数(例如,测试无限流)。spring-doc.cadn.net.cn

WebTestClient 基于模拟请求和响应构建,以提供支持 在没有 HTTP 服务器的情况下测试 WebFlux 应用程序。客户端也可用于 使用正在运行的服务器进行端到端测试。spring-doc.cadn.net.cn

单元测试支持类

Spring 包含许多可以帮助进行单元测试的类。它们分为两个 类别:spring-doc.cadn.net.cn

通用测试实用程序

org.springframework.test.util包包含多个通用实用程序用于单元和集成测试。spring-doc.cadn.net.cn

AopTestUtils是AOP 相关实用程序方法的集合。您可以使用这些方法来获取对隐藏在一个或多个 Spring 代理后面的底层目标对象的引用。例如,如果您已使用 EasyMock 或 Mockito 等库将 bean 配置为动态模拟,并且模拟被包装在 Spring 代理中,您可能需要直接访问底层mock 来配置对它的期望并执行验证。对于 Spring 的核心 AOP实用程序,请参阅AopUtilsAopProxyUtils.spring-doc.cadn.net.cn

ReflectionTestUtils是一个基于反射的实用程序方法的集合。您可以在测试中使用这些方法需要更改常量值的场景,请设置一个非public田 调用非publicsetter 方法,或调用非public配置或生命周期callback 方法,用于测试应用程序代码,例如以下用例:spring-doc.cadn.net.cn

  • 纵容的 ORM 框架(例如 JPA 和 Hibernate)privateprotected田 访问而不是public域实体中属性的 setter 方法。spring-doc.cadn.net.cn

  • Spring 对注释的支持(例如@Autowired,@Inject@Resource), 提供依赖注入privateprotected字段、setter 方法、和配置方法。spring-doc.cadn.net.cn

  • 使用 Comments,例如@PostConstruct@PreDestroy用于生命周期回调 方法。spring-doc.cadn.net.cn

TestSocketUtils是一个简单的用于查找可用 TCP 端口的实用程序localhost用于集成测试 场景。spring-doc.cadn.net.cn

TestSocketUtils可用于集成测试,在可用的随机端口。但是,这些实用程序不能保证后续给定端口的可用性,因此不可靠。而不是使用TestSocketUtils要为服务器查找可用的本地端口,建议您依赖于服务器在它选择的随机临时端口上启动的能力,或者由作系统分配。要与该服务器交互,您应该查询服务器以获取它当前正在使用的端口。spring-doc.cadn.net.cn

Spring MVC 测试实用程序

org.springframework.test.web包装内含ModelAndViewAssert,您可以可以与 JUnit、TestNG 或任何其他用于单元测试的测试框架结合使用处理 Spring MVCModelAndView对象。spring-doc.cadn.net.cn

单元测试 Spring MVC 控制器
对 Spring MVC 进行单元测试Controller类作为 POJO,使用ModelAndViewAssert结合MockHttpServletRequest,MockHttpSession,依此类推,来自 Spring 的 Servlet API 模拟。为了彻底集成测试您的 Spring MVC 和 RESTController与您的WebApplicationContextSpring MVC 的配置,请改用 MockMvc