测试请求和会话范围的 Bean
Spring 从早期版本开始就支持请求和会话范围的 Bean,您可以按照以下步骤测试请求范围和会话范围的 Bean
-
通过使用
@WebAppConfiguration
注解您的测试类,确保为您的测试加载了WebApplicationContext
。 -
将模拟请求或会话注入到您的测试实例中,并根据需要准备您的测试夹具。
-
调用您从配置的
WebApplicationContext
(使用依赖注入)中检索到的 Web 组件。 -
对模拟执行断言。
下一个代码片段显示了登录用例的 XML 配置。请注意,userService
Bean 依赖于请求范围的loginAction
Bean。此外,LoginAction
是使用SpEL 表达式实例化的,这些表达式从当前 HTTP 请求中检索用户名和密码。在我们的测试中,我们希望通过 TestContext 框架管理的模拟来配置这些请求参数。以下列表显示了此用例的配置
<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
。然后,我们可以根据用户名和密码的已知输入对结果执行断言。以下列表显示了如何执行此操作
-
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 框架管理的模拟会话中配置一个主题。以下示例显示了如何执行此操作
<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
中,我们将UserService
和MockHttpSession
注入到我们的测试实例中。在我们的sessionScope()
测试方法中,我们通过在提供的MockHttpSession
中设置预期的theme
属性来设置测试夹具。当在我们的userService
上调用processUserPreferences()
方法时,我们可以确保用户服务可以访问当前MockHttpSession
的会话范围的userPreferences
,并且我们可以根据配置的主题对结果执行断言。以下示例显示了如何执行此操作
-
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
}
}