From b2803fd408c3709889645061fad42d3371024b93 Mon Sep 17 00:00:00 2001 From: mnaganov Date: Wed, 4 Mar 2015 05:42:03 -0800 Subject: [Android WebView] Synthesize a fake page loading event on page source modification (Re-land) When a script modifies page source of a non-committed page, we need to notify clients, so they can update the URL bar to avoid confusion. New logic since the last attempt (https://codereview.chromium.org/924833003/): distinguish between a "vanilla" WebView state (basically, a newly created WebView, where no loading attempts have been made) and an "attempted to navigate" state. In the "vanilla" state, don't fire synthesized page loading events to avoid confusing clients. This is safe, as WebView is guaranteed to be on a blank page. Implementation note: we detect navigation attempts using didStartProvisionalLoadForFrame WebContentsObserver event on the Java side. As for popups AwWebContentsObserver gets re-attached from the original popup WebView to the one provided by the client, notifications issued inbetween can be missed on the Java side. To work around this, we assume that WebViews opened as popups can never be in "vanilla" state (as they are anyway opened as a result of navigation). BUG=458569,462213 TBR=davidben@chromium.org,tedchoc@chromium.org Review URL: https://codereview.chromium.org/970883002 Cr-Commit-Position: refs/heads/master@{#319061} --- .../org/chromium/net/test/util/TestWebServer.java | 26 ++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) (limited to 'net') diff --git a/net/test/android/javatests/src/org/chromium/net/test/util/TestWebServer.java b/net/test/android/javatests/src/org/chromium/net/test/util/TestWebServer.java index dd40220..48c257e 100644 --- a/net/test/android/javatests/src/org/chromium/net/test/util/TestWebServer.java +++ b/net/test/android/javatests/src/org/chromium/net/test/util/TestWebServer.java @@ -80,11 +80,14 @@ public class TestWebServer { final boolean mIsRedirect; final Runnable mResponseAction; final boolean mIsNotFound; + final boolean mIsNoContent; Response(byte[] responseData, List> responseHeaders, - boolean isRedirect, boolean isNotFound, Runnable responseAction) { + boolean isRedirect, boolean isNotFound, boolean isNoContent, + Runnable responseAction) { mIsRedirect = isRedirect; mIsNotFound = isNotFound; + mIsNoContent = isNoContent; mResponseData = responseData; mResponseHeaders = responseHeaders == null ? new ArrayList>() : responseHeaders; @@ -208,6 +211,7 @@ public class TestWebServer { private static final int RESPONSE_STATUS_NORMAL = 0; private static final int RESPONSE_STATUS_MOVED_TEMPORARILY = 1; private static final int RESPONSE_STATUS_NOT_FOUND = 2; + private static final int RESPONSE_STATUS_NO_CONTENT = 3; private String setResponseInternal( String requestPath, byte[] responseData, @@ -215,10 +219,12 @@ public class TestWebServer { int status) { final boolean isRedirect = (status == RESPONSE_STATUS_MOVED_TEMPORARILY); final boolean isNotFound = (status == RESPONSE_STATUS_NOT_FOUND); + final boolean isNoContent = (status == RESPONSE_STATUS_NO_CONTENT); synchronized (mLock) { mResponseMap.put(requestPath, new Response( - responseData, responseHeaders, isRedirect, isNotFound, responseAction)); + responseData, responseHeaders, isRedirect, isNotFound, isNoContent, + responseAction)); mResponseCountMap.put(requestPath, Integer.valueOf(0)); mLastRequestMap.put(requestPath, null); } @@ -251,6 +257,18 @@ public class TestWebServer { } /** + * Sets a 204 (no content) response to be returned when a particular request path is passed in. + * + * @param requestPath The path to respond to. + * @return The full URL including the path that should be requested to get the expected + * response. + */ + public String setResponseWithNoContentStatus(String requestPath) { + return setResponseInternal( + requestPath, "".getBytes(), null, null, RESPONSE_STATUS_NO_CONTENT); + } + + /** * Sets a response to be returned when a particular request path is passed * in (with the option to specify additional headers). * @@ -451,6 +469,10 @@ public class TestWebServer { } else if (response.mIsNotFound) { httpResponse = createResponse(HttpStatus.SC_NOT_FOUND); servedResponseFor(path, request); + } else if (response.mIsNoContent) { + httpResponse = createResponse(HttpStatus.SC_NO_CONTENT); + httpResponse.setHeader("Content-Length", "0"); + servedResponseFor(path, request); } else if (response.mIsRedirect) { httpResponse = createResponse(HttpStatus.SC_MOVED_TEMPORARILY); for (Pair header : response.mResponseHeaders) { -- cgit v1.1