diff options
Diffstat (limited to 'uitest')
-rw-r--r-- | uitest/src/com/vaadin/tests/application/CommErrorEmulatorServlet.java | 143 | ||||
-rw-r--r-- | uitest/src/com/vaadin/tests/application/CommErrorEmulatorUI.java | 7 |
2 files changed, 98 insertions, 52 deletions
diff --git a/uitest/src/com/vaadin/tests/application/CommErrorEmulatorServlet.java b/uitest/src/com/vaadin/tests/application/CommErrorEmulatorServlet.java index 06df6f9b55..116ef1c1f2 100644 --- a/uitest/src/com/vaadin/tests/application/CommErrorEmulatorServlet.java +++ b/uitest/src/com/vaadin/tests/application/CommErrorEmulatorServlet.java @@ -16,32 +16,101 @@ package com.vaadin.tests.application; import java.io.IOException; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; - -import com.vaadin.server.ServletPortletHelper; +import com.vaadin.server.DeploymentConfiguration; +import com.vaadin.server.RequestHandler; +import com.vaadin.server.ServiceException; +import com.vaadin.server.VaadinRequest; +import com.vaadin.server.VaadinResponse; import com.vaadin.server.VaadinServlet; -import com.vaadin.server.VaadinServletRequest; +import com.vaadin.server.VaadinServletService; +import com.vaadin.server.VaadinSession; +import com.vaadin.server.communication.HeartbeatHandler; +import com.vaadin.server.communication.UidlRequestHandler; +import com.vaadin.ui.UI; -/** - * - * @since - * @author Vaadin Ltd - */ public class CommErrorEmulatorServlet extends VaadinServlet { - private volatile Integer uidlResponseCode; - private volatile Integer heartbeatResponseCode; + private Map<UI, Integer> uidlResponseCode = Collections + .synchronizedMap(new HashMap<UI, Integer>()); + private Map<UI, Integer> heartbeatResponseCode = Collections + .synchronizedMap(new HashMap<UI, Integer>()); - public void setUIDLResponseCode(int responseCode, final int delay) { - uidlResponseCode = responseCode; - System.out.println("Responding with " + uidlResponseCode - + " to UIDL requests for " + delay + "s"); + private final CommErrorUIDLRequestHandler uidlHandler = new CommErrorUIDLRequestHandler(); + private final CommErrorHeartbeatHandler heartbeatHandler = new CommErrorHeartbeatHandler(); - new Thread(new Runnable() { + public class CommErrorUIDLRequestHandler extends UidlRequestHandler { + @Override + public boolean synchronizedHandleRequest(VaadinSession session, + VaadinRequest request, VaadinResponse response) + throws IOException { + UI ui = session.getService().findUI(request); + if (ui != null && uidlResponseCode.containsKey(ui)) { + response.sendError(uidlResponseCode.get(ui), "Error set in UI"); + return true; + } + + return super.synchronizedHandleRequest(session, request, response); + } + } + + public class CommErrorHeartbeatHandler extends HeartbeatHandler { + @Override + public boolean synchronizedHandleRequest(VaadinSession session, + VaadinRequest request, VaadinResponse response) + throws IOException { + UI ui = session.getService().findUI(request); + if (ui != null && heartbeatResponseCode.containsKey(ui)) { + response.sendError(heartbeatResponseCode.get(ui), + "Error set in UI"); + return true; + } + + return super.synchronizedHandleRequest(session, request, response); + } + + } + + public class CommErrorEmulatorService extends VaadinServletService { + + public CommErrorEmulatorService(VaadinServlet servlet, + DeploymentConfiguration deploymentConfiguration) + throws ServiceException { + super(servlet, deploymentConfiguration); + } + @Override + protected List<RequestHandler> createRequestHandlers() + throws ServiceException { + List<RequestHandler> handlers = super.createRequestHandlers(); + handlers.add(uidlHandler); + handlers.add(heartbeatHandler); + return handlers; + } + } + + @Override + protected VaadinServletService createServletService( + DeploymentConfiguration deploymentConfiguration) + throws ServiceException { + CommErrorEmulatorService s = new CommErrorEmulatorService(this, + deploymentConfiguration); + s.init(); + return s; + } + + public void setUIDLResponseCode(final UI ui, int responseCode, + final int delay) { + uidlResponseCode.put(ui, responseCode); + System.out.println("Responding with " + responseCode + + " to UIDL requests for " + ui + " for the next " + delay + + "s"); + + new Thread(new Runnable() { @Override public void run() { try { @@ -51,16 +120,18 @@ public class CommErrorEmulatorServlet extends VaadinServlet { } System.out.println("Handing UIDL requests normally again"); - uidlResponseCode = null; + uidlResponseCode.remove(ui); } }).start(); } - public void setHeartbeatResponseCode(int responseCode, final int delay) { - heartbeatResponseCode = responseCode; + public void setHeartbeatResponseCode(final UI ui, int responseCode, + final int delay) { + heartbeatResponseCode.put(ui, responseCode); System.out.println("Responding with " + responseCode - + " to heartbeat requests for " + delay + "s"); + + " to heartbeat requests for " + ui + " for the next " + delay + + "s"); new Thread(new Runnable() { @@ -72,35 +143,9 @@ public class CommErrorEmulatorServlet extends VaadinServlet { e.printStackTrace(); } System.out.println("Handing heartbeat requests normally again"); - heartbeatResponseCode = null; + heartbeatResponseCode.remove(ui); } }).start(); } - /* - * (non-Javadoc) - * - * @see - * com.vaadin.server.VaadinServlet#service(javax.servlet.http.HttpServletRequest - * , javax.servlet.http.HttpServletResponse) - */ - @Override - protected void service(HttpServletRequest request, - HttpServletResponse response) throws ServletException, IOException { - VaadinServletRequest vaadinRequest = createVaadinRequest(request); - if (ServletPortletHelper.isUIDLRequest(vaadinRequest)) { - if (uidlResponseCode != null) { - response.sendError(uidlResponseCode, "Error set in UI"); - return; - } - } - if (ServletPortletHelper.isHeartbeatRequest(vaadinRequest)) { - if (heartbeatResponseCode != null) { - response.sendError(heartbeatResponseCode, "Error set in UI"); - return; - } - } - super.service(request, response); - } - } diff --git a/uitest/src/com/vaadin/tests/application/CommErrorEmulatorUI.java b/uitest/src/com/vaadin/tests/application/CommErrorEmulatorUI.java index 9649b346b6..6e879d2a9b 100644 --- a/uitest/src/com/vaadin/tests/application/CommErrorEmulatorUI.java +++ b/uitest/src/com/vaadin/tests/application/CommErrorEmulatorUI.java @@ -108,8 +108,8 @@ public class CommErrorEmulatorUI extends AbstractTestUIWithLog { @Override public void buttonClick(ClickEvent event) { if (uidlResponse.code != null && uidlResponse.code != 200) { - getServlet().setUIDLResponseCode(uidlResponse.code, - uidlResponse.time); + getServlet().setUIDLResponseCode(CommErrorEmulatorUI.this, + uidlResponse.code, uidlResponse.time); log("Responding with " + uidlResponse.code + " to UIDL requests for " + uidlResponse.time + "s"); @@ -117,7 +117,8 @@ public class CommErrorEmulatorUI extends AbstractTestUIWithLog { if (heartbeatResponse.code != null && heartbeatResponse.code != 200) { getServlet().setHeartbeatResponseCode( - heartbeatResponse.code, heartbeatResponse.time); + CommErrorEmulatorUI.this, heartbeatResponse.code, + heartbeatResponse.time); log("Responding with " + heartbeatResponse.code + " to heartbeat requests for " + heartbeatResponse.time + "s"); |