commit
a189e4cf96
|
@ -28,12 +28,14 @@ import org.springframework.test.context.web.WebMergedContextConfiguration;
|
||||||
*
|
*
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @author Artsiom Yudovin
|
* @author Artsiom Yudovin
|
||||||
|
* @author Lorenzo Dee
|
||||||
*/
|
*/
|
||||||
class WebMvcTestContextBootstrapper extends SpringBootTestContextBootstrapper {
|
class WebMvcTestContextBootstrapper extends SpringBootTestContextBootstrapper {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected MergedContextConfiguration processMergedContextConfiguration(MergedContextConfiguration mergedConfig) {
|
protected MergedContextConfiguration processMergedContextConfiguration(MergedContextConfiguration mergedConfig) {
|
||||||
return new WebMergedContextConfiguration(super.processMergedContextConfiguration(mergedConfig), "");
|
MergedContextConfiguration processedMergedConfiguration = super.processMergedContextConfiguration(mergedConfig);
|
||||||
|
return new WebMergedContextConfiguration(processedMergedConfiguration, determineResourceBasePath(mergedConfig));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2019 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
|
||||||
|
*
|
||||||
|
* https://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.test.autoconfigure.web.servlet.mockmvc;
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import javax.servlet.ServletContext;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link WebMvcTest @WebMvcTest} when loading resources via
|
||||||
|
* {@link ServletContext}.
|
||||||
|
*
|
||||||
|
* @author Lorenzo Dee
|
||||||
|
*/
|
||||||
|
@WebMvcTest
|
||||||
|
class WebMvcTestServletContextResourceTests {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ServletContext servletContext;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getResourceLocation() throws Exception {
|
||||||
|
testResource("/inwebapp", "src/main/webapp");
|
||||||
|
testResource("/inmetainfresources", "/META-INF/resources");
|
||||||
|
testResource("/inresources", "/resources");
|
||||||
|
testResource("/instatic", "/static");
|
||||||
|
testResource("/inpublic", "/public");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void testResource(String path, String expectedLocation) throws MalformedURLException {
|
||||||
|
URL resource = this.servletContext.getResource(path);
|
||||||
|
assertThat(resource).isNotNull();
|
||||||
|
assertThat(resource.getPath()).contains(expectedLocation);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2019 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
|
||||||
|
*
|
||||||
|
* https://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.test.autoconfigure.web.servlet.mockmvc;
|
||||||
|
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
|
import javax.servlet.ServletContext;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest;
|
||||||
|
import org.springframework.test.context.web.WebAppConfiguration;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for {@link WebMvcTest @WebMvcTest} when loading resources via the
|
||||||
|
* {@link ServletContext} with {@link WebAppConfiguration @WebAppConfiguration}.
|
||||||
|
*
|
||||||
|
* @author Lorenzo Dee
|
||||||
|
*/
|
||||||
|
@WebMvcTest
|
||||||
|
@WebAppConfiguration("src/test/webapp")
|
||||||
|
class WebMvcTestWithWebAppConfigurationTests {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private ServletContext servletContext;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void whenBasePathIsCustomizedResourcesCanBeLoadedFromThatLocation() throws Exception {
|
||||||
|
testResource("/inwebapp", "src/test/webapp");
|
||||||
|
testResource("/inmetainfresources", "/META-INF/resources");
|
||||||
|
testResource("/inresources", "/resources");
|
||||||
|
testResource("/instatic", "/static");
|
||||||
|
testResource("/inpublic", "/public");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void testResource(String path, String expectedLocation) throws MalformedURLException {
|
||||||
|
URL resource = this.servletContext.getResource(path);
|
||||||
|
assertThat(resource).isNotNull();
|
||||||
|
assertThat(resource.getPath()).contains(expectedLocation);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -72,6 +72,7 @@ import org.springframework.util.StringUtils;
|
||||||
* @author Andy Wilkinson
|
* @author Andy Wilkinson
|
||||||
* @author Brian Clozel
|
* @author Brian Clozel
|
||||||
* @author Madhura Bhave
|
* @author Madhura Bhave
|
||||||
|
* @author Lorenzo Dee
|
||||||
* @since 1.4.0
|
* @since 1.4.0
|
||||||
* @see SpringBootTest
|
* @see SpringBootTest
|
||||||
* @see TestConfiguration
|
* @see TestConfiguration
|
||||||
|
@ -154,10 +155,7 @@ public class SpringBootTestContextBootstrapper extends DefaultTestContextBootstr
|
||||||
WebApplicationType webApplicationType = getWebApplicationType(mergedConfig);
|
WebApplicationType webApplicationType = getWebApplicationType(mergedConfig);
|
||||||
if (webApplicationType == WebApplicationType.SERVLET
|
if (webApplicationType == WebApplicationType.SERVLET
|
||||||
&& (webEnvironment.isEmbedded() || webEnvironment == WebEnvironment.MOCK)) {
|
&& (webEnvironment.isEmbedded() || webEnvironment == WebEnvironment.MOCK)) {
|
||||||
String resourceBasePath = MergedAnnotations.from(mergedConfig.getTestClass(), SearchStrategy.EXHAUSTIVE)
|
mergedConfig = new WebMergedContextConfiguration(mergedConfig, determineResourceBasePath(mergedConfig));
|
||||||
.get(WebAppConfiguration.class).getValue(MergedAnnotation.VALUE, String.class)
|
|
||||||
.orElse("src/main/webapp");
|
|
||||||
mergedConfig = new WebMergedContextConfiguration(mergedConfig, resourceBasePath);
|
|
||||||
}
|
}
|
||||||
else if (webApplicationType == WebApplicationType.REACTIVE
|
else if (webApplicationType == WebApplicationType.REACTIVE
|
||||||
&& (webEnvironment.isEmbedded() || webEnvironment == WebEnvironment.MOCK)) {
|
&& (webEnvironment.isEmbedded() || webEnvironment == WebEnvironment.MOCK)) {
|
||||||
|
@ -189,6 +187,20 @@ public class SpringBootTestContextBootstrapper extends DefaultTestContextBootstr
|
||||||
return WebApplicationType.SERVLET;
|
return WebApplicationType.SERVLET;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determines the resource base path for web applications using the value of
|
||||||
|
* {@link WebAppConfiguration @WebAppConfiguration}, if any, on the test class of the
|
||||||
|
* given {@code configuration}. Defaults to {@code src/main/webapp} in its absence.
|
||||||
|
* @param configuration the configure to examine
|
||||||
|
* @return the resource base path
|
||||||
|
* @since 2.1.6
|
||||||
|
*/
|
||||||
|
protected String determineResourceBasePath(MergedContextConfiguration configuration) {
|
||||||
|
return MergedAnnotations.from(configuration.getTestClass(), SearchStrategy.EXHAUSTIVE)
|
||||||
|
.get(WebAppConfiguration.class).getValue(MergedAnnotation.VALUE, String.class)
|
||||||
|
.orElse("src/main/webapp");
|
||||||
|
}
|
||||||
|
|
||||||
private boolean isWebEnvironmentSupported(MergedContextConfiguration mergedConfig) {
|
private boolean isWebEnvironmentSupported(MergedContextConfiguration mergedConfig) {
|
||||||
Class<?> testClass = mergedConfig.getTestClass();
|
Class<?> testClass = mergedConfig.getTestClass();
|
||||||
ContextHierarchy hierarchy = AnnotationUtils.getAnnotation(testClass, ContextHierarchy.class);
|
ContextHierarchy hierarchy = AnnotationUtils.getAnnotation(testClass, ContextHierarchy.class);
|
||||||
|
|
Loading…
Reference in New Issue