From ec28ad3a0541f3c60b12783075f3b5c39cb99f91 Mon Sep 17 00:00:00 2001 From: Turini and Harada Date: Thu, 18 Sep 2014 11:36:44 -0300 Subject: [PATCH 1/3] checking if result is used DefaultLogicResult --- .../vraptor/view/DefaultLogicResult.java | 22 ++++++++++++------- .../vraptor/view/DefaultLogicResultTest.java | 4 +++- 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java b/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java index 79d793cf5..9747e5967 100644 --- a/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java +++ b/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java @@ -34,6 +34,7 @@ import org.slf4j.LoggerFactory; import br.com.caelum.vraptor.Get; +import br.com.caelum.vraptor.Result; import br.com.caelum.vraptor.controller.ControllerMethod; import br.com.caelum.vraptor.controller.DefaultControllerMethod; import br.com.caelum.vraptor.controller.HttpMethod; @@ -68,17 +69,20 @@ public class DefaultLogicResult implements LogicResult { private final FlashScope flash; private final MethodInfo methodInfo; + private Result result; + /** * @deprecated CDI eyes only */ protected DefaultLogicResult() { - this(null, null, null, null, null, null, null, null, null); + this(null, null, null, null, null, null, null, null, null, null); } @Inject public DefaultLogicResult(Proxifier proxifier, Router router, MutableRequest request, HttpServletResponse response, - Container container, PathResolver resolver, TypeNameExtractor extractor, FlashScope flash, MethodInfo methodInfo) { + Container container, PathResolver resolver, TypeNameExtractor extractor, FlashScope flash, MethodInfo methodInfo, Result result) { this.proxifier = proxifier; + this.result = result; this.response = unproxifyIfPossible(response); this.request = unproxifyIfPossible(request); this.router = router; @@ -97,24 +101,26 @@ public DefaultLogicResult(Proxifier proxifier, Router router, MutableRequest req @Override public T forwardTo(final Class type) { return proxifier.proxify(type, new MethodInvocation() { + @Override public Object intercept(T proxy, Method method, Object[] args, SuperMethod superMethod) { try { logger.debug("Executing {}", method); ControllerMethod old = methodInfo.getControllerMethod(); methodInfo.setControllerMethod(DefaultControllerMethod.instanceFor(type, method)); - Object result = method.invoke(container.instanceFor(type), args); + Object methodResult = method.invoke(container.instanceFor(type), args); methodInfo.setControllerMethod(old); Type returnType = method.getGenericReturnType(); if (!(returnType == void.class)) { - request.setAttribute(extractor.nameFor(returnType), result); + request.setAttribute(extractor.nameFor(returnType), methodResult); } - if (!response.isCommitted()) { - String path = resolver.pathFor(DefaultControllerMethod.instanceFor(type, method)); - logger.debug("Forwarding to {}", path); - request.getRequestDispatcher(path).forward(request, response); + if (response.isCommitted() || result.used()) { + return null; } + String path = resolver.pathFor(DefaultControllerMethod.instanceFor(type, method)); + logger.debug("Forwarding to {}", path); + request.getRequestDispatcher(path).forward(request, response); return null; } catch (InvocationTargetException e) { propagateIfPossible(e.getCause()); diff --git a/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java b/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java index 231703d40..4ce2027e4 100644 --- a/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java +++ b/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java @@ -72,11 +72,13 @@ public class DefaultLogicResultTest { private @Mock TypeNameExtractor extractor; private @Mock RequestDispatcher dispatcher; private @Mock FlashScope flash; + private @Mock Result result; private Proxifier proxifier; private MethodInfo methodInfo; + public static class MyComponent { int calls = 0; @@ -114,7 +116,7 @@ public void setup() { proxifier = new JavassistProxifier(); methodInfo = new MethodInfo(new ParanamerNameProvider()); this.logicResult = new DefaultLogicResult(proxifier, router, request, response, container, - resolver, extractor, flash, methodInfo); + resolver, extractor, flash, methodInfo, result); } @Test From ae9ec35a3bbe2bb6edf0a7e8909da6733c2ec581 Mon Sep 17 00:00:00 2001 From: Rodrigo Turini Date: Mon, 22 Sep 2014 10:37:47 -0300 Subject: [PATCH 2/3] adding a debug log --- .../main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java | 1 + 1 file changed, 1 insertion(+) diff --git a/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java b/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java index 9747e5967..5a79c025d 100644 --- a/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java +++ b/vraptor-core/src/main/java/br/com/caelum/vraptor/view/DefaultLogicResult.java @@ -116,6 +116,7 @@ public Object intercept(T proxy, Method method, Object[] args, SuperMethod super request.setAttribute(extractor.nameFor(returnType), methodResult); } if (response.isCommitted() || result.used()) { + logger.debug("Response already commited, not forwarding."); return null; } String path = resolver.pathFor(DefaultControllerMethod.instanceFor(type, method)); From 9e65b7f24725b00019d5b06ea39e0f25e87a6109 Mon Sep 17 00:00:00 2001 From: Rodrigo Turini Date: Mon, 22 Sep 2014 10:38:06 -0300 Subject: [PATCH 3/3] simple test case --- .../com/caelum/vraptor/view/DefaultLogicResultTest.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java b/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java index 4ce2027e4..9efea7aaf 100644 --- a/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java +++ b/vraptor-core/src/test/java/br/com/caelum/vraptor/view/DefaultLogicResultTest.java @@ -169,6 +169,15 @@ public void shouldNotForwardToMethodsDefaultViewWhenResponseIsCommited() throws verify(dispatcher, never()).forward(request, response); } + @Test + public void shouldNotForwardToMethodsDefaultViewWhenResultIsUsed() throws Exception { + givenDispatcherWillBeReturnedWhenRequested(); + when(response.isCommitted()).thenReturn(false); + when(result.used()).thenReturn(true); + logicResult.forwardTo(MyComponent.class).base(); + verify(dispatcher, never()).forward(request, response); + } + @Test public void shouldPutParametersOnFlashScopeOnRedirect() throws Exception {