|
|
|
@ -353,6 +353,7 @@ class ServletWebServerFactoryAutoConfigurationTests {
|
|
|
|
|
assertThat(context).hasSingleBean(FilterRegistrationBean.class);
|
|
|
|
|
Filter filter = context.getBean(FilterRegistrationBean.class).getFilter();
|
|
|
|
|
assertThat(filter).isInstanceOf(ForwardedHeaderFilter.class);
|
|
|
|
|
assertThat(filter).extracting("relativeRedirects").isEqualTo(false);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -377,6 +378,48 @@ class ServletWebServerFactoryAutoConfigurationTests {
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
void relativeRedirectsShouldBeEnabledWhenUsingTomcatContainerAndUseRelativeRedirects() {
|
|
|
|
|
WebApplicationContextRunner runner = new WebApplicationContextRunner(
|
|
|
|
|
AnnotationConfigServletWebServerApplicationContext::new)
|
|
|
|
|
.withConfiguration(AutoConfigurations.of(ServletWebServerFactoryAutoConfiguration.class))
|
|
|
|
|
.withPropertyValues("server.forward-headers-strategy=framework",
|
|
|
|
|
"server.tomcat.use-relative-redirects=true");
|
|
|
|
|
runner.run((context) -> {
|
|
|
|
|
Filter filter = context.getBean(FilterRegistrationBean.class).getFilter();
|
|
|
|
|
assertThat(filter).isInstanceOf(ForwardedHeaderFilter.class);
|
|
|
|
|
assertThat(filter).extracting("relativeRedirects").isEqualTo(true);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
void relativeRedirectsShouldNotBeEnabledWhenUsingTomcatContainerAndNotUsingRelativeRedirects() {
|
|
|
|
|
WebApplicationContextRunner runner = new WebApplicationContextRunner(
|
|
|
|
|
AnnotationConfigServletWebServerApplicationContext::new)
|
|
|
|
|
.withConfiguration(AutoConfigurations.of(ServletWebServerFactoryAutoConfiguration.class))
|
|
|
|
|
.withPropertyValues("server.forward-headers-strategy=framework",
|
|
|
|
|
"server.tomcat.use-relative-redirects=false");
|
|
|
|
|
runner.run((context) -> {
|
|
|
|
|
Filter filter = context.getBean(FilterRegistrationBean.class).getFilter();
|
|
|
|
|
assertThat(filter).isInstanceOf(ForwardedHeaderFilter.class);
|
|
|
|
|
assertThat(filter).extracting("relativeRedirects").isEqualTo(false);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
void relativeRedirectsShouldNotBeEnabledWhenNotUsingTomcatContainer() {
|
|
|
|
|
WebApplicationContextRunner runner = new WebApplicationContextRunner(
|
|
|
|
|
AnnotationConfigServletWebServerApplicationContext::new)
|
|
|
|
|
.withClassLoader(new FilteredClassLoader(Tomcat.class))
|
|
|
|
|
.withConfiguration(AutoConfigurations.of(ServletWebServerFactoryAutoConfiguration.class))
|
|
|
|
|
.withPropertyValues("server.forward-headers-strategy=framework");
|
|
|
|
|
runner.run((context) -> {
|
|
|
|
|
Filter filter = context.getBean(FilterRegistrationBean.class).getFilter();
|
|
|
|
|
assertThat(filter).isInstanceOf(ForwardedHeaderFilter.class);
|
|
|
|
|
assertThat(filter).extracting("relativeRedirects").isEqualTo(false);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private ContextConsumer<AssertableWebApplicationContext> verifyContext() {
|
|
|
|
|
return this::verifyContext;
|
|
|
|
|
}
|
|
|
|
|