Я пытаюсь проверить @WebMvcTest
с пользовательскими настройками безопасности, определенным в SecurityConfig
классе:Тестирование безопасности в Спринг Ботинок 1,4
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests().antMatchers("/admin*").access("hasRole('ADMIN')").antMatchers("/**").permitAll().and().formLogin();
}
@Autowired
public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
auth.inMemoryAuthentication().withUser("user").password("password").roles("ADMIN");
}
}
тестовый класс:
@RunWith(SpringRunner.class)
@WebMvcTest(value = ExampleController.class)
public class ExampleControllerMockMVCTest {
@Autowired
private MockMvc mockMvc;
@Test
public void indexTest() throws Exception {
mockMvc.perform(get("/"))
.andExpect(status().isOk())
.andExpect(view().name("index"));
}
@Test
public void adminTestWithoutAuthentication() throws Exception {
mockMvc.perform(get("/admin"))
.andExpect(status().is3xxRedirection()); //login form redirect
}
@Test
@WithMockUser(username="example", password="password", roles={"ANONYMOUS"})
public void adminTestWithBadAuthentication() throws Exception {
mockMvc.perform(get("/admin"))
.andExpect(status().isForbidden());
}
@Test
@WithMockUser(username="user", password="password", roles={"ADMIN"})
public void adminTestWithAuthentication() throws Exception {
mockMvc.perform(get("/admin"))
.andExpect(status().isOk())
.andExpect(view().name("admin"))
.andExpect(model().attributeExists("name"))
.andExpect(model().attribute("name", is("user")));
}
}
тесты не потому, что они используют настройки безопасности по умолчанию для Spring Boot.
Я могу исправить это, используя @SpringBootTest
+ @AutoConfigureMockMvc
, но было бы интересно протестировать без запуска всей автоматической настройки.
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = WebEnvironment.MOCK)
@AutoConfigureMockMvc
public class ExampleControllerSpringBootTest {
@Autowired
private MockMvc mockMvc;
// tests
}
Есть ли способ, что @WebMvcTest
могут использовать параметры, определенные в классе SecurityConfig
?
просто добавьте это в «application.properties» (в разделе «src/main/resources»): security.user.password = пароль (и выберите свой собственный пароль) –
Спасибо, но не исправим ... все еще используя настройки безопасности по умолчанию, но заставляя пароль «пароль». Я просто защищаю «/ admin *» URI, используя роль «ADMIN», конфигурация безопасности по умолчанию защищает все URI, используя роль «ПОЛЬЗОВАТЕЛЬ». – dmunozfer
Спасибо за комментарий Дэвид. Я не знал о защите по умолчанию, защищающей все URI с помощью 'USER'. – Snekse