【发布时间】:2015-06-24 14:43:11
【问题描述】:
我有一个 Spring Boot 应用程序,它需要登录才能执行某些操作。我正在尝试使用MockMvc 测试它们,但它似乎不起作用。我不断收到状态为 403(禁止)的 HTTP 响应。可能是认证部分有问题。
我已尝试关注documentation,但无法正常工作。
这是我当前的测试代码:
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = {Application.class})
@WebIntegrationTest("server.port = 8093")
public class PasswordChangeTests {
@Autowired
private EmbeddedWebApplicationContext webApplicationContext;
@Autowired
private UserRepository userRepository;
private MockMvc mockMvc;
@Before
public void setUp() throws Exception {
this.mockMvc = MockMvcBuilders
.webAppContextSetup(webApplicationContext)
.apply(springSecurity())
.build();
}
@Test
public void changePasswordWorks() throws Exception {
// Send password change request
PasswordChangeRepresentation passwordChange = new PasswordChangeRepresentation(DefaultUsers.Admin.getPassword(), "12345678");
mockMvc.perform(MockMvcRequestBuilders.request(HttpMethod.POST, "/password/change")
.content(new ObjectMapper().writeValueAsString(passwordChange))
.contentType(MediaType.APPLICATION_JSON)
.accept(MediaType.APPLICATION_JSON))
.andExpect(status().isOk());
// Check that the password has been changed
User user = this.userRepository.findByUsername(DefaultUsers.Admin.getEmail());
Assert.assertEquals(user.getPassword(), "12345678");
}
}
对不起,如果我遗漏了一些明显的东西。这是我第一次使用 Spring Boot。
【问题讨论】:
-
我很好奇你的
springSecurity()方法。能否请您显示该方法的方法体? -
springSecurity() 方法由 Spring Security 提供。它添加了 springSecurityFilterChain 过滤器,并确保将测试支持集成到过滤器中。
标签: java spring-mvc spring-security spring-boot mockmvc