Browse Source

Merge branch '2.0.x'

pull/14912/merge
Phillip Webb 7 years ago
parent
commit
31335bb50f
  1. 1
      spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/BeanTypeRegistry.java
  2. 2
      spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/freemarker/FreeMarkerServletWebConfiguration.java
  3. 2
      spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/thymeleaf/ThymeleafAutoConfiguration.java
  4. 84
      spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/freemarker/FreeMarkerAutoConfigurationServletIntegrationTests.java
  5. 33
      spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/thymeleaf/ThymeleafServletAutoConfigurationTests.java

1
spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/condition/BeanTypeRegistry.java

@ -100,7 +100,6 @@ final class BeanTypeRegistry implements SmartInitializingSingleton { @@ -100,7 +100,6 @@ final class BeanTypeRegistry implements SmartInitializingSingleton {
(DefaultListableBeanFactory) beanFactory))
.getBeanDefinition();
listableBeanFactory.registerBeanDefinition(BEAN_NAME, bd);
}
return listableBeanFactory.getBean(BEAN_NAME, BeanTypeRegistry.class);
}

2
spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/freemarker/FreeMarkerServletWebConfiguration.java

@ -74,7 +74,7 @@ class FreeMarkerServletWebConfiguration extends AbstractFreeMarkerConfiguration @@ -74,7 +74,7 @@ class FreeMarkerServletWebConfiguration extends AbstractFreeMarkerConfiguration
}
@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingBean(ResourceUrlEncodingFilter.class)
@ConditionalOnEnabledResourceChain
public FilterRegistrationBean<ResourceUrlEncodingFilter> resourceUrlEncodingFilter() {
FilterRegistrationBean<ResourceUrlEncodingFilter> registration = new FilterRegistrationBean<>(

2
spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/thymeleaf/ThymeleafAutoConfiguration.java

@ -169,7 +169,7 @@ public class ThymeleafAutoConfiguration { @@ -169,7 +169,7 @@ public class ThymeleafAutoConfiguration {
static class ThymeleafWebMvcConfiguration {
@Bean
@ConditionalOnMissingBean
@ConditionalOnMissingBean(ResourceUrlEncodingFilter.class)
@ConditionalOnEnabledResourceChain
public FilterRegistrationBean<ResourceUrlEncodingFilter> resourceUrlEncodingFilter() {
FilterRegistrationBean<ResourceUrlEncodingFilter> registration = new FilterRegistrationBean<>(

84
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/freemarker/FreeMarkerAutoConfigurationServletIntegrationTests.java

@ -19,16 +19,22 @@ package org.springframework.boot.autoconfigure.freemarker; @@ -19,16 +19,22 @@ package org.springframework.boot.autoconfigure.freemarker;
import java.io.StringWriter;
import java.util.EnumSet;
import java.util.Locale;
import java.util.Map;
import javax.servlet.DispatcherType;
import javax.servlet.http.HttpServletRequest;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.boot.autoconfigure.ImportAutoConfiguration;
import org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration;
import org.springframework.boot.test.util.TestPropertyValues;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.filter.OrderedCharacterEncodingFilter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.mock.web.MockHttpServletRequest;
import org.springframework.mock.web.MockHttpServletResponse;
import org.springframework.mock.web.MockServletContext;
@ -51,12 +57,7 @@ import static org.assertj.core.api.Assertions.assertThat; @@ -51,12 +57,7 @@ import static org.assertj.core.api.Assertions.assertThat;
*/
public class FreeMarkerAutoConfigurationServletIntegrationTests {
private AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
@Before
public void setupContext() {
this.context.setServletContext(new MockServletContext());
}
private AnnotationConfigWebApplicationContext context;
@After
public void close() {
@ -67,7 +68,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -67,7 +68,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void defaultConfiguration() {
registerAndRefreshContext();
load();
assertThat(this.context.getBean(FreeMarkerViewResolver.class)).isNotNull();
assertThat(this.context.getBean(FreeMarkerConfigurer.class)).isNotNull();
assertThat(this.context.getBean(FreeMarkerConfig.class)).isNotNull();
@ -77,7 +78,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -77,7 +78,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void defaultViewResolution() throws Exception {
registerAndRefreshContext();
load();
MockHttpServletResponse response = render("home");
String result = response.getContentAsString();
assertThat(result).contains("home");
@ -86,7 +87,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -86,7 +87,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void customContentType() throws Exception {
registerAndRefreshContext("spring.freemarker.contentType:application/json");
load("spring.freemarker.contentType:application/json");
MockHttpServletResponse response = render("home");
String result = response.getContentAsString();
assertThat(result).contains("home");
@ -95,7 +96,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -95,7 +96,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void customPrefix() throws Exception {
registerAndRefreshContext("spring.freemarker.prefix:prefix/");
load("spring.freemarker.prefix:prefix/");
MockHttpServletResponse response = render("prefixed");
String result = response.getContentAsString();
assertThat(result).contains("prefixed");
@ -103,7 +104,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -103,7 +104,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void customSuffix() throws Exception {
registerAndRefreshContext("spring.freemarker.suffix:.freemarker");
load("spring.freemarker.suffix:.freemarker");
MockHttpServletResponse response = render("suffixed");
String result = response.getContentAsString();
assertThat(result).contains("suffixed");
@ -111,7 +112,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -111,7 +112,7 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void customTemplateLoaderPath() throws Exception {
registerAndRefreshContext(
load(
"spring.freemarker.templateLoaderPath:classpath:/custom-templates/");
MockHttpServletResponse response = render("custom");
String result = response.getContentAsString();
@ -120,14 +121,14 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -120,14 +121,14 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void disableCache() {
registerAndRefreshContext("spring.freemarker.cache:false");
load("spring.freemarker.cache:false");
assertThat(this.context.getBean(FreeMarkerViewResolver.class).getCacheLimit())
.isEqualTo(0);
}
@Test
public void allowSessionOverride() {
registerAndRefreshContext("spring.freemarker.allow-session-override:true");
load("spring.freemarker.allow-session-override:true");
AbstractTemplateViewResolver viewResolver = this.context
.getBean(FreeMarkerViewResolver.class);
assertThat(viewResolver).hasFieldOrPropertyWithValue("allowSessionOverride",
@ -137,14 +138,14 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -137,14 +138,14 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@SuppressWarnings("deprecation")
@Test
public void customFreeMarkerSettings() {
registerAndRefreshContext("spring.freemarker.settings.boolean_format:yup,nope");
load("spring.freemarker.settings.boolean_format:yup,nope");
assertThat(this.context.getBean(FreeMarkerConfigurer.class).getConfiguration()
.getSetting("boolean_format")).isEqualTo("yup,nope");
}
@Test
public void renderTemplate() throws Exception {
registerAndRefreshContext();
load();
FreeMarkerConfigurer freemarker = this.context
.getBean(FreeMarkerConfigurer.class);
StringWriter writer = new StringWriter();
@ -154,13 +155,13 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -154,13 +155,13 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
@Test
public void registerResourceHandlingFilterDisabledByDefault() {
registerAndRefreshContext();
load();
assertThat(this.context.getBeansOfType(FilterRegistrationBean.class)).isEmpty();
}
@Test
public void registerResourceHandlingFilterOnlyIfResourceChainIsEnabled() {
registerAndRefreshContext("spring.resources.chain.enabled:true");
load("spring.resources.chain.enabled:true");
FilterRegistrationBean<?> registration = this.context
.getBean(FilterRegistrationBean.class);
assertThat(registration.getFilter())
@ -169,9 +170,31 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -169,9 +170,31 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
EnumSet.of(DispatcherType.REQUEST, DispatcherType.ERROR));
}
private void registerAndRefreshContext(String... env) {
@Test
@SuppressWarnings("rawtypes")
public void registerResourceHandlingFilterWithOtherRegistrationBean() {
// gh-14897
load(FilterRegistrationConfiguration.class,
"spring.resources.chain.enabled:true");
Map<String, FilterRegistrationBean> beans = this.context
.getBeansOfType(FilterRegistrationBean.class);
assertThat(beans).hasSize(2);
FilterRegistrationBean registration = beans.values().stream()
.filter((r) -> r.getFilter() instanceof ResourceUrlEncodingFilter)
.findFirst().get();
assertThat(registration).hasFieldOrPropertyWithValue("dispatcherTypes",
EnumSet.of(DispatcherType.REQUEST, DispatcherType.ERROR));
}
private void load(String... env) {
load(BaseConfiguration.class, env);
}
private void load(Class<?> config, String... env) {
this.context = new AnnotationConfigWebApplicationContext();
this.context.setServletContext(new MockServletContext());
TestPropertyValues.of(env).applyTo(this.context);
this.context.register(FreeMarkerAutoConfiguration.class);
this.context.register(config);
this.context.refresh();
}
@ -192,4 +215,23 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests { @@ -192,4 +215,23 @@ public class FreeMarkerAutoConfigurationServletIntegrationTests {
return response;
}
@Configuration
@ImportAutoConfiguration({ FreeMarkerAutoConfiguration.class,
PropertyPlaceholderAutoConfiguration.class })
static class BaseConfiguration {
}
@Configuration
@Import(BaseConfiguration.class)
static class FilterRegistrationConfiguration {
@Bean
public FilterRegistrationBean<OrderedCharacterEncodingFilter> filterRegisration() {
return new FilterRegistrationBean<OrderedCharacterEncodingFilter>(
new OrderedCharacterEncodingFilter());
}
}
}

33
spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/thymeleaf/ThymeleafServletAutoConfigurationTests.java

@ -20,6 +20,7 @@ import java.io.File; @@ -20,6 +20,7 @@ import java.io.File;
import java.util.Collections;
import java.util.EnumSet;
import java.util.Locale;
import java.util.Map;
import javax.servlet.DispatcherType;
@ -42,6 +43,7 @@ import org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoCon @@ -42,6 +43,7 @@ import org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoCon
import org.springframework.boot.test.rule.OutputCapture;
import org.springframework.boot.test.util.TestPropertyValues;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.filter.OrderedCharacterEncodingFilter;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@ -275,6 +277,22 @@ public class ThymeleafServletAutoConfigurationTests { @@ -275,6 +277,22 @@ public class ThymeleafServletAutoConfigurationTests {
EnumSet.of(DispatcherType.REQUEST, DispatcherType.ERROR));
}
@Test
@SuppressWarnings("rawtypes")
public void registerResourceHandlingFilterWithOtherRegistrationBean() {
// gh-14897
load(FilterRegistrationConfiguration.class,
"spring.resources.chain.enabled:true");
Map<String, FilterRegistrationBean> beans = this.context
.getBeansOfType(FilterRegistrationBean.class);
assertThat(beans).hasSize(2);
FilterRegistrationBean registration = beans.values().stream()
.filter((r) -> r.getFilter() instanceof ResourceUrlEncodingFilter)
.findFirst().get();
assertThat(registration).hasFieldOrPropertyWithValue("dispatcherTypes",
EnumSet.of(DispatcherType.REQUEST, DispatcherType.ERROR));
}
@Test
public void layoutDialectCanBeCustomized() {
load(LayoutDialectConfiguration.class);
@ -295,9 +313,6 @@ public class ThymeleafServletAutoConfigurationTests { @@ -295,9 +313,6 @@ public class ThymeleafServletAutoConfigurationTests {
private void load(Class<?> config, String... envVariables) {
this.context = new AnnotationConfigWebApplicationContext();
TestPropertyValues.of(envVariables).applyTo(this.context);
if (config != null) {
this.context.register(config);
}
this.context.register(config);
this.context.refresh();
}
@ -320,4 +335,16 @@ public class ThymeleafServletAutoConfigurationTests { @@ -320,4 +335,16 @@ public class ThymeleafServletAutoConfigurationTests {
}
@Configuration
@Import(BaseConfiguration.class)
static class FilterRegistrationConfiguration {
@Bean
public FilterRegistrationBean<OrderedCharacterEncodingFilter> filterRegisration() {
return new FilterRegistrationBean<OrderedCharacterEncodingFilter>(
new OrderedCharacterEncodingFilter());
}
}
}

Loading…
Cancel
Save