Ho un'applicazione di avvio a molla che richiede l'accesso per alcune azioni. Sto provando a testarli usando MockMvc
, ma non sembra funzionare. Continuo a ricevere una risposta HTTP con stato 403 (vietato). Probabilmente c'è qualcosa di sbagliato nella parte di autenticazione.Esegui test di unità su controller che richiedono l'autenticazione
Ho provato a seguire il documentation, ma non sono riuscito a farlo funzionare.
Questo è il mio codice di prova corrente:
@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");
}
}
Scusate se mi manca qualcosa di ovvio. Questa è la mia prima esperienza con lo stivale a molla.
Sono curioso del metodo 'springSecurity()'. Potresti mostrare il corpo del metodo di quel metodo? –
Il metodo springSecurity() è fornito da Spring Security. Aggiunge il filtro springSecurityFilterChain e garantisce che il supporto di test sia integrato nel filtro. –