Ich habe eine Spring-Boot-Anwendung, die für einige Aktionen eine Anmeldung erfordert. Ich versuche, sie mit MockMvc
zu testen, aber es scheint nicht zu funktionieren. Ich bekomme immer eine HTTP-Antwort mit Status 403 (verboten). Wahrscheinlich stimmt etwas mit dem Authentifizierungsteil nicht.Führen Sie Unit-Tests auf Controllern durch, die eine Authentifizierung erfordern
Ich habe versucht, die documentation zu folgen, aber ich konnte es nicht funktionieren.
Dies ist mein aktueller Testcode:
@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");
}
}
Sorry, wenn ich etwas offensichtlich fehle. Dies ist meine erste Erfahrung mit Spring Boot.
Ich bin neugierig auf Ihre 'springSecurity()' Methode. Könnten Sie bitte den Methodenkörper dieser Methode zeigen? –
Die Methode SpringSecurity() wird von Spring Security bereitgestellt. Es fügt den springSecurityFilterChain-Filter hinzu und stellt sicher, dass die Testunterstützung in den Filter integriert ist. –