OLD | NEW |
---|---|
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 package org.chromium.android_webview.test; | 5 package org.chromium.android_webview.test; |
6 | 6 |
7 import android.test.suitebuilder.annotation.MediumTest; | 7 import android.test.suitebuilder.annotation.MediumTest; |
8 | 8 |
9 import org.chromium.android_webview.AwContents; | 9 import org.chromium.android_webview.AwContents; |
10 import org.chromium.android_webview.test.util.CommonResources; | 10 import org.chromium.android_webview.test.util.CommonResources; |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
65 1 /* numberOfCallsToWaitFor */, | 65 1 /* numberOfCallsToWaitFor */, |
66 WAIT_TIMEOUT_MS, | 66 WAIT_TIMEOUT_MS, |
67 TimeUnit.MILLISECONDS); | 67 TimeUnit.MILLISECONDS); |
68 onPageFinishedHelper.waitForCallback(onPageFinishedCallCount, | 68 onPageFinishedHelper.waitForCallback(onPageFinishedCallCount, |
69 1 /* numberOfCallsToWaitFor */, | 69 1 /* numberOfCallsToWaitFor */, |
70 WAIT_TIMEOUT_MS, | 70 WAIT_TIMEOUT_MS, |
71 TimeUnit.MILLISECONDS); | 71 TimeUnit.MILLISECONDS); |
72 assertEquals(1, onReceivedErrorHelper.getCallCount()); | 72 assertEquals(1, onReceivedErrorHelper.getCallCount()); |
73 } | 73 } |
74 | 74 |
75 /** | |
76 * If url1 is redirected url2, and url2 load is overridden, onPageFinished s hould still be | |
mkosiba (inactive)
2014/02/12 16:03:38
umm.. this isn't a "proper" JavaDoc, so please don
hush (inactive)
2014/02/12 18:40:40
Done.
| |
77 * called for url2. | |
78 * Steps: | |
79 * 1. load url1. url1 onPageStarted | |
80 * 2. server redirects url1 to url2. url2 onPageStarted | |
81 * 3. shouldOverridedUrlLoading called for url2 and returns true | |
82 * 4. url2 onPageFinishedCalled | |
83 */ | |
84 @MediumTest | |
85 @Feature({"AndroidWebView"}) | |
86 public void testOnPageFinishedCalledAfterRedirectedUrlIsOverridden() throws Throwable { | |
87 TestWebServer webServer = null; | |
88 try { | |
89 webServer = new TestWebServer(false); | |
90 final String redirectTargetPath = "/redirect_target.html"; | |
91 // If you visit redirectUrl, you will be redirected to redirectTarge tUrl | |
mkosiba (inactive)
2014/02/12 16:03:38
IMHO this is pretty obvious from the code and does
hush (inactive)
2014/02/12 18:40:40
Done.
| |
92 final String redirectTargetUrl = webServer.setResponse(redirectTarge tPath, | |
93 "<html><body>hello world</body></html>", null); | |
94 final String redirectUrl = webServer.setRedirect("/302.html", redire ctTargetUrl); | |
95 | |
96 mContentsClient = new TestAwContentsClient() { | |
97 @Override | |
98 public boolean shouldOverrideUrlLoading(String url) { | |
mkosiba (inactive)
2014/02/12 16:03:38
I'd prefer either:
a) moving the shouldOverrideUr
hush (inactive)
2014/02/12 18:40:40
Sure. Actually I would like to do some refactoring
| |
99 if (url.equals(redirectTargetUrl)) { | |
mkosiba (inactive)
2014/02/12 16:03:38
I don't think you need this check - we shouldn't c
hush (inactive)
2014/02/12 18:40:40
you are right, I don't need this check. I was just
| |
100 return true; | |
101 } | |
102 return false; | |
103 } | |
104 }; | |
105 final AwTestContainerView testContainerView = | |
106 createAwTestContainerViewOnMainSync(mContentsClient); | |
107 mAwContents = testContainerView.getAwContents(); | |
108 | |
109 TestCallbackHelperContainer.OnPageFinishedHelper onPageFinishedHelpe r = | |
110 mContentsClient.getOnPageFinishedHelper(); | |
111 | |
112 loadUrlSync(mAwContents, onPageFinishedHelper, redirectUrl); | |
113 | |
114 // onPageFinished needs to be called for redirectTargetUrl, but not for redirectUrl | |
115 assertEquals(1, onPageFinishedHelper.getCallCount()); | |
mkosiba (inactive)
2014/02/12 16:03:38
please don't use absolute for this. Grab the curre
hush (inactive)
2014/02/12 18:40:40
Done. I loadUrlAync then I waitforCallback to incr
| |
116 assertEquals(redirectTargetUrl, onPageFinishedHelper.getUrl()); | |
117 } finally { | |
118 if (webServer != null) webServer.shutdown(); | |
119 } | |
120 } | |
121 | |
122 /** | |
123 * Tests that onPageFinished is called after onReceivedError, if there is in deed an error | |
124 */ | |
125 @MediumTest | |
126 @Feature({"AndroidWebView"}) | |
127 public void testOnPageFinishedCalledAfterOnReceivedError() throws Throwable { | |
128 mContentsClient = new TestAwContentsClient() { | |
129 private boolean isOnReceivedErrorCalled = false; | |
130 private boolean isOnPageFinishedCalled = false; | |
131 | |
132 @Override | |
133 public void onReceivedError(int errorCode, String description, Strin g failingUrl) { | |
134 isOnReceivedErrorCalled = true; | |
135 // Make sure onReceivedError is not called before onPageFinished | |
mkosiba (inactive)
2014/02/12 16:03:38
is this really how Classic operated? sigh..
hush (inactive)
2014/02/12 18:40:40
sorry. I typed the wrong comments there. I meant "
hush (inactive)
2014/02/12 19:41:00
testOnPageFinishedCalledAfterError is not testing
| |
136 assertEquals(false, isOnPageFinishedCalled); | |
137 super.onReceivedError(errorCode, description, failingUrl); | |
138 } | |
139 | |
140 @Override | |
141 public void onPageFinished(String url) { | |
142 isOnPageFinishedCalled = true; | |
143 super.onPageFinished(url); | |
144 } | |
145 }; | |
146 | |
147 final AwTestContainerView testContainerView = | |
148 createAwTestContainerViewOnMainSync(mContentsClient); | |
149 mAwContents = testContainerView.getAwContents(); | |
150 | |
151 TestCallbackHelperContainer.OnPageFinishedHelper onPageFinishedHelper = | |
152 mContentsClient.getOnPageFinishedHelper(); | |
153 | |
154 TestCallbackHelperContainer.OnReceivedErrorHelper onReceivedErrorHelper = | |
155 mContentsClient.getOnReceivedErrorHelper(); | |
156 | |
157 final String invalidUrl = "foo://invalid.url.co"; | |
158 loadUrlSync(mAwContents, onPageFinishedHelper, invalidUrl); | |
159 | |
160 assertEquals(invalidUrl, onReceivedErrorHelper.getFailingUrl()); | |
mkosiba (inactive)
2014/02/12 16:03:38
a couple of lines above you're checking that onRec
hush (inactive)
2014/02/12 18:40:40
Sorry. I was actually trying to test onReceivedErr
| |
161 assertEquals(invalidUrl, onPageFinishedHelper.getUrl()); | |
162 } | |
163 | |
75 @MediumTest | 164 @MediumTest |
76 @Feature({"AndroidWebView"}) | 165 @Feature({"AndroidWebView"}) |
77 public void testOnPageFinishedNotCalledForValidSubresources() throws Throwab le { | 166 public void testOnPageFinishedNotCalledForValidSubresources() throws Throwab le { |
78 TestCallbackHelperContainer.OnPageFinishedHelper onPageFinishedHelper = | 167 TestCallbackHelperContainer.OnPageFinishedHelper onPageFinishedHelper = |
79 mContentsClient.getOnPageFinishedHelper(); | 168 mContentsClient.getOnPageFinishedHelper(); |
80 | 169 |
81 TestWebServer webServer = null; | 170 TestWebServer webServer = null; |
82 try { | 171 try { |
83 webServer = new TestWebServer(false); | 172 webServer = new TestWebServer(false); |
84 | 173 |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
206 executeJavaScriptAndWaitForResult(mAwContents, mContentsClient, | 295 executeJavaScriptAndWaitForResult(mAwContents, mContentsClient, |
207 "window.history.go(-1)"); | 296 "window.history.go(-1)"); |
208 | 297 |
209 onPageFinishedHelper.waitForCallback(onPageFinishedCallCount); | 298 onPageFinishedHelper.waitForCallback(onPageFinishedCallCount); |
210 assertEquals(onPageStartedCallCount, onPageStartedHelper.getCallCoun t()); | 299 assertEquals(onPageStartedCallCount, onPageStartedHelper.getCallCoun t()); |
211 } finally { | 300 } finally { |
212 if (webServer != null) webServer.shutdown(); | 301 if (webServer != null) webServer.shutdown(); |
213 } | 302 } |
214 } | 303 } |
215 } | 304 } |
OLD | NEW |