测试请求和会话范围的 Bean

Spring 从早期版本开始就支持请求和会话范围的 Bean,您可以按照以下步骤测试请求范围和会话范围的 Bean

  • 通过使用@WebAppConfiguration注解您的测试类,确保为您的测试加载了WebApplicationContext

  • 将模拟请求或会话注入到您的测试实例中,并根据需要准备您的测试夹具。

  • 调用您从配置的WebApplicationContext(使用依赖注入)中检索到的 Web 组件。

  • 对模拟执行断言。

下一个代码片段显示了登录用例的 XML 配置。请注意,userService Bean 依赖于请求范围的loginAction Bean。此外,LoginAction 是使用SpEL 表达式实例化的,这些表达式从当前 HTTP 请求中检索用户名和密码。在我们的测试中,我们希望通过 TestContext 框架管理的模拟来配置这些请求参数。以下列表显示了此用例的配置

请求范围的 Bean 配置
<beans>

	<bean id="userService" class="com.example.SimpleUserService"
			c:loginAction-ref="loginAction"/>

	<bean id="loginAction" class="com.example.LoginAction"
			c:username="#{request.getParameter('user')}"
			c:password="#{request.getParameter('pswd')}"
			scope="request">
		<aop:scoped-proxy/>
	</bean>

</beans>

RequestScopedBeanTests中,我们将UserService(即被测对象)和MockHttpServletRequest都注入到我们的测试实例中。在我们的requestScope()测试方法中,我们通过在提供的MockHttpServletRequest中设置请求参数来设置测试夹具。当在我们的userService上调用loginUser()方法时,我们可以确保用户服务可以访问当前MockHttpServletRequest(即我们刚刚设置参数的那个)的请求范围的loginAction。然后,我们可以根据用户名和密码的已知输入对结果执行断言。以下列表显示了如何执行此操作

请求范围的 Bean 测试
  • Java

  • Kotlin

@SpringJUnitWebConfig
class RequestScopedBeanTests {

	@Autowired UserService userService;
	@Autowired MockHttpServletRequest request;

	@Test
	void requestScope() {
		request.setParameter("user", "enigma");
		request.setParameter("pswd", "$pr!ng");

		LoginResults results = userService.loginUser();
		// assert results
	}
}
@SpringJUnitWebConfig
class RequestScopedBeanTests {

	@Autowired lateinit var userService: UserService
	@Autowired lateinit var request: MockHttpServletRequest

	@Test
	fun requestScope() {
		request.setParameter("user", "enigma")
		request.setParameter("pswd", "\$pr!ng")

		val results = userService.loginUser()
		// assert results
	}
}

以下代码片段类似于我们之前看到的请求范围 Bean 的代码片段。但是,这次,userService Bean 依赖于会话范围的userPreferences Bean。请注意,UserPreferences Bean 是使用 SpEL 表达式实例化的,该表达式从当前 HTTP 会话中检索主题。在我们的测试中,我们需要在 TestContext 框架管理的模拟会话中配置一个主题。以下示例显示了如何执行此操作

会话范围的 Bean 配置
<beans>

	<bean id="userService" class="com.example.SimpleUserService"
			c:userPreferences-ref="userPreferences" />

	<bean id="userPreferences" class="com.example.UserPreferences"
			c:theme="#{session.getAttribute('theme')}"
			scope="session">
		<aop:scoped-proxy/>
	</bean>

</beans>

SessionScopedBeanTests中,我们将UserServiceMockHttpSession注入到我们的测试实例中。在我们的sessionScope()测试方法中,我们通过在提供的MockHttpSession中设置预期的theme属性来设置测试夹具。当在我们的userService上调用processUserPreferences()方法时,我们可以确保用户服务可以访问当前MockHttpSession的会话范围的userPreferences,并且我们可以根据配置的主题对结果执行断言。以下示例显示了如何执行此操作

会话范围的 Bean 测试
  • Java

  • Kotlin

@SpringJUnitWebConfig
class SessionScopedBeanTests {

	@Autowired UserService userService;
	@Autowired MockHttpSession session;

	@Test
	void sessionScope() throws Exception {
		session.setAttribute("theme", "blue");

		Results results = userService.processUserPreferences();
		// assert results
	}
}
@SpringJUnitWebConfig
class SessionScopedBeanTests {

	@Autowired lateinit var userService: UserService
	@Autowired lateinit var session: MockHttpSession

	@Test
	fun sessionScope() {
		session.setAttribute("theme", "blue")

		val results = userService.processUserPreferences()
		// assert results
	}
}