Browse Source
* pr/5645: Polish auto-configuration for Spring Web Services Add auto-configuration for Spring Web Servicespull/5706/head
11 changed files with 335 additions and 27 deletions
@ -0,0 +1,79 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2016 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.autoconfigure.ws; |
||||||
|
|
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter; |
||||||
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration; |
||||||
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; |
||||||
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; |
||||||
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication; |
||||||
|
import org.springframework.boot.autoconfigure.web.EmbeddedServletContainerAutoConfiguration; |
||||||
|
import org.springframework.boot.context.embedded.ServletRegistrationBean; |
||||||
|
import org.springframework.boot.context.properties.EnableConfigurationProperties; |
||||||
|
import org.springframework.context.ApplicationContext; |
||||||
|
import org.springframework.context.annotation.Bean; |
||||||
|
import org.springframework.context.annotation.Configuration; |
||||||
|
import org.springframework.ws.config.annotation.EnableWs; |
||||||
|
import org.springframework.ws.config.annotation.WsConfigurationSupport; |
||||||
|
import org.springframework.ws.transport.http.MessageDispatcherServlet; |
||||||
|
|
||||||
|
/** |
||||||
|
* {@link EnableAutoConfiguration Auto-configuration} for Spring Web Services. |
||||||
|
* |
||||||
|
* @author Vedran Pavic |
||||||
|
* @author Stephane Nicoll |
||||||
|
* @since 1.4.0 |
||||||
|
*/ |
||||||
|
@Configuration |
||||||
|
@ConditionalOnWebApplication |
||||||
|
@ConditionalOnClass(MessageDispatcherServlet.class) |
||||||
|
@ConditionalOnMissingBean(WsConfigurationSupport.class) |
||||||
|
@EnableConfigurationProperties(WsProperties.class) |
||||||
|
@AutoConfigureAfter(EmbeddedServletContainerAutoConfiguration.class) |
||||||
|
public class WsAutoConfiguration { |
||||||
|
|
||||||
|
private final WsProperties properties; |
||||||
|
|
||||||
|
public WsAutoConfiguration(WsProperties properties) { |
||||||
|
this.properties = properties; |
||||||
|
} |
||||||
|
|
||||||
|
@Bean |
||||||
|
public ServletRegistrationBean messageDispatcherServlet( |
||||||
|
ApplicationContext applicationContext) { |
||||||
|
MessageDispatcherServlet servlet = new MessageDispatcherServlet(); |
||||||
|
servlet.setApplicationContext(applicationContext); |
||||||
|
String path = this.properties.getPath(); |
||||||
|
String urlMapping = (path.endsWith("/") ? path + "*" : path + "/*"); |
||||||
|
ServletRegistrationBean registration = new ServletRegistrationBean( |
||||||
|
servlet, urlMapping); |
||||||
|
WsProperties.Servlet servletProperties = this.properties.getServlet(); |
||||||
|
registration.setLoadOnStartup(servletProperties.getLoadOnStartup()); |
||||||
|
for (Map.Entry<String, String> entry : servletProperties.getInit().entrySet()) { |
||||||
|
registration.addInitParameter(entry.getKey(), entry.getValue()); |
||||||
|
} |
||||||
|
return registration; |
||||||
|
} |
||||||
|
|
||||||
|
@Configuration |
||||||
|
@EnableWs |
||||||
|
protected static class WsConfiguration { |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
@ -0,0 +1,89 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2016 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.autoconfigure.ws; |
||||||
|
|
||||||
|
import java.util.HashMap; |
||||||
|
import java.util.Map; |
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull; |
||||||
|
import javax.validation.constraints.Pattern; |
||||||
|
|
||||||
|
import org.springframework.boot.context.properties.ConfigurationProperties; |
||||||
|
|
||||||
|
/** |
||||||
|
* {@link ConfigurationProperties} for Spring Web Services. |
||||||
|
* |
||||||
|
* @author Vedran Pavic |
||||||
|
* @author Stephane Nicoll |
||||||
|
* @since 1.4.0 |
||||||
|
*/ |
||||||
|
@ConfigurationProperties("spring.ws") |
||||||
|
public class WsProperties { |
||||||
|
|
||||||
|
/** |
||||||
|
* Path that serves as the base URI for the services. |
||||||
|
*/ |
||||||
|
@NotNull |
||||||
|
@Pattern(regexp = "/[^?#]*", message = "Path must start with /") |
||||||
|
private String path = "/services"; |
||||||
|
|
||||||
|
private final Servlet servlet = new Servlet(); |
||||||
|
|
||||||
|
public String getPath() { |
||||||
|
return this.path; |
||||||
|
} |
||||||
|
|
||||||
|
public void setPath(String path) { |
||||||
|
this.path = path; |
||||||
|
} |
||||||
|
|
||||||
|
public Servlet getServlet() { |
||||||
|
return this.servlet; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
public static class Servlet { |
||||||
|
|
||||||
|
/** |
||||||
|
* Servlet init parameters to pass to Spring Web Services. |
||||||
|
*/ |
||||||
|
private Map<String, String> init = new HashMap<String, String>(); |
||||||
|
|
||||||
|
/** |
||||||
|
* Load on startup priority of the Spring Web Services servlet. |
||||||
|
*/ |
||||||
|
private int loadOnStartup = -1; |
||||||
|
|
||||||
|
public Map<String, String> getInit() { |
||||||
|
return this.init; |
||||||
|
} |
||||||
|
|
||||||
|
public void setInit(Map<String, String> init) { |
||||||
|
this.init = init; |
||||||
|
} |
||||||
|
|
||||||
|
public int getLoadOnStartup() { |
||||||
|
return this.loadOnStartup; |
||||||
|
} |
||||||
|
|
||||||
|
public void setLoadOnStartup(int loadOnStartup) { |
||||||
|
this.loadOnStartup = loadOnStartup; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
@ -0,0 +1,20 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2016 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. |
||||||
|
*/ |
||||||
|
|
||||||
|
/** |
||||||
|
* Auto-configuration for Spring Web Services. |
||||||
|
*/ |
||||||
|
package org.springframework.boot.autoconfigure.ws; |
||||||
@ -0,0 +1,110 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2016 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.autoconfigure.ws; |
||||||
|
|
||||||
|
import org.junit.After; |
||||||
|
import org.junit.Rule; |
||||||
|
import org.junit.Test; |
||||||
|
import org.junit.rules.ExpectedException; |
||||||
|
|
||||||
|
import org.springframework.beans.factory.BeanCreationException; |
||||||
|
import org.springframework.boot.context.embedded.ServletRegistrationBean; |
||||||
|
import org.springframework.boot.test.util.EnvironmentTestUtils; |
||||||
|
import org.springframework.mock.web.MockServletContext; |
||||||
|
import org.springframework.test.util.ReflectionTestUtils; |
||||||
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext; |
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat; |
||||||
|
|
||||||
|
/** |
||||||
|
* Tests for {@link WsAutoConfiguration}. |
||||||
|
* |
||||||
|
* @author Vedran Pavic |
||||||
|
* @author Stephane Nicoll |
||||||
|
*/ |
||||||
|
public class WsAutoConfigurationTests { |
||||||
|
|
||||||
|
@Rule |
||||||
|
public ExpectedException thrown = ExpectedException.none(); |
||||||
|
|
||||||
|
private AnnotationConfigWebApplicationContext context; |
||||||
|
|
||||||
|
@After |
||||||
|
public void close() { |
||||||
|
if (this.context != null) { |
||||||
|
this.context.close(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void defaultConfiguration() { |
||||||
|
load(WsAutoConfiguration.class); |
||||||
|
|
||||||
|
assertThat(this.context.getBeansOfType(ServletRegistrationBean.class)).hasSize(1); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void customPathMustBeginWithASlash() { |
||||||
|
this.thrown.expect(BeanCreationException.class); |
||||||
|
this.thrown.expectMessage("Path must start with /"); |
||||||
|
load(WsAutoConfiguration.class, "spring.ws.path=invalid"); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void customPathWithTrailingSlash() { |
||||||
|
load(WsAutoConfiguration.class, "spring.ws.path=/valid/"); |
||||||
|
assertThat(this.context.getBean(ServletRegistrationBean.class).getUrlMappings()) |
||||||
|
.contains("/valid/*"); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void customPath() { |
||||||
|
load(WsAutoConfiguration.class, "spring.ws.path=/valid"); |
||||||
|
assertThat(this.context.getBeansOfType(ServletRegistrationBean.class)).hasSize(1); |
||||||
|
assertThat(this.context.getBean(ServletRegistrationBean.class).getUrlMappings()) |
||||||
|
.contains("/valid/*"); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void customLoadOnStartup() { |
||||||
|
load(WsAutoConfiguration.class, "spring.ws.servlet.load-on-startup=1"); |
||||||
|
ServletRegistrationBean registrationBean = this.context |
||||||
|
.getBean(ServletRegistrationBean.class); |
||||||
|
assertThat(ReflectionTestUtils.getField(registrationBean, "loadOnStartup")) |
||||||
|
.isEqualTo(1); |
||||||
|
} |
||||||
|
|
||||||
|
@Test |
||||||
|
public void customInitParameters() { |
||||||
|
load(WsAutoConfiguration.class, "spring.ws.servlet.init.key1=value1", |
||||||
|
"spring.ws.servlet.init.key2=value2"); |
||||||
|
ServletRegistrationBean registrationBean = this.context |
||||||
|
.getBean(ServletRegistrationBean.class); |
||||||
|
assertThat(registrationBean.getInitParameters()).containsEntry("key1", "value1"); |
||||||
|
assertThat(registrationBean.getInitParameters()).containsEntry("key2", "value2"); |
||||||
|
} |
||||||
|
|
||||||
|
private void load(Class<?> config, String... environment) { |
||||||
|
AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext(); |
||||||
|
ctx.setServletContext(new MockServletContext()); |
||||||
|
EnvironmentTestUtils.addEnvironment(ctx, environment); |
||||||
|
ctx.register(config); |
||||||
|
ctx.refresh(); |
||||||
|
this.context = ctx; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
Loading…
Reference in new issue