Mam aplikację rozruchową, która wymaga logowania do niektórych działań. Próbuję przetestować je za pomocą MockMvc
, ale nie wydaje się działać. Ciągle otrzymuję odpowiedź HTTP o statusie 403 (zabronione). Prawdopodobnie coś jest nie tak z częścią uwierzytelniania.Uruchamiaj testy jednostek na kontrolerach wymagających uwierzytelniania.
Próbowałem podążać za documentation, ale nie udało mi się uruchomić.
To jest mój aktualny kod do testowania:
@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");
}
}
Przepraszam, jeśli jestem brakujące coś oczywistego. To moje pierwsze doświadczenie z wiosennym zyskiem.
Ciekawi mnie twoja metoda 'springSecurity()'. Czy mógłbyś pokazać metodę metody tej metody? –
Metoda springSecurity() jest zapewniana przez Spring Security. Dodaje filtr springSecurityFilterChain i zapewnia zintegrowanie obsługi testowej z filtrem. –