|
|
|
@ -45,6 +45,8 @@ import org.springframework.mock.web.MockHttpServletRequest;
|
|
|
|
|
import org.springframework.mock.web.MockHttpServletResponse;
|
|
|
|
|
import org.springframework.mock.web.MockServletContext;
|
|
|
|
|
import org.springframework.security.config.BeanIds;
|
|
|
|
|
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
|
|
|
|
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
|
|
|
|
|
import org.springframework.test.web.servlet.MockMvc;
|
|
|
|
|
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
|
|
|
|
|
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
|
|
|
@ -157,6 +159,7 @@ class RemoteDevToolsAutoConfigurationTests {
|
|
|
|
|
mockMvc.perform(MockMvcRequestBuilders.get(DEFAULT_CONTEXT_PATH + "/restart").header(DEFAULT_SECRET_HEADER_NAME,
|
|
|
|
|
"supersecret")).andExpect(status().isOk());
|
|
|
|
|
assertRestartInvoked(true);
|
|
|
|
|
assertThat(this.context.containsBean("devtoolsSecurityFilterChain")).isTrue();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
@ -182,6 +185,25 @@ class RemoteDevToolsAutoConfigurationTests {
|
|
|
|
|
mockMvc.perform(MockMvcRequestBuilders.get("/my-path")).andExpect(status().isUnauthorized());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
void securityConfigurationWhenWebSecurityConfigurerAdapterIsFound2() throws Exception {
|
|
|
|
|
this.context = getContext(() -> {
|
|
|
|
|
AnnotationConfigServletWebApplicationContext context = new AnnotationConfigServletWebApplicationContext();
|
|
|
|
|
context.setServletContext(new MockServletContext());
|
|
|
|
|
context.register(Config.class, PropertyPlaceholderAutoConfiguration.class,
|
|
|
|
|
TestWebSecurityConfigurerAdapter.class);
|
|
|
|
|
TestPropertyValues.of("spring.devtools.remote.secret:supersecret").applyTo(context);
|
|
|
|
|
context.refresh();
|
|
|
|
|
return context;
|
|
|
|
|
});
|
|
|
|
|
DispatcherFilter filter = this.context.getBean(DispatcherFilter.class);
|
|
|
|
|
MockMvc mockMvc = MockMvcBuilders.webAppContextSetup(this.context).apply(springSecurity()).addFilter(filter)
|
|
|
|
|
.build();
|
|
|
|
|
mockMvc.perform(MockMvcRequestBuilders.get(DEFAULT_CONTEXT_PATH + "/restart").header(DEFAULT_SECRET_HEADER_NAME,
|
|
|
|
|
"supersecret")).andExpect(status().isOk());
|
|
|
|
|
assertRestartInvoked(true);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
void disableRestart() throws Exception {
|
|
|
|
|
this.context = getContext(() -> loadContext("spring.devtools.remote.secret:supersecret",
|
|
|
|
@ -250,6 +272,16 @@ class RemoteDevToolsAutoConfigurationTests {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Configuration(proxyBeanMethods = false)
|
|
|
|
|
static class TestWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected void configure(HttpSecurity http) throws Exception {
|
|
|
|
|
http.antMatcher("/foo/**").authorizeRequests().anyRequest().authenticated().and().httpBasic();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Mock {@link HttpRestartServer} implementation.
|
|
|
|
|
*/
|
|
|
|
|