Merge branch '1.5.x'
This commit is contained in:
commit
d477223d77
|
|
@ -3054,6 +3054,16 @@ Hibernate autoconfig is active because the `ddl-auto` settings are more fine-gra
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[[boot-features-jpa-in-web-environment]]
|
||||||
|
==== Open EntityManager in View
|
||||||
|
If you are running a web application, Spring Boot will by default register
|
||||||
|
{spring-javadoc}/orm/jpa/support/OpenEntityManagerInViewInterceptor.html[`OpenEntityManagerInViewInterceptor`]
|
||||||
|
to apply the "Open EntityManager in View" pattern, i.e. to allow for lazy loading in web
|
||||||
|
views. If you don't want this behavior you should set `spring.jpa.open-in-view` to
|
||||||
|
`false` in your `application.properties`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[[boot-features-sql-h2-console]]
|
[[boot-features-sql-h2-console]]
|
||||||
=== Using H2's web console
|
=== Using H2's web console
|
||||||
The http://www.h2database.com[H2 database] provides a
|
The http://www.h2database.com[H2 database] provides a
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2016 the original author or authors.
|
* Copyright 2012-2017 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -121,7 +121,7 @@ public class ServletContextInitializerBeans
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
addServletContextInitializerBean(ServletContextInitializer.class, beanName,
|
addServletContextInitializerBean(ServletContextInitializer.class, beanName,
|
||||||
initializer, beanFactory, null);
|
initializer, beanFactory, initializer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,121 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2017 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.web.servlet;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.servlet.Filter;
|
||||||
|
import javax.servlet.FilterChain;
|
||||||
|
import javax.servlet.FilterConfig;
|
||||||
|
import javax.servlet.ServletContext;
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
|
import javax.servlet.ServletResponse;
|
||||||
|
import javax.servlet.http.HttpServlet;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import org.springframework.context.ConfigurableApplicationContext;
|
||||||
|
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link ServletContextInitializerBeans}.
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
*/
|
||||||
|
public class ServletContextInitializerBeansTests {
|
||||||
|
|
||||||
|
private ConfigurableApplicationContext context;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void servletThatImplementsServletContextInitializerIsOnlyRegisteredOnce() {
|
||||||
|
load(ServletConfiguration.class);
|
||||||
|
ServletContextInitializerBeans initializerBeans = new ServletContextInitializerBeans(
|
||||||
|
this.context.getBeanFactory());
|
||||||
|
assertThat(initializerBeans.size()).isEqualTo(1);
|
||||||
|
assertThat(initializerBeans.iterator()).hasOnlyElementsOfType(TestServlet.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void filterThatImplementsServletContextInitializerIsOnlyRegisteredOnce() {
|
||||||
|
load(FilterConfiguration.class);
|
||||||
|
ServletContextInitializerBeans initializerBeans = new ServletContextInitializerBeans(
|
||||||
|
this.context.getBeanFactory());
|
||||||
|
assertThat(initializerBeans.size()).isEqualTo(1);
|
||||||
|
assertThat(initializerBeans.iterator()).hasOnlyElementsOfType(TestFilter.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void load(Class<?> configuration) {
|
||||||
|
this.context = new AnnotationConfigApplicationContext(configuration);
|
||||||
|
}
|
||||||
|
|
||||||
|
static class ServletConfiguration {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public TestServlet testServlet() {
|
||||||
|
return new TestServlet();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static class FilterConfiguration {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public TestFilter testFilter() {
|
||||||
|
return new TestFilter();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static class TestServlet extends HttpServlet implements ServletContextInitializer {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStartup(ServletContext servletContext) throws ServletException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static class TestFilter implements Filter, ServletContextInitializer {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStartup(ServletContext servletContext) throws ServletException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init(FilterConfig filterConfig) throws ServletException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doFilter(ServletRequest request, ServletResponse response,
|
||||||
|
FilterChain chain) throws IOException, ServletException {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void destroy() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue