Do not override requestContextAttribute with null in UrlBasedViewResolvers
Prior to this commit, if a subclass of org.springframework.web.servlet.view.AbstractView or org.springframework.web.reactive.result.view.AbstractUrlBasedView configured a custom value for the requestContextAttribute, that value was overwritten with null whenever the View was dynamically instantiated by a UrlBasedViewResolver, and this could lead to confusing behavior for users of the View. This commit addresses this issue by ensuring that the UrlBasedViewResolvers in spring-webmvc and spring-webflux do not override the requestContextAttribute in a View if the UrlBasedViewResolver has not been explicitly configured with a custom requestContextAttribute value. Closes gh-23129
This commit is contained in:
parent
c4075cf216
commit
451cce4fe8
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2017 the original author or authors.
|
* Copyright 2002-2019 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.
|
||||||
|
@ -30,8 +30,8 @@ import org.springframework.util.Assert;
|
||||||
import org.springframework.util.PatternMatchUtils;
|
import org.springframework.util.PatternMatchUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A {@link ViewResolver} that allow direct resolution of symbolic view names
|
* A {@link ViewResolver} that allows direct resolution of symbolic view names
|
||||||
* to URLs without explicit mapping definition. This is useful if symbolic names
|
* to URLs without explicit mapping definitions. This is useful if symbolic names
|
||||||
* match the names of view resources in a straightforward manner (i.e. the
|
* match the names of view resources in a straightforward manner (i.e. the
|
||||||
* symbolic name is the unique part of the resource's filename), without the need
|
* symbolic name is the unique part of the resource's filename), without the need
|
||||||
* for a dedicated mapping to be defined for each view.
|
* for a dedicated mapping to be defined for each view.
|
||||||
|
@ -59,6 +59,7 @@ import org.springframework.util.PatternMatchUtils;
|
||||||
* @author Rossen Stoyanchev
|
* @author Rossen Stoyanchev
|
||||||
* @author Sebastien Deleuze
|
* @author Sebastien Deleuze
|
||||||
* @author Juergen Hoeller
|
* @author Juergen Hoeller
|
||||||
|
* @author Sam Brannen
|
||||||
* @since 5.0
|
* @since 5.0
|
||||||
*/
|
*/
|
||||||
public class UrlBasedViewResolver extends ViewResolverSupport
|
public class UrlBasedViewResolver extends ViewResolverSupport
|
||||||
|
@ -266,7 +267,7 @@ public class UrlBasedViewResolver extends ViewResolverSupport
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new View instance of the specified view class and configures it.
|
* Creates a new View instance of the specified view class and configures it.
|
||||||
* Does <i>not</i> perform any lookup for pre-defined View instances.
|
* <p>Does <i>not</i> perform any lookup for pre-defined View instances.
|
||||||
* <p>Spring lifecycle methods as defined by the bean container do not have to
|
* <p>Spring lifecycle methods as defined by the bean container do not have to
|
||||||
* be called here: They will be automatically applied afterwards, provided
|
* be called here: They will be automatically applied afterwards, provided
|
||||||
* that an {@link #setApplicationContext ApplicationContext} is available.
|
* that an {@link #setApplicationContext ApplicationContext} is available.
|
||||||
|
@ -281,10 +282,14 @@ public class UrlBasedViewResolver extends ViewResolverSupport
|
||||||
|
|
||||||
AbstractUrlBasedView view = (AbstractUrlBasedView) BeanUtils.instantiateClass(viewClass);
|
AbstractUrlBasedView view = (AbstractUrlBasedView) BeanUtils.instantiateClass(viewClass);
|
||||||
view.setSupportedMediaTypes(getSupportedMediaTypes());
|
view.setSupportedMediaTypes(getSupportedMediaTypes());
|
||||||
view.setRequestContextAttribute(getRequestContextAttribute());
|
|
||||||
view.setDefaultCharset(getDefaultCharset());
|
view.setDefaultCharset(getDefaultCharset());
|
||||||
view.setUrl(getPrefix() + viewName + getSuffix());
|
view.setUrl(getPrefix() + viewName + getSuffix());
|
||||||
|
|
||||||
|
String requestContextAttribute = getRequestContextAttribute();
|
||||||
|
if (requestContextAttribute != null) {
|
||||||
|
view.setRequestContextAttribute(requestContextAttribute);
|
||||||
|
}
|
||||||
|
|
||||||
return view;
|
return view;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,20 +37,60 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
*
|
*
|
||||||
* @author Rossen Stoyanchev
|
* @author Rossen Stoyanchev
|
||||||
* @author Sebastien Deleuze
|
* @author Sebastien Deleuze
|
||||||
|
* @author Sam Brannen
|
||||||
*/
|
*/
|
||||||
public class UrlBasedViewResolverTests {
|
public class UrlBasedViewResolverTests {
|
||||||
|
|
||||||
private UrlBasedViewResolver resolver;
|
private final UrlBasedViewResolver resolver = new UrlBasedViewResolver();
|
||||||
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setup() {
|
public void setup() {
|
||||||
StaticApplicationContext context = new StaticApplicationContext();
|
StaticApplicationContext context = new StaticApplicationContext();
|
||||||
context.refresh();
|
context.refresh();
|
||||||
this.resolver = new UrlBasedViewResolver();
|
|
||||||
this.resolver.setApplicationContext(context);
|
this.resolver.setApplicationContext(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void urlBasedViewResolverOverridesCustomRequestContextAttributeWithNonNullValue() throws Exception {
|
||||||
|
assertThat(new TestView().getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated directly")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
|
||||||
|
this.resolver.setViewClass(TestView.class);
|
||||||
|
this.resolver.setRequestContextAttribute("viewResolverRequestContext");
|
||||||
|
|
||||||
|
Mono<View> mono = this.resolver.resolveViewName("example", Locale.getDefault());
|
||||||
|
StepVerifier.create(mono)
|
||||||
|
.consumeNextWith(view -> {
|
||||||
|
assertThat(view).isInstanceOf(TestView.class);
|
||||||
|
assertThat(((TestView) view).getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated dynamically by UrlBasedViewResolver")
|
||||||
|
.isEqualTo("viewResolverRequestContext");
|
||||||
|
})
|
||||||
|
.expectComplete()
|
||||||
|
.verify(Duration.ZERO);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void urlBasedViewResolverDoesNotOverrideCustomRequestContextAttributeWithNull() throws Exception {
|
||||||
|
assertThat(new TestView().getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated directly")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
|
||||||
|
this.resolver.setViewClass(TestView.class);
|
||||||
|
|
||||||
|
Mono<View> mono = this.resolver.resolveViewName("example", Locale.getDefault());
|
||||||
|
StepVerifier.create(mono)
|
||||||
|
.consumeNextWith(view -> {
|
||||||
|
assertThat(view).isInstanceOf(TestView.class);
|
||||||
|
assertThat(((TestView) view).getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated dynamically by UrlBasedViewResolver")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
})
|
||||||
|
.expectComplete()
|
||||||
|
.verify(Duration.ZERO);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void viewNames() throws Exception {
|
public void viewNames() throws Exception {
|
||||||
|
@ -98,6 +138,10 @@ public class UrlBasedViewResolverTests {
|
||||||
|
|
||||||
private static class TestView extends AbstractUrlBasedView {
|
private static class TestView extends AbstractUrlBasedView {
|
||||||
|
|
||||||
|
public TestView() {
|
||||||
|
setRequestContextAttribute("testRequestContext");
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean checkResourceExists(Locale locale) throws Exception {
|
public boolean checkResourceExists(Locale locale) throws Exception {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2018 the original author or authors.
|
* Copyright 2002-2019 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.
|
||||||
|
@ -34,7 +34,7 @@ import org.springframework.web.servlet.View;
|
||||||
/**
|
/**
|
||||||
* Simple implementation of the {@link org.springframework.web.servlet.ViewResolver}
|
* Simple implementation of the {@link org.springframework.web.servlet.ViewResolver}
|
||||||
* interface, allowing for direct resolution of symbolic view names to URLs,
|
* interface, allowing for direct resolution of symbolic view names to URLs,
|
||||||
* without explicit mapping definition. This is useful if your symbolic names
|
* without explicit mapping definitions. This is useful if your symbolic names
|
||||||
* match the names of your view resources in a straightforward manner
|
* match the names of your view resources in a straightforward manner
|
||||||
* (i.e. the symbolic name is the unique part of the resource's filename),
|
* (i.e. the symbolic name is the unique part of the resource's filename),
|
||||||
* without the need for a dedicated mapping to be defined for each view.
|
* without the need for a dedicated mapping to be defined for each view.
|
||||||
|
@ -65,14 +65,15 @@ import org.springframework.web.servlet.View;
|
||||||
* a symbolic view name to different resources depending on the current locale.
|
* a symbolic view name to different resources depending on the current locale.
|
||||||
*
|
*
|
||||||
* <p><b>Note:</b> When chaining ViewResolvers, a UrlBasedViewResolver will check whether
|
* <p><b>Note:</b> When chaining ViewResolvers, a UrlBasedViewResolver will check whether
|
||||||
* the {@link AbstractUrlBasedView#checkResource specified resource actually exists}.
|
* the {@linkplain AbstractUrlBasedView#checkResource specified resource actually exists}.
|
||||||
* However, with {@link InternalResourceView}, it is not generally possible to
|
* However, with {@link InternalResourceView}, it is not generally possible to
|
||||||
* determine the existence of the target resource upfront. In such a scenario,
|
* determine the existence of the target resource upfront. In such a scenario,
|
||||||
* a UrlBasedViewResolver will always return View for any given view name;
|
* a UrlBasedViewResolver will always return a View for any given view name;
|
||||||
* as a consequence, it should be configured as the last ViewResolver in the chain.
|
* as a consequence, it should be configured as the last ViewResolver in the chain.
|
||||||
*
|
*
|
||||||
* @author Juergen Hoeller
|
* @author Juergen Hoeller
|
||||||
* @author Rob Harrop
|
* @author Rob Harrop
|
||||||
|
* @author Sam Brannen
|
||||||
* @since 13.12.2003
|
* @since 13.12.2003
|
||||||
* @see #setViewClass
|
* @see #setViewClass
|
||||||
* @see #setPrefix
|
* @see #setPrefix
|
||||||
|
@ -550,14 +551,17 @@ public class UrlBasedViewResolver extends AbstractCachingViewResolver implements
|
||||||
|
|
||||||
AbstractUrlBasedView view = (AbstractUrlBasedView) BeanUtils.instantiateClass(viewClass);
|
AbstractUrlBasedView view = (AbstractUrlBasedView) BeanUtils.instantiateClass(viewClass);
|
||||||
view.setUrl(getPrefix() + viewName + getSuffix());
|
view.setUrl(getPrefix() + viewName + getSuffix());
|
||||||
|
view.setAttributesMap(getAttributesMap());
|
||||||
|
|
||||||
String contentType = getContentType();
|
String contentType = getContentType();
|
||||||
if (contentType != null) {
|
if (contentType != null) {
|
||||||
view.setContentType(contentType);
|
view.setContentType(contentType);
|
||||||
}
|
}
|
||||||
|
|
||||||
view.setRequestContextAttribute(getRequestContextAttribute());
|
String requestContextAttribute = getRequestContextAttribute();
|
||||||
view.setAttributesMap(getAttributesMap());
|
if (requestContextAttribute != null) {
|
||||||
|
view.setRequestContextAttribute(requestContextAttribute);
|
||||||
|
}
|
||||||
|
|
||||||
Boolean exposePathVariables = getExposePathVariables();
|
Boolean exposePathVariables = getExposePathVariables();
|
||||||
if (exposePathVariables != null) {
|
if (exposePathVariables != null) {
|
||||||
|
|
|
@ -22,8 +22,6 @@ import java.util.Map;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
import javax.servlet.RequestDispatcher;
|
import javax.servlet.RequestDispatcher;
|
||||||
import javax.servlet.ServletContext;
|
|
||||||
import javax.servlet.ServletException;
|
|
||||||
import javax.servlet.ServletRequest;
|
import javax.servlet.ServletRequest;
|
||||||
import javax.servlet.ServletResponse;
|
import javax.servlet.ServletResponse;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
@ -31,6 +29,7 @@ import javax.servlet.http.HttpServletResponse;
|
||||||
import javax.servlet.jsp.jstl.core.Config;
|
import javax.servlet.jsp.jstl.core.Config;
|
||||||
import javax.servlet.jsp.jstl.fmt.LocalizationContext;
|
import javax.servlet.jsp.jstl.fmt.LocalizationContext;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import org.springframework.beans.MutablePropertyValues;
|
import org.springframework.beans.MutablePropertyValues;
|
||||||
|
@ -56,94 +55,140 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
|
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Unit tests for {@link BeanNameViewResolver}, {@link UrlBasedViewResolver},
|
||||||
|
* {@link InternalResourceViewResolver}, {@link XmlViewResolver}, and
|
||||||
|
* {@link AbstractCachingViewResolver}.
|
||||||
|
*
|
||||||
* @author Juergen Hoeller
|
* @author Juergen Hoeller
|
||||||
* @author Chris Beams
|
* @author Chris Beams
|
||||||
|
* @author Sam Brannen
|
||||||
* @since 18.06.2003
|
* @since 18.06.2003
|
||||||
*/
|
*/
|
||||||
public class ViewResolverTests {
|
public class ViewResolverTests {
|
||||||
|
|
||||||
|
private final StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
||||||
|
private final MockServletContext sc = new MockServletContext();
|
||||||
|
private final MockHttpServletRequest request = new MockHttpServletRequest(this.sc);
|
||||||
|
private final HttpServletResponse response = new MockHttpServletResponse();
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
this.wac.setServletContext(this.sc);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBeanNameViewResolver() throws ServletException {
|
public void beanNameViewResolver() {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
|
||||||
wac.setServletContext(new MockServletContext());
|
|
||||||
MutablePropertyValues pvs1 = new MutablePropertyValues();
|
MutablePropertyValues pvs1 = new MutablePropertyValues();
|
||||||
pvs1.addPropertyValue(new PropertyValue("url", "/example1.jsp"));
|
pvs1.addPropertyValue(new PropertyValue("url", "/example1.jsp"));
|
||||||
wac.registerSingleton("example1", InternalResourceView.class, pvs1);
|
this.wac.registerSingleton("example1", InternalResourceView.class, pvs1);
|
||||||
MutablePropertyValues pvs2 = new MutablePropertyValues();
|
MutablePropertyValues pvs2 = new MutablePropertyValues();
|
||||||
pvs2.addPropertyValue(new PropertyValue("url", "/example2.jsp"));
|
pvs2.addPropertyValue(new PropertyValue("url", "/example2.jsp"));
|
||||||
wac.registerSingleton("example2", JstlView.class, pvs2);
|
this.wac.registerSingleton("example2", JstlView.class, pvs2);
|
||||||
BeanNameViewResolver vr = new BeanNameViewResolver();
|
BeanNameViewResolver vr = new BeanNameViewResolver();
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
wac.refresh();
|
this.wac.refresh();
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(InternalResourceView.class);
|
assertThat(view.getClass()).as("Correct view class").isEqualTo(InternalResourceView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/example1.jsp");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/example1.jsp");
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("/example2.jsp");
|
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("/example2.jsp");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUrlBasedViewResolverWithoutPrefixes() throws Exception {
|
public void urlBasedViewResolverOverridesCustomRequestContextAttributeWithNonNullValue() throws Exception {
|
||||||
|
assertThat(new TestView().getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated directly")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
|
||||||
|
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
||||||
|
vr.setViewClass(TestView.class);
|
||||||
|
vr.setApplicationContext(this.wac);
|
||||||
|
vr.setRequestContextAttribute("viewResolverRequestContext");
|
||||||
|
this.wac.refresh();
|
||||||
|
|
||||||
|
View view = vr.resolveViewName("example", Locale.getDefault());
|
||||||
|
assertThat(view).isInstanceOf(TestView.class);
|
||||||
|
assertThat(((TestView) view).getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated dynamically by UrlBasedViewResolver")
|
||||||
|
.isEqualTo("viewResolverRequestContext");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void urlBasedViewResolverDoesNotOverrideCustomRequestContextAttributeWithNull() throws Exception {
|
||||||
|
assertThat(new TestView().getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated directly")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
|
||||||
|
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
||||||
|
vr.setViewClass(TestView.class);
|
||||||
|
vr.setApplicationContext(this.wac);
|
||||||
|
this.wac.refresh();
|
||||||
|
|
||||||
|
View view = vr.resolveViewName("example", Locale.getDefault());
|
||||||
|
assertThat(view).isInstanceOf(TestView.class);
|
||||||
|
assertThat(((TestView) view).getRequestContextAttribute())
|
||||||
|
.as("requestContextAttribute when instantiated dynamically by UrlBasedViewResolver")
|
||||||
|
.isEqualTo("testRequestContext");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void urlBasedViewResolverWithoutPrefixes() throws Exception {
|
||||||
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
||||||
vr.setViewClass(JstlView.class);
|
vr.setViewClass(JstlView.class);
|
||||||
doTestUrlBasedViewResolverWithoutPrefixes(vr);
|
doTestUrlBasedViewResolverWithoutPrefixes(vr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUrlBasedViewResolverWithPrefixes() throws Exception {
|
public void urlBasedViewResolverWithPrefixes() throws Exception {
|
||||||
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
UrlBasedViewResolver vr = new UrlBasedViewResolver();
|
||||||
vr.setViewClass(JstlView.class);
|
vr.setViewClass(JstlView.class);
|
||||||
doTestUrlBasedViewResolverWithPrefixes(vr);
|
doTestUrlBasedViewResolverWithPrefixes(vr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithoutPrefixes() throws Exception {
|
public void internalResourceViewResolverWithoutPrefixes() throws Exception {
|
||||||
doTestUrlBasedViewResolverWithoutPrefixes(new InternalResourceViewResolver());
|
doTestUrlBasedViewResolverWithoutPrefixes(new InternalResourceViewResolver());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithPrefixes() throws Exception {
|
public void internalResourceViewResolverWithPrefixes() throws Exception {
|
||||||
doTestUrlBasedViewResolverWithPrefixes(new InternalResourceViewResolver());
|
doTestUrlBasedViewResolverWithPrefixes(new InternalResourceViewResolver());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doTestUrlBasedViewResolverWithoutPrefixes(UrlBasedViewResolver vr) throws Exception {
|
private void doTestUrlBasedViewResolverWithoutPrefixes(UrlBasedViewResolver vr) throws Exception {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.refresh();
|
||||||
wac.setServletContext(new MockServletContext());
|
vr.setApplicationContext(this.wac);
|
||||||
wac.refresh();
|
|
||||||
vr.setApplicationContext(wac);
|
|
||||||
vr.setContentType("myContentType");
|
vr.setContentType("myContentType");
|
||||||
vr.setRequestContextAttribute("rc");
|
vr.setRequestContextAttribute("rc");
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
||||||
assertThat(((InternalResourceView) view).getContentType()).as("Correct textContentType").isEqualTo("myContentType");
|
assertThat(((InternalResourceView) view).getContentType()).as("Correct textContentType").isEqualTo("myContentType");
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
||||||
assertThat(((InternalResourceView) view).getContentType()).as("Correct textContentType").isEqualTo("myContentType");
|
assertThat(((InternalResourceView) view).getContentType()).as("Correct textContentType").isEqualTo("myContentType");
|
||||||
|
|
||||||
HttpServletRequest request = new MockHttpServletRequest(wac.getServletContext());
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
this.request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
|
||||||
request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
|
||||||
Map<String, Object> model = new HashMap<>();
|
Map<String, Object> model = new HashMap<>();
|
||||||
TestBean tb = new TestBean();
|
TestBean tb = new TestBean();
|
||||||
model.put("tb", tb);
|
model.put("tb", tb);
|
||||||
view.render(model, request, response);
|
view.render(model, this.request, this.response);
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
boolean condition = request.getAttribute("rc") instanceof RequestContext;
|
boolean condition = this.request.getAttribute("rc") instanceof RequestContext;
|
||||||
assertThat(condition).as("Correct rc attribute").isTrue();
|
assertThat(condition).as("Correct rc attribute").isTrue();
|
||||||
|
|
||||||
view = vr.resolveViewName("redirect:myUrl", Locale.getDefault());
|
view = vr.resolveViewName("redirect:myUrl", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(RedirectView.class);
|
assertThat(view.getClass()).as("Correct view class").isEqualTo(RedirectView.class);
|
||||||
assertThat(((RedirectView) view).getUrl()).as("Correct URL").isEqualTo("myUrl");
|
assertThat(((RedirectView) view).getUrl()).as("Correct URL").isEqualTo("myUrl");
|
||||||
assertThat(((RedirectView) view).getApplicationContext()).as("View not initialized as bean").isSameAs(wac);
|
assertThat(((RedirectView) view).getApplicationContext()).as("View not initialized as bean").isSameAs(this.wac);
|
||||||
|
|
||||||
view = vr.resolveViewName("forward:myUrl", Locale.getDefault());
|
view = vr.resolveViewName("forward:myUrl", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(InternalResourceView.class);
|
assertThat(view.getClass()).as("Correct view class").isEqualTo(InternalResourceView.class);
|
||||||
|
@ -151,19 +196,17 @@ public class ViewResolverTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doTestUrlBasedViewResolverWithPrefixes(UrlBasedViewResolver vr) throws Exception {
|
private void doTestUrlBasedViewResolverWithPrefixes(UrlBasedViewResolver vr) throws Exception {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.refresh();
|
||||||
wac.setServletContext(new MockServletContext());
|
|
||||||
wac.refresh();
|
|
||||||
vr.setPrefix("/WEB-INF/");
|
vr.setPrefix("/WEB-INF/");
|
||||||
vr.setSuffix(".jsp");
|
vr.setSuffix(".jsp");
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/WEB-INF/example1.jsp");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/WEB-INF/example1.jsp");
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/WEB-INF/example2.jsp");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("/WEB-INF/example2.jsp");
|
||||||
|
|
||||||
view = vr.resolveViewName("redirect:myUrl", Locale.getDefault());
|
view = vr.resolveViewName("redirect:myUrl", Locale.getDefault());
|
||||||
|
@ -176,11 +219,8 @@ public class ViewResolverTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithAttributes() throws Exception {
|
public void internalResourceViewResolverWithAttributes() throws Exception {
|
||||||
MockServletContext sc = new MockServletContext();
|
this.wac.refresh();
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
|
||||||
wac.setServletContext(sc);
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
Properties props = new Properties();
|
Properties props = new Properties();
|
||||||
props.setProperty("key1", "value1");
|
props.setProperty("key1", "value1");
|
||||||
|
@ -188,45 +228,40 @@ public class ViewResolverTests {
|
||||||
Map<String, Object> map = new HashMap<>();
|
Map<String, Object> map = new HashMap<>();
|
||||||
map.put("key2", new Integer(2));
|
map.put("key2", new Integer(2));
|
||||||
vr.setAttributesMap(map);
|
vr.setAttributesMap(map);
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
||||||
Map<String, Object> attributes = ((InternalResourceView) view).getStaticAttributes();
|
Map<String, Object> attributes = ((InternalResourceView) view).getStaticAttributes();
|
||||||
assertThat(attributes.get("key1")).isEqualTo("value1");
|
assertThat(attributes.get("key1")).isEqualTo("value1");
|
||||||
assertThat(attributes.get("key2")).isEqualTo(new Integer(2));
|
assertThat(attributes.get("key2")).isEqualTo(new Integer(2));
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
assertThat(((InternalResourceView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
||||||
attributes = ((InternalResourceView) view).getStaticAttributes();
|
attributes = ((InternalResourceView) view).getStaticAttributes();
|
||||||
assertThat(attributes.get("key1")).isEqualTo("value1");
|
assertThat(attributes.get("key1")).isEqualTo("value1");
|
||||||
assertThat(attributes.get("key2")).isEqualTo(new Integer(2));
|
assertThat(attributes.get("key2")).isEqualTo(new Integer(2));
|
||||||
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest(sc);
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
|
||||||
Map<String, Object> model = new HashMap<>();
|
Map<String, Object> model = new HashMap<>();
|
||||||
TestBean tb = new TestBean();
|
TestBean tb = new TestBean();
|
||||||
model.put("tb", tb);
|
model.put("tb", tb);
|
||||||
view.render(model, request, response);
|
view.render(model, this.request, this.response);
|
||||||
|
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
assertThat(request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
assertThat(this.request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
||||||
assertThat(request.getAttribute("key1")).isEqualTo("value1");
|
assertThat(this.request.getAttribute("key1")).isEqualTo("value1");
|
||||||
assertThat(request.getAttribute("key2")).isEqualTo(new Integer(2));
|
assertThat(this.request.getAttribute("key2")).isEqualTo(new Integer(2));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithContextBeans() throws Exception {
|
public void internalResourceViewResolverWithContextBeans() throws Exception {
|
||||||
MockServletContext sc = new MockServletContext();
|
this.wac.registerSingleton("myBean", TestBean.class);
|
||||||
final StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.registerSingleton("myBean2", TestBean.class);
|
||||||
wac.registerSingleton("myBean", TestBean.class);
|
this.wac.refresh();
|
||||||
wac.registerSingleton("myBean2", TestBean.class);
|
|
||||||
wac.setServletContext(sc);
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
Properties props = new Properties();
|
Properties props = new Properties();
|
||||||
props.setProperty("key1", "value1");
|
props.setProperty("key1", "value1");
|
||||||
|
@ -235,9 +270,9 @@ public class ViewResolverTests {
|
||||||
map.put("key2", new Integer(2));
|
map.put("key2", new Integer(2));
|
||||||
vr.setAttributesMap(map);
|
vr.setAttributesMap(map);
|
||||||
vr.setExposeContextBeansAsAttributes(true);
|
vr.setExposeContextBeansAsAttributes(true);
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest(sc) {
|
HttpServletRequest request = new MockHttpServletRequest(this.sc) {
|
||||||
@Override
|
@Override
|
||||||
public RequestDispatcher getRequestDispatcher(String path) {
|
public RequestDispatcher getRequestDispatcher(String path) {
|
||||||
return new MockRequestDispatcher(path) {
|
return new MockRequestDispatcher(path) {
|
||||||
|
@ -252,21 +287,17 @@ public class ViewResolverTests {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
view.render(new HashMap<String, Object>(), request, response);
|
view.render(new HashMap<String, Object>(), request, this.response);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithSpecificContextBeans() throws Exception {
|
public void internalResourceViewResolverWithSpecificContextBeans() throws Exception {
|
||||||
MockServletContext sc = new MockServletContext();
|
this.wac.registerSingleton("myBean", TestBean.class);
|
||||||
final StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.registerSingleton("myBean2", TestBean.class);
|
||||||
wac.registerSingleton("myBean", TestBean.class);
|
this.wac.refresh();
|
||||||
wac.registerSingleton("myBean2", TestBean.class);
|
|
||||||
wac.setServletContext(sc);
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
Properties props = new Properties();
|
Properties props = new Properties();
|
||||||
props.setProperty("key1", "value1");
|
props.setProperty("key1", "value1");
|
||||||
|
@ -275,9 +306,9 @@ public class ViewResolverTests {
|
||||||
map.put("key2", new Integer(2));
|
map.put("key2", new Integer(2));
|
||||||
vr.setAttributesMap(map);
|
vr.setAttributesMap(map);
|
||||||
vr.setExposedContextBeanNames(new String[] {"myBean2"});
|
vr.setExposedContextBeanNames(new String[] {"myBean2"});
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest(sc) {
|
HttpServletRequest request = new MockHttpServletRequest(this.sc) {
|
||||||
@Override
|
@Override
|
||||||
public RequestDispatcher getRequestDispatcher(String path) {
|
public RequestDispatcher getRequestDispatcher(String path) {
|
||||||
return new MockRequestDispatcher(path) {
|
return new MockRequestDispatcher(path) {
|
||||||
|
@ -292,101 +323,88 @@ public class ViewResolverTests {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
view.render(new HashMap<String, Object>(), request, response);
|
view.render(new HashMap<String, Object>(), request, this.response);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithJstl() throws Exception {
|
public void internalResourceViewResolverWithJstl() throws Exception {
|
||||||
Locale locale = !Locale.GERMAN.equals(Locale.getDefault()) ? Locale.GERMAN : Locale.FRENCH;
|
Locale locale = !Locale.GERMAN.equals(Locale.getDefault()) ? Locale.GERMAN : Locale.FRENCH;
|
||||||
|
|
||||||
MockServletContext sc = new MockServletContext();
|
this.wac.addMessage("code1", locale, "messageX");
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.refresh();
|
||||||
wac.setServletContext(sc);
|
|
||||||
wac.addMessage("code1", locale, "messageX");
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
vr.setViewClass(JstlView.class);
|
vr.setViewClass(JstlView.class);
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
||||||
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest(sc);
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new FixedLocaleResolver(locale));
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new FixedLocaleResolver(locale));
|
|
||||||
Map<String, Object> model = new HashMap<>();
|
Map<String, Object> model = new HashMap<>();
|
||||||
TestBean tb = new TestBean();
|
TestBean tb = new TestBean();
|
||||||
model.put("tb", tb);
|
model.put("tb", tb);
|
||||||
view.render(model, request, response);
|
view.render(model, this.request, this.response);
|
||||||
|
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
assertThat(request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
assertThat(this.request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
||||||
|
|
||||||
assertThat(Config.get(request, Config.FMT_LOCALE)).isEqualTo(locale);
|
assertThat(Config.get(this.request, Config.FMT_LOCALE)).isEqualTo(locale);
|
||||||
LocalizationContext lc = (LocalizationContext) Config.get(request, Config.FMT_LOCALIZATION_CONTEXT);
|
LocalizationContext lc = (LocalizationContext) Config.get(this.request, Config.FMT_LOCALIZATION_CONTEXT);
|
||||||
assertThat(lc.getResourceBundle().getString("code1")).isEqualTo("messageX");
|
assertThat(lc.getResourceBundle().getString("code1")).isEqualTo("messageX");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInternalResourceViewResolverWithJstlAndContextParam() throws Exception {
|
public void internalResourceViewResolverWithJstlAndContextParam() throws Exception {
|
||||||
Locale locale = !Locale.GERMAN.equals(Locale.getDefault()) ? Locale.GERMAN : Locale.FRENCH;
|
Locale locale = !Locale.GERMAN.equals(Locale.getDefault()) ? Locale.GERMAN : Locale.FRENCH;
|
||||||
|
|
||||||
MockServletContext sc = new MockServletContext();
|
this.sc.addInitParameter(Config.FMT_LOCALIZATION_CONTEXT, "org/springframework/web/context/WEB-INF/context-messages");
|
||||||
sc.addInitParameter(Config.FMT_LOCALIZATION_CONTEXT, "org/springframework/web/context/WEB-INF/context-messages");
|
this.wac.addMessage("code1", locale, "messageX");
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.refresh();
|
||||||
wac.setServletContext(sc);
|
|
||||||
wac.addMessage("code1", locale, "messageX");
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
vr.setViewClass(JstlView.class);
|
vr.setViewClass(JstlView.class);
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example1");
|
||||||
|
|
||||||
view = vr.resolveViewName("example2", Locale.getDefault());
|
view = vr.resolveViewName("example2", Locale.getDefault());
|
||||||
assertThat(view.getClass()).as("Correct view class").isEqualTo(JstlView.class);
|
assertThat(view).isInstanceOf(JstlView.class);
|
||||||
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
assertThat(((JstlView) view).getUrl()).as("Correct URL").isEqualTo("example2");
|
||||||
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest(sc);
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new FixedLocaleResolver(locale));
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new FixedLocaleResolver(locale));
|
|
||||||
Map<String, Object> model = new HashMap<>();
|
Map<String, Object> model = new HashMap<>();
|
||||||
TestBean tb = new TestBean();
|
TestBean tb = new TestBean();
|
||||||
model.put("tb", tb);
|
model.put("tb", tb);
|
||||||
view.render(model, request, response);
|
view.render(model, this.request, this.response);
|
||||||
|
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
assertThat(request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
assertThat(this.request.getAttribute("rc") == null).as("Correct rc attribute").isTrue();
|
||||||
|
|
||||||
assertThat(Config.get(request, Config.FMT_LOCALE)).isEqualTo(locale);
|
assertThat(Config.get(this.request, Config.FMT_LOCALE)).isEqualTo(locale);
|
||||||
LocalizationContext lc = (LocalizationContext) Config.get(request, Config.FMT_LOCALIZATION_CONTEXT);
|
LocalizationContext lc = (LocalizationContext) Config.get(this.request, Config.FMT_LOCALIZATION_CONTEXT);
|
||||||
assertThat(lc.getResourceBundle().getString("code1")).isEqualTo("message1");
|
assertThat(lc.getResourceBundle().getString("code1")).isEqualTo("message1");
|
||||||
assertThat(lc.getResourceBundle().getString("code2")).isEqualTo("message2");
|
assertThat(lc.getResourceBundle().getString("code2")).isEqualTo("message2");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testXmlViewResolver() throws Exception {
|
public void xmlViewResolver() throws Exception {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.registerSingleton("testBean", TestBean.class);
|
||||||
wac.registerSingleton("testBean", TestBean.class);
|
this.wac.refresh();
|
||||||
wac.setServletContext(new MockServletContext());
|
TestBean testBean = (TestBean) this.wac.getBean("testBean");
|
||||||
wac.refresh();
|
|
||||||
TestBean testBean = (TestBean) wac.getBean("testBean");
|
|
||||||
XmlViewResolver vr = new XmlViewResolver();
|
XmlViewResolver vr = new XmlViewResolver();
|
||||||
vr.setLocation(new ClassPathResource("org/springframework/web/servlet/view/views.xml"));
|
vr.setLocation(new ClassPathResource("org/springframework/web/servlet/view/views.xml"));
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view1 = vr.resolveViewName("example1", Locale.getDefault());
|
View view1 = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
assertThat(TestView.class.equals(view1.getClass())).as("Correct view class").isTrue();
|
assertThat(TestView.class.equals(view1.getClass())).as("Correct view class").isTrue();
|
||||||
|
@ -396,34 +414,30 @@ public class ViewResolverTests {
|
||||||
assertThat(JstlView.class.equals(view2.getClass())).as("Correct view class").isTrue();
|
assertThat(JstlView.class.equals(view2.getClass())).as("Correct view class").isTrue();
|
||||||
assertThat("/example2new.jsp".equals(((InternalResourceView) view2).getUrl())).as("Correct URL").isTrue();
|
assertThat("/example2new.jsp".equals(((InternalResourceView) view2).getUrl())).as("Correct URL").isTrue();
|
||||||
|
|
||||||
ServletContext sc = new MockServletContext();
|
|
||||||
Map<String, Object> model = new HashMap<>();
|
Map<String, Object> model = new HashMap<>();
|
||||||
TestBean tb = new TestBean();
|
TestBean tb = new TestBean();
|
||||||
model.put("tb", tb);
|
model.put("tb", tb);
|
||||||
|
|
||||||
HttpServletRequest request = new MockHttpServletRequest(sc);
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
HttpServletResponse response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
this.request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
view1.render(model, this.request, this.response);
|
||||||
request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
view1.render(model, request, response);
|
assertThat("testvalue1".equals(this.request.getAttribute("test1"))).as("Correct test1 attribute").isTrue();
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat(testBean.equals(this.request.getAttribute("test2"))).as("Correct test2 attribute").isTrue();
|
||||||
assertThat("testvalue1".equals(request.getAttribute("test1"))).as("Correct test1 attribute").isTrue();
|
|
||||||
assertThat(testBean.equals(request.getAttribute("test2"))).as("Correct test2 attribute").isTrue();
|
|
||||||
|
|
||||||
request = new MockHttpServletRequest(sc);
|
this.request.clearAttributes();
|
||||||
response = new MockHttpServletResponse();
|
this.request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, this.wac);
|
||||||
request.setAttribute(DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE, wac);
|
this.request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
||||||
request.setAttribute(DispatcherServlet.LOCALE_RESOLVER_ATTRIBUTE, new AcceptHeaderLocaleResolver());
|
this.request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
||||||
request.setAttribute(DispatcherServlet.THEME_RESOLVER_ATTRIBUTE, new FixedThemeResolver());
|
view2.render(model, this.request, this.response);
|
||||||
view2.render(model, request, response);
|
assertThat(tb.equals(this.request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
||||||
assertThat(tb.equals(request.getAttribute("tb"))).as("Correct tb attribute").isTrue();
|
assertThat("testvalue1".equals(this.request.getAttribute("test1"))).as("Correct test1 attribute").isTrue();
|
||||||
assertThat("testvalue1".equals(request.getAttribute("test1"))).as("Correct test1 attribute").isTrue();
|
assertThat("testvalue2".equals(this.request.getAttribute("test2"))).as("Correct test2 attribute").isTrue();
|
||||||
assertThat("testvalue2".equals(request.getAttribute("test2"))).as("Correct test2 attribute").isTrue();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testXmlViewResolverDefaultLocation() {
|
public void xmlViewResolverDefaultLocation() {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext() {
|
StaticWebApplicationContext wac = new StaticWebApplicationContext() {
|
||||||
@Override
|
@Override
|
||||||
protected Resource getResourceByPath(String path) {
|
protected Resource getResourceByPath(String path) {
|
||||||
|
@ -431,16 +445,15 @@ public class ViewResolverTests {
|
||||||
return super.getResourceByPath(path);
|
return super.getResourceByPath(path);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
wac.setServletContext(new MockServletContext());
|
wac.setServletContext(this.sc);
|
||||||
wac.refresh();
|
wac.refresh();
|
||||||
XmlViewResolver vr = new XmlViewResolver();
|
XmlViewResolver vr = new XmlViewResolver();
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(wac);
|
||||||
assertThatExceptionOfType(BeanDefinitionStoreException.class).isThrownBy(
|
assertThatExceptionOfType(BeanDefinitionStoreException.class).isThrownBy(vr::afterPropertiesSet);
|
||||||
vr::afterPropertiesSet);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testXmlViewResolverWithoutCache() throws Exception {
|
public void xmlViewResolverWithoutCache() throws Exception {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext() {
|
StaticWebApplicationContext wac = new StaticWebApplicationContext() {
|
||||||
@Override
|
@Override
|
||||||
protected Resource getResourceByPath(String path) {
|
protected Resource getResourceByPath(String path) {
|
||||||
|
@ -448,7 +461,7 @@ public class ViewResolverTests {
|
||||||
return super.getResourceByPath(path);
|
return super.getResourceByPath(path);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
wac.setServletContext(new MockServletContext());
|
wac.setServletContext(this.sc);
|
||||||
wac.refresh();
|
wac.refresh();
|
||||||
XmlViewResolver vr = new XmlViewResolver();
|
XmlViewResolver vr = new XmlViewResolver();
|
||||||
vr.setCache(false);
|
vr.setCache(false);
|
||||||
|
@ -458,13 +471,11 @@ public class ViewResolverTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCacheRemoval() throws Exception {
|
public void cacheRemoval() throws Exception {
|
||||||
StaticWebApplicationContext wac = new StaticWebApplicationContext();
|
this.wac.refresh();
|
||||||
wac.setServletContext(new MockServletContext());
|
|
||||||
wac.refresh();
|
|
||||||
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
InternalResourceViewResolver vr = new InternalResourceViewResolver();
|
||||||
vr.setViewClass(JstlView.class);
|
vr.setViewClass(JstlView.class);
|
||||||
vr.setApplicationContext(wac);
|
vr.setApplicationContext(this.wac);
|
||||||
|
|
||||||
View view = vr.resolveViewName("example1", Locale.getDefault());
|
View view = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
View cached = vr.resolveViewName("example1", Locale.getDefault());
|
View cached = vr.resolveViewName("example1", Locale.getDefault());
|
||||||
|
@ -477,11 +488,11 @@ public class ViewResolverTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCacheUnresolved() throws Exception {
|
public void cacheUnresolved() throws Exception {
|
||||||
final AtomicInteger count = new AtomicInteger();
|
final AtomicInteger count = new AtomicInteger();
|
||||||
AbstractCachingViewResolver viewResolver = new AbstractCachingViewResolver() {
|
AbstractCachingViewResolver viewResolver = new AbstractCachingViewResolver() {
|
||||||
@Override
|
@Override
|
||||||
protected View loadView(String viewName, Locale locale) throws Exception {
|
protected View loadView(String viewName, Locale locale) {
|
||||||
count.incrementAndGet();
|
count.incrementAndGet();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -508,9 +519,13 @@ public class ViewResolverTests {
|
||||||
|
|
||||||
public static class TestView extends InternalResourceView {
|
public static class TestView extends InternalResourceView {
|
||||||
|
|
||||||
|
public TestView() {
|
||||||
|
setRequestContextAttribute("testRequestContext");
|
||||||
|
}
|
||||||
|
|
||||||
public void setLocation(Resource location) {
|
public void setLocation(Resource location) {
|
||||||
if (!(location instanceof ServletContextResource)) {
|
if (!(location instanceof ServletContextResource)) {
|
||||||
throw new IllegalArgumentException("Expecting ClassPathResource, not " + location.getClass().getName());
|
throw new IllegalArgumentException("Expecting ServletContextResource, not " + location.getClass().getName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue