OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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.net; | 5 package org.chromium.net; |
6 | 6 |
7 import android.content.Context; | 7 import android.content.Context; |
8 import android.content.ContextWrapper; | |
9 import android.os.ConditionVariable; | 8 import android.os.ConditionVariable; |
10 import android.os.Handler; | 9 import android.os.Handler; |
11 import android.os.Looper; | 10 import android.os.Looper; |
12 import android.os.StrictMode; | 11 import android.os.StrictMode; |
13 import android.test.suitebuilder.annotation.SmallTest; | 12 import android.test.suitebuilder.annotation.SmallTest; |
14 | 13 |
15 import org.chromium.base.FileUtils; | 14 import org.chromium.base.FileUtils; |
16 import org.chromium.base.PathUtils; | 15 import org.chromium.base.PathUtils; |
17 import org.chromium.base.annotations.JNINamespace; | 16 import org.chromium.base.annotations.JNINamespace; |
18 import org.chromium.base.test.util.Feature; | 17 import org.chromium.base.test.util.Feature; |
19 import org.chromium.net.TestUrlRequestCallback.ResponseStep; | 18 import org.chromium.net.TestUrlRequestCallback.ResponseStep; |
| 19 import org.chromium.net.impl.CronetEngineBase; |
| 20 import org.chromium.net.impl.CronetEngineBuilderImpl; |
20 import org.chromium.net.impl.CronetLibraryLoader; | 21 import org.chromium.net.impl.CronetLibraryLoader; |
21 import org.chromium.net.impl.CronetUrlRequestContext; | 22 import org.chromium.net.impl.CronetUrlRequestContext; |
22 import org.chromium.net.test.EmbeddedTestServer; | 23 import org.chromium.net.test.EmbeddedTestServer; |
23 import org.json.JSONObject; | 24 import org.json.JSONObject; |
24 | 25 |
25 import java.io.BufferedReader; | 26 import java.io.BufferedReader; |
26 import java.io.File; | 27 import java.io.File; |
27 import java.io.FileReader; | 28 import java.io.FileReader; |
28 import java.net.URL; | 29 import java.net.URL; |
29 import java.util.Arrays; | 30 import java.util.Arrays; |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
83 mUrl = url; | 84 mUrl = url; |
84 mRunBlocker = runBlocker; | 85 mRunBlocker = runBlocker; |
85 } | 86 } |
86 | 87 |
87 @Override | 88 @Override |
88 public void run() { | 89 public void run() { |
89 mRunBlocker.block(); | 90 mRunBlocker.block(); |
90 CronetEngine cronetEngine = mTestFramework.initCronetEngine(); | 91 CronetEngine cronetEngine = mTestFramework.initCronetEngine(); |
91 mCallback = new TestUrlRequestCallback(); | 92 mCallback = new TestUrlRequestCallback(); |
92 UrlRequest.Builder urlRequestBuilder = | 93 UrlRequest.Builder urlRequestBuilder = |
93 new UrlRequest.Builder(mUrl, mCallback, mCallback.getExecuto
r(), cronetEngine); | 94 cronetEngine.newUrlRequestBuilder(mUrl, mCallback, mCallback
.getExecutor()); |
94 urlRequestBuilder.build().start(); | 95 urlRequestBuilder.build().start(); |
95 mCallback.blockForDone(); | 96 mCallback.blockForDone(); |
96 } | 97 } |
97 } | 98 } |
98 | 99 |
99 /** | 100 /** |
100 * Callback that shutdowns the request context when request has succeeded | 101 * Callback that shutdowns the request context when request has succeeded |
101 * or failed. | 102 * or failed. |
102 */ | 103 */ |
103 static class ShutdownTestUrlRequestCallback extends TestUrlRequestCallback { | 104 static class ShutdownTestUrlRequestCallback extends TestUrlRequestCallback { |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
167 return mNetworkQualityThread; | 168 return mNetworkQualityThread; |
168 } | 169 } |
169 } | 170 } |
170 | 171 |
171 @SmallTest | 172 @SmallTest |
172 @Feature({"Cronet"}) | 173 @Feature({"Cronet"}) |
173 @SuppressWarnings("deprecation") | 174 @SuppressWarnings("deprecation") |
174 public void testConfigUserAgent() throws Exception { | 175 public void testConfigUserAgent() throws Exception { |
175 String userAgentName = "User-Agent"; | 176 String userAgentName = "User-Agent"; |
176 String userAgentValue = "User-Agent-Value"; | 177 String userAgentValue = "User-Agent-Value"; |
177 CronetEngine.Builder cronetEngineBuilder = new CronetEngine.Builder(getC
ontext()); | 178 ExperimentalCronetEngine.Builder cronetEngineBuilder = |
| 179 new ExperimentalCronetEngine.Builder(getContext()); |
178 if (testingJavaImpl()) { | 180 if (testingJavaImpl()) { |
179 cronetEngineBuilder.enableLegacyMode(true); | 181 cronetEngineBuilder.enableLegacyMode(true); |
180 } | 182 } |
181 cronetEngineBuilder.setUserAgent(userAgentValue); | 183 cronetEngineBuilder.setUserAgent(userAgentValue); |
182 cronetEngineBuilder.setLibraryName("cronet_tests"); | 184 CronetTestUtil.setLibraryName(cronetEngineBuilder, "cronet_tests"); |
183 final CronetTestFramework testFramework = | 185 final CronetTestFramework testFramework = |
184 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(mUrl, cron
etEngineBuilder); | 186 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(mUrl, cron
etEngineBuilder); |
185 NativeTestServer.shutdownNativeTestServer(); // startNativeTestServer re
turns false if it's | 187 NativeTestServer.shutdownNativeTestServer(); // startNativeTestServer re
turns false if it's |
186 // already running | 188 // already running |
187 assertTrue(NativeTestServer.startNativeTestServer(getContext())); | 189 assertTrue(NativeTestServer.startNativeTestServer(getContext())); |
188 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 190 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
189 UrlRequest.Builder urlRequestBuilder = | 191 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
190 new UrlRequest.Builder(NativeTestServer.getEchoHeaderURL(userAge
ntName), callback, | 192 NativeTestServer.getEchoHeaderURL(userAgentName), callback, call
back.getExecutor()); |
191 callback.getExecutor(), testFramework.mCronetEngine); | |
192 urlRequestBuilder.build().start(); | 193 urlRequestBuilder.build().start(); |
193 callback.blockForDone(); | 194 callback.blockForDone(); |
194 assertEquals(userAgentValue, callback.mResponseAsString); | 195 assertEquals(userAgentValue, callback.mResponseAsString); |
195 } | 196 } |
196 | 197 |
197 @SmallTest | 198 @SmallTest |
198 @Feature({"Cronet"}) | 199 @Feature({"Cronet"}) |
199 @OnlyRunNativeCronet | 200 @OnlyRunNativeCronet |
200 public void testDataReductionProxyEnabled() throws Exception { | 201 public void testDataReductionProxyEnabled() throws Exception { |
201 final CronetTestFramework testFramework = startCronetTestFrameworkAndSki
pLibraryInit(); | 202 final CronetTestFramework testFramework = startCronetTestFrameworkAndSki
pLibraryInit(); |
202 | 203 |
203 // Ensure native code is loaded before trying to start test server. | 204 // Ensure native code is loaded before trying to start test server. |
204 new CronetEngine.Builder(getContext()).setLibraryName("cronet_tests").bu
ild().shutdown(); | 205 ExperimentalCronetEngine.Builder engineBuilder = |
| 206 new ExperimentalCronetEngine.Builder(getContext()); |
| 207 CronetTestUtil.setLibraryName(engineBuilder, "cronet_tests"); |
| 208 engineBuilder.build().shutdown(); |
205 | 209 |
206 assertTrue(NativeTestServer.startNativeTestServer(getContext())); | 210 assertTrue(NativeTestServer.startNativeTestServer(getContext())); |
207 if (!NativeTestServer.isDataReductionProxySupported()) { | 211 if (!NativeTestServer.isDataReductionProxySupported()) { |
208 return; | 212 return; |
209 } | 213 } |
210 String serverHostPort = NativeTestServer.getHostPort(); | 214 String serverHostPort = NativeTestServer.getHostPort(); |
211 | 215 |
212 // Enable the Data Reduction Proxy and configure it to use the test | 216 // Enable the Data Reduction Proxy and configure it to use the test |
213 // server as its primary proxy, and to check successfully that this | 217 // server as its primary proxy, and to check successfully that this |
214 // proxy is OK to use. | 218 // proxy is OK to use. |
215 CronetEngine.Builder cronetEngineBuilder = new CronetEngine.Builder(getC
ontext()); | 219 ExperimentalCronetEngine.Builder cronetEngineBuilder = |
| 220 new ExperimentalCronetEngine.Builder(getContext()); |
216 cronetEngineBuilder.enableDataReductionProxy("test-key"); | 221 cronetEngineBuilder.enableDataReductionProxy("test-key"); |
217 cronetEngineBuilder.setDataReductionProxyOptions(serverHostPort, "unused
.net:9999", | 222 cronetEngineBuilder.setDataReductionProxyOptions(serverHostPort, "unused
.net:9999", |
218 NativeTestServer.getFileURL("/secureproxychecksuccess.txt")); | 223 NativeTestServer.getFileURL("/secureproxychecksuccess.txt")); |
219 cronetEngineBuilder.setLibraryName("cronet_tests"); | 224 CronetTestUtil.setLibraryName(cronetEngineBuilder, "cronet_tests"); |
220 testFramework.mCronetEngine = cronetEngineBuilder.build(); | 225 testFramework.mCronetEngine = (CronetEngineBase) cronetEngineBuilder.bui
ld(); |
221 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 226 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
222 | 227 |
223 // Construct and start a request that can only be returned by the test | 228 // Construct and start a request that can only be returned by the test |
224 // server. This request will fail if the configuration logic for the | 229 // server. This request will fail if the configuration logic for the |
225 // Data Reduction Proxy is not used. | 230 // Data Reduction Proxy is not used. |
226 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 231 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
227 "http://DomainThatDoesnt.Resolve/datareductionproxysuccess.txt",
callback, | 232 "http://DomainThatDoesnt.Resolve/datareductionproxysuccess.txt",
callback, |
228 callback.getExecutor(), testFramework.mCronetEngine); | 233 callback.getExecutor()); |
229 urlRequestBuilder.build().start(); | 234 urlRequestBuilder.build().start(); |
230 callback.blockForDone(); | 235 callback.blockForDone(); |
231 | 236 |
232 // Verify that the request is successful and that the Data Reduction | 237 // Verify that the request is successful and that the Data Reduction |
233 // Proxy logic configured to use the test server as its proxy. | 238 // Proxy logic configured to use the test server as its proxy. |
234 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); | 239 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); |
235 assertEquals(serverHostPort, callback.mResponseInfo.getProxyServer()); | 240 assertEquals(serverHostPort, callback.mResponseInfo.getProxyServer()); |
236 assertEquals("http://DomainThatDoesnt.Resolve/datareductionproxysuccess.
txt", | 241 assertEquals("http://DomainThatDoesnt.Resolve/datareductionproxysuccess.
txt", |
237 callback.mResponseInfo.getUrl()); | 242 callback.mResponseInfo.getUrl()); |
238 } | 243 } |
239 | 244 |
240 @SmallTest | 245 @SmallTest |
241 @Feature({"Cronet"}) | 246 @Feature({"Cronet"}) |
242 public void testRealTimeNetworkQualityObservationsNotEnabled() throws Except
ion { | 247 public void testRealTimeNetworkQualityObservationsNotEnabled() throws Except
ion { |
243 CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(get
Context()); | 248 ExperimentalCronetEngine.Builder mCronetEngineBuilder = |
| 249 new ExperimentalCronetEngine.Builder(getContext()); |
244 final CronetTestFramework testFramework = | 250 final CronetTestFramework testFramework = |
245 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); | 251 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); |
246 Executor networkQualityExecutor = Executors.newSingleThreadExecutor(); | 252 Executor networkQualityExecutor = Executors.newSingleThreadExecutor(); |
247 TestNetworkQualityRttListener rttListener = | 253 TestNetworkQualityRttListener rttListener = |
248 new TestNetworkQualityRttListener(networkQualityExecutor); | 254 new TestNetworkQualityRttListener(networkQualityExecutor); |
249 TestNetworkQualityThroughputListener throughputListener = | 255 TestNetworkQualityThroughputListener throughputListener = |
250 new TestNetworkQualityThroughputListener(networkQualityExecutor,
null); | 256 new TestNetworkQualityThroughputListener(networkQualityExecutor,
null); |
251 try { | 257 try { |
252 testFramework.mCronetEngine.addRttListener(rttListener); | 258 testFramework.mCronetEngine.addRttListener(rttListener); |
253 fail("Should throw an exception."); | 259 fail("Should throw an exception."); |
254 } catch (IllegalStateException e) { | 260 } catch (IllegalStateException e) { |
255 } | 261 } |
256 try { | 262 try { |
257 testFramework.mCronetEngine.addThroughputListener(throughputListener
); | 263 testFramework.mCronetEngine.addThroughputListener(throughputListener
); |
258 fail("Should throw an exception."); | 264 fail("Should throw an exception."); |
259 } catch (IllegalStateException e) { | 265 } catch (IllegalStateException e) { |
260 } | 266 } |
261 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 267 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
262 UrlRequest.Builder builder = new UrlRequest.Builder( | 268 UrlRequest.Builder builder = testFramework.mCronetEngine.newUrlRequestBu
ilder( |
263 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 269 mUrl, callback, callback.getExecutor()); |
264 UrlRequest urlRequest = builder.build(); | 270 UrlRequest urlRequest = builder.build(); |
265 | 271 |
266 urlRequest.start(); | 272 urlRequest.start(); |
267 callback.blockForDone(); | 273 callback.blockForDone(); |
268 assertEquals(0, rttListener.rttObservationCount()); | 274 assertEquals(0, rttListener.rttObservationCount()); |
269 assertEquals(0, throughputListener.throughputObservationCount()); | 275 assertEquals(0, throughputListener.throughputObservationCount()); |
270 testFramework.mCronetEngine.shutdown(); | 276 testFramework.mCronetEngine.shutdown(); |
271 } | 277 } |
272 | 278 |
273 @SmallTest | 279 @SmallTest |
274 @Feature({"Cronet"}) | 280 @Feature({"Cronet"}) |
275 public void testRealTimeNetworkQualityObservationsListenerRemoved() throws E
xception { | 281 public void testRealTimeNetworkQualityObservationsListenerRemoved() throws E
xception { |
276 CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(get
Context()); | 282 ExperimentalCronetEngine.Builder mCronetEngineBuilder = |
| 283 new ExperimentalCronetEngine.Builder(getContext()); |
277 TestExecutor networkQualityExecutor = new TestExecutor(); | 284 TestExecutor networkQualityExecutor = new TestExecutor(); |
278 TestNetworkQualityRttListener rttListener = | 285 TestNetworkQualityRttListener rttListener = |
279 new TestNetworkQualityRttListener(networkQualityExecutor); | 286 new TestNetworkQualityRttListener(networkQualityExecutor); |
280 mCronetEngineBuilder.enableNetworkQualityEstimator(true); | 287 mCronetEngineBuilder.enableNetworkQualityEstimator(true); |
281 final CronetTestFramework testFramework = | 288 final CronetTestFramework testFramework = |
282 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); | 289 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); |
283 testFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(t
rue, true); | 290 testFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(t
rue, true); |
284 | 291 |
285 testFramework.mCronetEngine.addRttListener(rttListener); | 292 testFramework.mCronetEngine.addRttListener(rttListener); |
286 testFramework.mCronetEngine.removeRttListener(rttListener); | 293 testFramework.mCronetEngine.removeRttListener(rttListener); |
287 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 294 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
288 UrlRequest.Builder builder = new UrlRequest.Builder( | 295 UrlRequest.Builder builder = testFramework.mCronetEngine.newUrlRequestBu
ilder( |
289 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 296 mUrl, callback, callback.getExecutor()); |
290 UrlRequest urlRequest = builder.build(); | 297 UrlRequest urlRequest = builder.build(); |
291 urlRequest.start(); | 298 urlRequest.start(); |
292 callback.blockForDone(); | 299 callback.blockForDone(); |
293 networkQualityExecutor.runAllTasks(); | 300 networkQualityExecutor.runAllTasks(); |
294 assertEquals(0, rttListener.rttObservationCount()); | 301 assertEquals(0, rttListener.rttObservationCount()); |
295 testFramework.mCronetEngine.shutdown(); | 302 testFramework.mCronetEngine.shutdown(); |
296 } | 303 } |
297 | 304 |
298 @SmallTest | 305 @SmallTest |
299 @Feature({"Cronet"}) | 306 @Feature({"Cronet"}) |
300 public void testRealTimeNetworkQualityObservationsQuicDisabled() throws Exce
ption { | 307 public void testRealTimeNetworkQualityObservationsQuicDisabled() throws Exce
ption { |
301 CronetEngine.Builder mCronetEngineBuilder = new CronetEngine.Builder(get
Context()); | 308 ExperimentalCronetEngine.Builder mCronetEngineBuilder = |
| 309 new ExperimentalCronetEngine.Builder(getContext()); |
302 Executor listenersExecutor = Executors.newSingleThreadExecutor(new Execu
torThreadFactory()); | 310 Executor listenersExecutor = Executors.newSingleThreadExecutor(new Execu
torThreadFactory()); |
303 ConditionVariable waitForThroughput = new ConditionVariable(); | 311 ConditionVariable waitForThroughput = new ConditionVariable(); |
304 TestNetworkQualityRttListener rttListener = | 312 TestNetworkQualityRttListener rttListener = |
305 new TestNetworkQualityRttListener(listenersExecutor); | 313 new TestNetworkQualityRttListener(listenersExecutor); |
306 TestNetworkQualityThroughputListener throughputListener = | 314 TestNetworkQualityThroughputListener throughputListener = |
307 new TestNetworkQualityThroughputListener(listenersExecutor, wait
ForThroughput); | 315 new TestNetworkQualityThroughputListener(listenersExecutor, wait
ForThroughput); |
308 mCronetEngineBuilder.enableHttp2(true).enableQuic(false).enableNetworkQu
alityEstimator( | 316 mCronetEngineBuilder.enableNetworkQualityEstimator(true).enableHttp2(tru
e).enableQuic( |
309 true); | 317 false); |
310 final CronetTestFramework testFramework = | 318 final CronetTestFramework testFramework = |
311 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); | 319 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, mCro
netEngineBuilder); |
312 testFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(t
rue, true); | 320 testFramework.mCronetEngine.configureNetworkQualityEstimatorForTesting(t
rue, true); |
313 | 321 |
314 testFramework.mCronetEngine.addRttListener(rttListener); | 322 testFramework.mCronetEngine.addRttListener(rttListener); |
315 testFramework.mCronetEngine.addThroughputListener(throughputListener); | 323 testFramework.mCronetEngine.addThroughputListener(throughputListener); |
316 | 324 |
317 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 325 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
318 UrlRequest.Builder builder = new UrlRequest.Builder( | 326 UrlRequest.Builder builder = testFramework.mCronetEngine.newUrlRequestBu
ilder( |
319 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 327 mUrl, callback, callback.getExecutor()); |
320 UrlRequest urlRequest = builder.build(); | 328 UrlRequest urlRequest = builder.build(); |
321 urlRequest.start(); | 329 urlRequest.start(); |
322 callback.blockForDone(); | 330 callback.blockForDone(); |
323 | 331 |
324 // Throughput observation is posted to the network quality estimator on
the network thread | 332 // Throughput observation is posted to the network quality estimator on
the network thread |
325 // after the UrlRequest is completed. The observations are then eventual
ly posted to | 333 // after the UrlRequest is completed. The observations are then eventual
ly posted to |
326 // throughput listeners on the executor provided to network quality. | 334 // throughput listeners on the executor provided to network quality. |
327 waitForThroughput.block(); | 335 waitForThroughput.block(); |
328 assertTrue(throughputListener.throughputObservationCount() > 0); | 336 assertTrue(throughputListener.throughputObservationCount() > 0); |
329 | 337 |
(...skipping 26 matching lines...) Expand all Loading... |
356 @Feature({"Cronet"}) | 364 @Feature({"Cronet"}) |
357 // TODO: Remove the annotation after fixing http://crbug.com/637979 & http:/
/crbug.com/637972 | 365 // TODO: Remove the annotation after fixing http://crbug.com/637979 & http:/
/crbug.com/637972 |
358 @OnlyRunNativeCronet | 366 @OnlyRunNativeCronet |
359 public void testShutdown() throws Exception { | 367 public void testShutdown() throws Exception { |
360 final CronetTestFramework testFramework = startCronetTestFramework(); | 368 final CronetTestFramework testFramework = startCronetTestFramework(); |
361 ShutdownTestUrlRequestCallback callback = | 369 ShutdownTestUrlRequestCallback callback = |
362 new ShutdownTestUrlRequestCallback(testFramework.mCronetEngine); | 370 new ShutdownTestUrlRequestCallback(testFramework.mCronetEngine); |
363 // Block callback when response starts to verify that shutdown fails | 371 // Block callback when response starts to verify that shutdown fails |
364 // if there are active requests. | 372 // if there are active requests. |
365 callback.setAutoAdvance(false); | 373 callback.setAutoAdvance(false); |
366 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 374 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
367 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 375 mUrl, callback, callback.getExecutor()); |
368 UrlRequest urlRequest = urlRequestBuilder.build(); | 376 UrlRequest urlRequest = urlRequestBuilder.build(); |
369 urlRequest.start(); | 377 urlRequest.start(); |
370 try { | 378 try { |
371 testFramework.mCronetEngine.shutdown(); | 379 testFramework.mCronetEngine.shutdown(); |
372 fail("Should throw an exception"); | 380 fail("Should throw an exception"); |
373 } catch (Exception e) { | 381 } catch (Exception e) { |
374 assertEquals("Cannot shutdown with active requests.", | 382 assertEquals("Cannot shutdown with active requests.", |
375 e.getMessage()); | 383 e.getMessage()); |
376 } | 384 } |
377 | 385 |
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
492 } | 500 } |
493 | 501 |
494 @SmallTest | 502 @SmallTest |
495 @Feature({"Cronet"}) | 503 @Feature({"Cronet"}) |
496 // TODO: Remove the annotation after fixing http://crbug.com/637972 | 504 // TODO: Remove the annotation after fixing http://crbug.com/637972 |
497 @OnlyRunNativeCronet | 505 @OnlyRunNativeCronet |
498 public void testShutdownAfterError() throws Exception { | 506 public void testShutdownAfterError() throws Exception { |
499 final CronetTestFramework testFramework = startCronetTestFramework(); | 507 final CronetTestFramework testFramework = startCronetTestFramework(); |
500 ShutdownTestUrlRequestCallback callback = | 508 ShutdownTestUrlRequestCallback callback = |
501 new ShutdownTestUrlRequestCallback(testFramework.mCronetEngine); | 509 new ShutdownTestUrlRequestCallback(testFramework.mCronetEngine); |
502 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder(MOCK_CRONE
T_TEST_FAILED_URL, | 510 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
503 callback, callback.getExecutor(), testFramework.mCronetEngine); | 511 MOCK_CRONET_TEST_FAILED_URL, callback, callback.getExecutor()); |
504 urlRequestBuilder.build().start(); | 512 urlRequestBuilder.build().start(); |
505 callback.blockForDone(); | 513 callback.blockForDone(); |
506 assertTrue(callback.mOnErrorCalled); | 514 assertTrue(callback.mOnErrorCalled); |
507 callback.blockForCallbackToComplete(); | 515 callback.blockForCallbackToComplete(); |
508 callback.shutdownExecutor(); | 516 callback.shutdownExecutor(); |
509 } | 517 } |
510 | 518 |
511 @SmallTest | 519 @SmallTest |
512 @Feature({"Cronet"}) | 520 @Feature({"Cronet"}) |
513 public void testShutdownAfterCancel() throws Exception { | 521 public void testShutdownAfterCancel() throws Exception { |
514 final CronetTestFramework testFramework = startCronetTestFramework(); | 522 final CronetTestFramework testFramework = startCronetTestFramework(); |
515 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 523 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
516 // Block callback when response starts to verify that shutdown fails | 524 // Block callback when response starts to verify that shutdown fails |
517 // if there are active requests. | 525 // if there are active requests. |
518 callback.setAutoAdvance(false); | 526 callback.setAutoAdvance(false); |
519 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 527 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
520 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 528 mUrl, callback, callback.getExecutor()); |
521 UrlRequest urlRequest = urlRequestBuilder.build(); | 529 UrlRequest urlRequest = urlRequestBuilder.build(); |
522 urlRequest.start(); | 530 urlRequest.start(); |
523 try { | 531 try { |
524 testFramework.mCronetEngine.shutdown(); | 532 testFramework.mCronetEngine.shutdown(); |
525 fail("Should throw an exception"); | 533 fail("Should throw an exception"); |
526 } catch (Exception e) { | 534 } catch (Exception e) { |
527 assertEquals("Cannot shutdown with active requests.", | 535 assertEquals("Cannot shutdown with active requests.", |
528 e.getMessage()); | 536 e.getMessage()); |
529 } | 537 } |
530 callback.waitForNextStep(); | 538 callback.waitForNextStep(); |
531 assertEquals(ResponseStep.ON_RESPONSE_STARTED, callback.mResponseStep); | 539 assertEquals(ResponseStep.ON_RESPONSE_STARTED, callback.mResponseStep); |
532 urlRequest.cancel(); | 540 urlRequest.cancel(); |
533 testFramework.mCronetEngine.shutdown(); | 541 testFramework.mCronetEngine.shutdown(); |
534 } | 542 } |
535 | 543 |
536 @SmallTest | 544 @SmallTest |
537 @Feature({"Cronet"}) | 545 @Feature({"Cronet"}) |
538 @OnlyRunNativeCronet // No netlogs for pure java impl | 546 @OnlyRunNativeCronet // No netlogs for pure java impl |
539 public void testNetLog() throws Exception { | 547 public void testNetLog() throws Exception { |
540 Context context = getContext(); | 548 Context context = getContext(); |
541 File directory = new File(PathUtils.getDataDirectory()); | 549 File directory = new File(PathUtils.getDataDirectory()); |
542 File file = File.createTempFile("cronet", "json", directory); | 550 File file = File.createTempFile("cronet", "json", directory); |
543 CronetEngine cronetEngine = new CronetUrlRequestContext( | 551 CronetEngine cronetEngine = new CronetUrlRequestContext( |
544 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 552 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
545 // Start NetLog immediately after the request context is created to make | 553 // Start NetLog immediately after the request context is created to make |
546 // sure that the call won't crash the app even when the native request | 554 // sure that the call won't crash the app even when the native request |
547 // context is not fully initialized. See crbug.com/470196. | 555 // context is not fully initialized. See crbug.com/470196. |
548 cronetEngine.startNetLogToFile(file.getPath(), false); | 556 cronetEngine.startNetLogToFile(file.getPath(), false); |
549 | 557 |
550 // Start a request. | 558 // Start a request. |
551 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 559 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
552 UrlRequest.Builder urlRequestBuilder = | 560 UrlRequest.Builder urlRequestBuilder = |
553 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 561 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
554 urlRequestBuilder.build().start(); | 562 urlRequestBuilder.build().start(); |
555 callback.blockForDone(); | 563 callback.blockForDone(); |
556 cronetEngine.stopNetLog(); | 564 cronetEngine.stopNetLog(); |
557 assertTrue(file.exists()); | 565 assertTrue(file.exists()); |
558 assertTrue(file.length() != 0); | 566 assertTrue(file.length() != 0); |
559 assertFalse(hasBytesInNetLog(file)); | 567 assertFalse(hasBytesInNetLog(file)); |
560 assertTrue(file.delete()); | 568 assertTrue(file.delete()); |
561 assertTrue(!file.exists()); | 569 assertTrue(!file.exists()); |
562 } | 570 } |
563 | 571 |
564 @SmallTest | 572 @SmallTest |
565 @Feature({"Cronet"}) | 573 @Feature({"Cronet"}) |
566 @OnlyRunNativeCronet // No netlogs for pure java impl | 574 @OnlyRunNativeCronet // No netlogs for pure java impl |
567 public void testBoundedFileNetLog() throws Exception { | 575 public void testBoundedFileNetLog() throws Exception { |
568 Context context = getContext(); | 576 Context context = getContext(); |
569 File directory = new File(PathUtils.getDataDirectory()); | 577 File directory = new File(PathUtils.getDataDirectory()); |
570 File netLogDir = new File(directory, "NetLog"); | 578 File netLogDir = new File(directory, "NetLog"); |
571 assertFalse(netLogDir.exists()); | 579 assertFalse(netLogDir.exists()); |
572 assertTrue(netLogDir.mkdir()); | 580 assertTrue(netLogDir.mkdir()); |
573 File eventFile = new File(netLogDir, "event_file_0.json"); | 581 File eventFile = new File(netLogDir, "event_file_0.json"); |
574 CronetEngine cronetEngine = new CronetUrlRequestContext( | 582 CronetUrlRequestContext cronetEngine = new CronetUrlRequestContext( |
575 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 583 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
576 // Start NetLog immediately after the request context is created to make | 584 // Start NetLog immediately after the request context is created to make |
577 // sure that the call won't crash the app even when the native request | 585 // sure that the call won't crash the app even when the native request |
578 // context is not fully initialized. See crbug.com/470196. | 586 // context is not fully initialized. See crbug.com/470196. |
579 cronetEngine.startNetLogToDisk(netLogDir.getPath(), false, MAX_FILE_SIZE
); | 587 cronetEngine.startNetLogToDisk(netLogDir.getPath(), false, MAX_FILE_SIZE
); |
580 | 588 |
581 // Start a request. | 589 // Start a request. |
582 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 590 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
583 UrlRequest.Builder urlRequestBuilder = | 591 UrlRequest.Builder urlRequestBuilder = |
584 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 592 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
585 urlRequestBuilder.build().start(); | 593 urlRequestBuilder.build().start(); |
586 callback.blockForDone(); | 594 callback.blockForDone(); |
587 cronetEngine.stopNetLog(); | 595 cronetEngine.stopNetLog(); |
588 assertTrue(eventFile.exists()); | 596 assertTrue(eventFile.exists()); |
589 assertTrue(eventFile.length() != 0); | 597 assertTrue(eventFile.length() != 0); |
590 assertFalse(hasBytesInNetLog(eventFile)); | 598 assertFalse(hasBytesInNetLog(eventFile)); |
591 FileUtils.recursivelyDeleteFile(netLogDir); | 599 FileUtils.recursivelyDeleteFile(netLogDir); |
592 assertFalse(netLogDir.exists()); | 600 assertFalse(netLogDir.exists()); |
593 } | 601 } |
594 | 602 |
595 @SmallTest | 603 @SmallTest |
596 @Feature({"Cronet"}) | 604 @Feature({"Cronet"}) |
597 @OnlyRunNativeCronet // No netlogs for pure java impl | 605 @OnlyRunNativeCronet // No netlogs for pure java impl |
598 // Tests that if stopNetLog is not explicity called, CronetEngine.shutdown() | 606 // Tests that if stopNetLog is not explicity called, CronetEngine.shutdown() |
599 // will take care of it. crbug.com/623701. | 607 // will take care of it. crbug.com/623701. |
600 public void testNoStopNetLog() throws Exception { | 608 public void testNoStopNetLog() throws Exception { |
601 Context context = getContext(); | 609 Context context = getContext(); |
602 File directory = new File(PathUtils.getDataDirectory()); | 610 File directory = new File(PathUtils.getDataDirectory()); |
603 File file = File.createTempFile("cronet", "json", directory); | 611 File file = File.createTempFile("cronet", "json", directory); |
604 CronetEngine cronetEngine = new CronetUrlRequestContext( | 612 CronetUrlRequestContext cronetEngine = new CronetUrlRequestContext( |
605 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 613 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
606 cronetEngine.startNetLogToFile(file.getPath(), false); | 614 cronetEngine.startNetLogToFile(file.getPath(), false); |
607 | 615 |
608 // Start a request. | 616 // Start a request. |
609 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 617 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
610 UrlRequest.Builder urlRequestBuilder = | 618 UrlRequest.Builder urlRequestBuilder = |
611 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 619 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
612 urlRequestBuilder.build().start(); | 620 urlRequestBuilder.build().start(); |
613 callback.blockForDone(); | 621 callback.blockForDone(); |
614 // Shut down the engine without calling stopNetLog. | 622 // Shut down the engine without calling stopNetLog. |
615 cronetEngine.shutdown(); | 623 cronetEngine.shutdown(); |
616 assertTrue(file.exists()); | 624 assertTrue(file.exists()); |
617 assertTrue(file.length() != 0); | 625 assertTrue(file.length() != 0); |
618 assertFalse(hasBytesInNetLog(file)); | 626 assertFalse(hasBytesInNetLog(file)); |
619 assertTrue(file.delete()); | 627 assertTrue(file.delete()); |
620 assertTrue(!file.exists()); | 628 assertTrue(!file.exists()); |
621 } | 629 } |
622 | 630 |
623 @SmallTest | 631 @SmallTest |
624 @Feature({"Cronet"}) | 632 @Feature({"Cronet"}) |
625 @OnlyRunNativeCronet // No netlogs for pure java impl | 633 @OnlyRunNativeCronet // No netlogs for pure java impl |
626 // Tests that if stopNetLog is not explicity called, CronetEngine.shutdown() | 634 // Tests that if stopNetLog is not explicity called, CronetEngine.shutdown() |
627 // will take care of it. crbug.com/623701. | 635 // will take care of it. crbug.com/623701. |
628 public void testNoStopBoundedFileNetLog() throws Exception { | 636 public void testNoStopBoundedFileNetLog() throws Exception { |
629 Context context = getContext(); | 637 Context context = getContext(); |
630 File directory = new File(PathUtils.getDataDirectory()); | 638 File directory = new File(PathUtils.getDataDirectory()); |
631 File netLogDir = new File(directory, "NetLog"); | 639 File netLogDir = new File(directory, "NetLog"); |
632 assertFalse(netLogDir.exists()); | 640 assertFalse(netLogDir.exists()); |
633 assertTrue(netLogDir.mkdir()); | 641 assertTrue(netLogDir.mkdir()); |
634 File eventFile = new File(netLogDir, "event_file_0.json"); | 642 File eventFile = new File(netLogDir, "event_file_0.json"); |
635 CronetEngine cronetEngine = new CronetUrlRequestContext( | 643 CronetUrlRequestContext cronetEngine = new CronetUrlRequestContext( |
636 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 644 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
637 cronetEngine.startNetLogToDisk(netLogDir.getPath(), false, MAX_FILE_SIZE
); | 645 cronetEngine.startNetLogToDisk(netLogDir.getPath(), false, MAX_FILE_SIZE
); |
638 | 646 |
639 // Start a request. | 647 // Start a request. |
640 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 648 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
641 UrlRequest.Builder urlRequestBuilder = | 649 UrlRequest.Builder urlRequestBuilder = |
642 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 650 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
643 urlRequestBuilder.build().start(); | 651 urlRequestBuilder.build().start(); |
644 callback.blockForDone(); | 652 callback.blockForDone(); |
645 // Shut down the engine without calling stopNetLog. | 653 // Shut down the engine without calling stopNetLog. |
646 cronetEngine.shutdown(); | 654 cronetEngine.shutdown(); |
647 assertTrue(eventFile.exists()); | 655 assertTrue(eventFile.exists()); |
648 assertTrue(eventFile.length() != 0); | 656 assertTrue(eventFile.length() != 0); |
649 | 657 |
650 FileUtils.recursivelyDeleteFile(netLogDir); | 658 FileUtils.recursivelyDeleteFile(netLogDir); |
651 assertFalse(netLogDir.exists()); | 659 assertFalse(netLogDir.exists()); |
652 } | 660 } |
653 | 661 |
654 @SmallTest | 662 @SmallTest |
655 @Feature({"Cronet"}) | 663 @Feature({"Cronet"}) |
656 @OnlyRunNativeCronet | 664 @OnlyRunNativeCronet |
657 // Tests that NetLog contains events emitted by all live CronetEngines. | 665 // Tests that NetLog contains events emitted by all live CronetEngines. |
658 public void testNetLogContainEventsFromAllLiveEngines() throws Exception { | 666 public void testNetLogContainEventsFromAllLiveEngines() throws Exception { |
659 Context context = getContext(); | 667 Context context = getContext(); |
660 File directory = new File(PathUtils.getDataDirectory()); | 668 File directory = new File(PathUtils.getDataDirectory()); |
661 File file1 = File.createTempFile("cronet1", "json", directory); | 669 File file1 = File.createTempFile("cronet1", "json", directory); |
662 File file2 = File.createTempFile("cronet2", "json", directory); | 670 File file2 = File.createTempFile("cronet2", "json", directory); |
663 CronetEngine cronetEngine1 = new CronetUrlRequestContext( | 671 CronetEngine cronetEngine1 = new CronetUrlRequestContext( |
664 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 672 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
665 CronetEngine cronetEngine2 = new CronetUrlRequestContext( | 673 CronetEngine cronetEngine2 = new CronetUrlRequestContext( |
666 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 674 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
667 | 675 |
668 cronetEngine1.startNetLogToFile(file1.getPath(), false); | 676 cronetEngine1.startNetLogToFile(file1.getPath(), false); |
669 cronetEngine2.startNetLogToFile(file2.getPath(), false); | 677 cronetEngine2.startNetLogToFile(file2.getPath(), false); |
670 | 678 |
671 // Warm CronetEngine and make sure both CronetUrlRequestContexts are | 679 // Warm CronetEngine and make sure both CronetUrlRequestContexts are |
672 // initialized before testing the logs. | 680 // initialized before testing the logs. |
673 makeRequestAndCheckStatus(cronetEngine1, mUrl, 200); | 681 makeRequestAndCheckStatus(cronetEngine1, mUrl, 200); |
674 makeRequestAndCheckStatus(cronetEngine2, mUrl, 200); | 682 makeRequestAndCheckStatus(cronetEngine2, mUrl, 200); |
675 | 683 |
676 // Use cronetEngine1 to make a request to mUrl404. | 684 // Use cronetEngine1 to make a request to mUrl404. |
(...skipping 26 matching lines...) Expand all Loading... |
703 File netLogDir1 = new File(directory, "NetLog1"); | 711 File netLogDir1 = new File(directory, "NetLog1"); |
704 assertFalse(netLogDir1.exists()); | 712 assertFalse(netLogDir1.exists()); |
705 assertTrue(netLogDir1.mkdir()); | 713 assertTrue(netLogDir1.mkdir()); |
706 File netLogDir2 = new File(directory, "NetLog2"); | 714 File netLogDir2 = new File(directory, "NetLog2"); |
707 assertFalse(netLogDir2.exists()); | 715 assertFalse(netLogDir2.exists()); |
708 assertTrue(netLogDir2.mkdir()); | 716 assertTrue(netLogDir2.mkdir()); |
709 File eventFile1 = new File(netLogDir1, "event_file_0.json"); | 717 File eventFile1 = new File(netLogDir1, "event_file_0.json"); |
710 File eventFile2 = new File(netLogDir2, "event_file_0.json"); | 718 File eventFile2 = new File(netLogDir2, "event_file_0.json"); |
711 | 719 |
712 CronetUrlRequestContext cronetEngine1 = new CronetUrlRequestContext( | 720 CronetUrlRequestContext cronetEngine1 = new CronetUrlRequestContext( |
713 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 721 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
714 CronetUrlRequestContext cronetEngine2 = new CronetUrlRequestContext( | 722 CronetUrlRequestContext cronetEngine2 = new CronetUrlRequestContext( |
715 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 723 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
716 | 724 |
717 cronetEngine1.startNetLogToDisk(netLogDir1.getPath(), false, MAX_FILE_SI
ZE); | 725 cronetEngine1.startNetLogToDisk(netLogDir1.getPath(), false, MAX_FILE_SI
ZE); |
718 cronetEngine2.startNetLogToDisk(netLogDir2.getPath(), false, MAX_FILE_SI
ZE); | 726 cronetEngine2.startNetLogToDisk(netLogDir2.getPath(), false, MAX_FILE_SI
ZE); |
719 | 727 |
720 // Warm CronetEngine and make sure both CronetUrlRequestContexts are | 728 // Warm CronetEngine and make sure both CronetUrlRequestContexts are |
721 // initialized before testing the logs. | 729 // initialized before testing the logs. |
722 makeRequestAndCheckStatus(cronetEngine1, mUrl, 200); | 730 makeRequestAndCheckStatus(cronetEngine1, mUrl, 200); |
723 makeRequestAndCheckStatus(cronetEngine2, mUrl, 200); | 731 makeRequestAndCheckStatus(cronetEngine2, mUrl, 200); |
724 | 732 |
725 // Use cronetEngine1 to make a request to mUrl404. | 733 // Use cronetEngine1 to make a request to mUrl404. |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
791 } | 799 } |
792 Executor directExecutor = new Executor() { | 800 Executor directExecutor = new Executor() { |
793 @Override | 801 @Override |
794 public void execute(Runnable command) { | 802 public void execute(Runnable command) { |
795 command.run(); | 803 command.run(); |
796 } | 804 } |
797 }; | 805 }; |
798 CancelUrlRequestCallback callback = new CancelUrlRequestCallback(); | 806 CancelUrlRequestCallback callback = new CancelUrlRequestCallback(); |
799 callback.setAllowDirectExecutor(true); | 807 callback.setAllowDirectExecutor(true); |
800 UrlRequest.Builder urlRequestBuilder = | 808 UrlRequest.Builder urlRequestBuilder = |
801 new UrlRequest.Builder(url, callback, directExecutor, testFramew
ork.mCronetEngine); | 809 testFramework.mCronetEngine.newUrlRequestBuilder(url, callback,
directExecutor); |
802 urlRequestBuilder.allowDirectExecutor(); | 810 urlRequestBuilder.allowDirectExecutor(); |
803 urlRequestBuilder.build().start(); | 811 urlRequestBuilder.build().start(); |
804 callback.blockForDone(); | 812 callback.blockForDone(); |
805 assertTrue(thrown.get() instanceof RuntimeException); | 813 assertTrue(thrown.get() instanceof RuntimeException); |
806 } | 814 } |
807 | 815 |
808 @SmallTest | 816 @SmallTest |
809 @Feature({"Cronet"}) | 817 @Feature({"Cronet"}) |
810 @OnlyRunNativeCronet | 818 @OnlyRunNativeCronet |
811 // Tests that if CronetEngine is shut down when reading from disk cache, | 819 // Tests that if CronetEngine is shut down when reading from disk cache, |
(...skipping 23 matching lines...) Expand all Loading... |
835 throw new RuntimeException("Unexpected"); | 843 throw new RuntimeException("Unexpected"); |
836 } | 844 } |
837 | 845 |
838 @Override | 846 @Override |
839 public void onFailed( | 847 public void onFailed( |
840 UrlRequest request, UrlResponseInfo info, UrlRequestExceptio
n error) { | 848 UrlRequest request, UrlResponseInfo info, UrlRequestExceptio
n error) { |
841 throw new RuntimeException("Unexpected"); | 849 throw new RuntimeException("Unexpected"); |
842 } | 850 } |
843 } | 851 } |
844 CancelUrlRequestCallback callback = new CancelUrlRequestCallback(); | 852 CancelUrlRequestCallback callback = new CancelUrlRequestCallback(); |
845 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 853 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
846 url, callback, callback.getExecutor(), testFramework.mCronetEngi
ne); | 854 url, callback, callback.getExecutor()); |
847 urlRequestBuilder.build().start(); | 855 urlRequestBuilder.build().start(); |
848 callback.blockForDone(); | 856 callback.blockForDone(); |
849 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); | 857 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); |
850 assertTrue(callback.mResponseInfo.wasCached()); | 858 assertTrue(callback.mResponseInfo.wasCached()); |
851 assertTrue(callback.mOnCanceledCalled); | 859 assertTrue(callback.mOnCanceledCalled); |
852 } | 860 } |
853 | 861 |
854 @SmallTest | 862 @SmallTest |
855 @Feature({"Cronet"}) | 863 @Feature({"Cronet"}) |
856 @OnlyRunNativeCronet | 864 @OnlyRunNativeCronet |
857 public void testNetLogAfterShutdown() throws Exception { | 865 public void testNetLogAfterShutdown() throws Exception { |
858 final CronetTestFramework testFramework = startCronetTestFramework(); | 866 final CronetTestFramework testFramework = startCronetTestFramework(); |
859 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 867 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
860 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 868 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
861 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 869 mUrl, callback, callback.getExecutor()); |
862 urlRequestBuilder.build().start(); | 870 urlRequestBuilder.build().start(); |
863 callback.blockForDone(); | 871 callback.blockForDone(); |
864 testFramework.mCronetEngine.shutdown(); | 872 testFramework.mCronetEngine.shutdown(); |
865 | 873 |
866 File directory = new File(PathUtils.getDataDirectory()); | 874 File directory = new File(PathUtils.getDataDirectory()); |
867 File file = File.createTempFile("cronet", "json", directory); | 875 File file = File.createTempFile("cronet", "json", directory); |
868 try { | 876 try { |
869 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false)
; | 877 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false)
; |
870 fail("Should throw an exception."); | 878 fail("Should throw an exception."); |
871 } catch (Exception e) { | 879 } catch (Exception e) { |
872 assertEquals("Engine is shut down.", e.getMessage()); | 880 assertEquals("Engine is shut down.", e.getMessage()); |
873 } | 881 } |
874 assertFalse(hasBytesInNetLog(file)); | 882 assertFalse(hasBytesInNetLog(file)); |
875 assertTrue(file.delete()); | 883 assertTrue(file.delete()); |
876 assertTrue(!file.exists()); | 884 assertTrue(!file.exists()); |
877 } | 885 } |
878 | 886 |
879 @SmallTest | 887 @SmallTest |
880 @Feature({"Cronet"}) | 888 @Feature({"Cronet"}) |
881 @OnlyRunNativeCronet | 889 @OnlyRunNativeCronet |
882 public void testBoundedFileNetLogAfterShutdown() throws Exception { | 890 public void testBoundedFileNetLogAfterShutdown() throws Exception { |
883 final CronetTestFramework testFramework = startCronetTestFramework(); | 891 final CronetTestFramework testFramework = startCronetTestFramework(); |
884 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 892 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
885 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 893 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
886 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 894 mUrl, callback, callback.getExecutor()); |
887 urlRequestBuilder.build().start(); | 895 urlRequestBuilder.build().start(); |
888 callback.blockForDone(); | 896 callback.blockForDone(); |
889 testFramework.mCronetEngine.shutdown(); | 897 testFramework.mCronetEngine.shutdown(); |
890 | 898 |
891 File directory = new File(PathUtils.getDataDirectory()); | 899 File directory = new File(PathUtils.getDataDirectory()); |
892 File netLogDir = new File(directory, "NetLog"); | 900 File netLogDir = new File(directory, "NetLog"); |
893 assertFalse(netLogDir.exists()); | 901 assertFalse(netLogDir.exists()); |
894 assertTrue(netLogDir.mkdir()); | 902 assertTrue(netLogDir.mkdir()); |
895 File constantsFile = new File(netLogDir, "constants.json"); | 903 File constantsFile = new File(netLogDir, "constants.json"); |
896 try { | 904 try { |
(...skipping 14 matching lines...) Expand all Loading... |
911 final CronetTestFramework testFramework = startCronetTestFramework(); | 919 final CronetTestFramework testFramework = startCronetTestFramework(); |
912 File directory = new File(PathUtils.getDataDirectory()); | 920 File directory = new File(PathUtils.getDataDirectory()); |
913 File file = File.createTempFile("cronet", "json", directory); | 921 File file = File.createTempFile("cronet", "json", directory); |
914 // Start NetLog multiple times. | 922 // Start NetLog multiple times. |
915 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); | 923 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); |
916 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); | 924 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); |
917 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); | 925 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); |
918 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); | 926 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); |
919 // Start a request. | 927 // Start a request. |
920 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 928 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
921 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 929 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
922 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 930 mUrl, callback, callback.getExecutor()); |
923 urlRequestBuilder.build().start(); | 931 urlRequestBuilder.build().start(); |
924 callback.blockForDone(); | 932 callback.blockForDone(); |
925 testFramework.mCronetEngine.stopNetLog(); | 933 testFramework.mCronetEngine.stopNetLog(); |
926 assertTrue(file.exists()); | 934 assertTrue(file.exists()); |
927 assertTrue(file.length() != 0); | 935 assertTrue(file.length() != 0); |
928 assertFalse(hasBytesInNetLog(file)); | 936 assertFalse(hasBytesInNetLog(file)); |
929 assertTrue(file.delete()); | 937 assertTrue(file.delete()); |
930 assertTrue(!file.exists()); | 938 assertTrue(!file.exists()); |
931 } | 939 } |
932 | 940 |
933 @SmallTest | 941 @SmallTest |
934 @Feature({"Cronet"}) | 942 @Feature({"Cronet"}) |
935 public void testBoundedFileNetLogStartMultipleTimes() throws Exception { | 943 public void testBoundedFileNetLogStartMultipleTimes() throws Exception { |
936 final CronetTestFramework testFramework = startCronetTestFramework(); | 944 final CronetTestFramework testFramework = startCronetTestFramework(); |
937 File directory = new File(PathUtils.getDataDirectory()); | 945 File directory = new File(PathUtils.getDataDirectory()); |
938 File netLogDir = new File(directory, "NetLog"); | 946 File netLogDir = new File(directory, "NetLog"); |
939 assertFalse(netLogDir.exists()); | 947 assertFalse(netLogDir.exists()); |
940 assertTrue(netLogDir.mkdir()); | 948 assertTrue(netLogDir.mkdir()); |
941 File eventFile = new File(netLogDir, "event_file_0.json"); | 949 File eventFile = new File(netLogDir, "event_file_0.json"); |
942 // Start NetLog multiple times. This should be equivalent to starting Ne
tLog | 950 // Start NetLog multiple times. This should be equivalent to starting Ne
tLog |
943 // once. Each subsequent start (without calling stopNetLog) should be a
no-op. | 951 // once. Each subsequent start (without calling stopNetLog) should be a
no-op. |
944 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); | 952 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); |
945 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); | 953 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); |
946 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); | 954 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); |
947 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); | 955 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); |
948 // Start a request. | 956 // Start a request. |
949 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 957 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
950 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 958 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
951 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 959 mUrl, callback, callback.getExecutor()); |
952 urlRequestBuilder.build().start(); | 960 urlRequestBuilder.build().start(); |
953 callback.blockForDone(); | 961 callback.blockForDone(); |
954 testFramework.mCronetEngine.stopNetLog(); | 962 testFramework.mCronetEngine.stopNetLog(); |
955 assertTrue(eventFile.exists()); | 963 assertTrue(eventFile.exists()); |
956 assertTrue(eventFile.length() != 0); | 964 assertTrue(eventFile.length() != 0); |
957 assertFalse(hasBytesInNetLog(eventFile)); | 965 assertFalse(hasBytesInNetLog(eventFile)); |
958 FileUtils.recursivelyDeleteFile(netLogDir); | 966 FileUtils.recursivelyDeleteFile(netLogDir); |
959 assertFalse(netLogDir.exists()); | 967 assertFalse(netLogDir.exists()); |
960 } | 968 } |
961 | 969 |
962 @SmallTest | 970 @SmallTest |
963 @Feature({"Cronet"}) | 971 @Feature({"Cronet"}) |
964 public void testNetLogStopMultipleTimes() throws Exception { | 972 public void testNetLogStopMultipleTimes() throws Exception { |
965 final CronetTestFramework testFramework = startCronetTestFramework(); | 973 final CronetTestFramework testFramework = startCronetTestFramework(); |
966 File directory = new File(PathUtils.getDataDirectory()); | 974 File directory = new File(PathUtils.getDataDirectory()); |
967 File file = File.createTempFile("cronet", "json", directory); | 975 File file = File.createTempFile("cronet", "json", directory); |
968 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); | 976 testFramework.mCronetEngine.startNetLogToFile(file.getPath(), false); |
969 // Start a request. | 977 // Start a request. |
970 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 978 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
971 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 979 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
972 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 980 mUrl, callback, callback.getExecutor()); |
973 urlRequestBuilder.build().start(); | 981 urlRequestBuilder.build().start(); |
974 callback.blockForDone(); | 982 callback.blockForDone(); |
975 // Stop NetLog multiple times. | 983 // Stop NetLog multiple times. |
976 testFramework.mCronetEngine.stopNetLog(); | 984 testFramework.mCronetEngine.stopNetLog(); |
977 testFramework.mCronetEngine.stopNetLog(); | 985 testFramework.mCronetEngine.stopNetLog(); |
978 testFramework.mCronetEngine.stopNetLog(); | 986 testFramework.mCronetEngine.stopNetLog(); |
979 testFramework.mCronetEngine.stopNetLog(); | 987 testFramework.mCronetEngine.stopNetLog(); |
980 testFramework.mCronetEngine.stopNetLog(); | 988 testFramework.mCronetEngine.stopNetLog(); |
981 assertTrue(file.exists()); | 989 assertTrue(file.exists()); |
982 assertTrue(file.length() != 0); | 990 assertTrue(file.length() != 0); |
983 assertFalse(hasBytesInNetLog(file)); | 991 assertFalse(hasBytesInNetLog(file)); |
984 assertTrue(file.delete()); | 992 assertTrue(file.delete()); |
985 assertTrue(!file.exists()); | 993 assertTrue(!file.exists()); |
986 } | 994 } |
987 | 995 |
988 @SmallTest | 996 @SmallTest |
989 @Feature({"Cronet"}) | 997 @Feature({"Cronet"}) |
990 public void testBoundedFileNetLogStopMultipleTimes() throws Exception { | 998 public void testBoundedFileNetLogStopMultipleTimes() throws Exception { |
991 final CronetTestFramework testFramework = startCronetTestFramework(); | 999 final CronetTestFramework testFramework = startCronetTestFramework(); |
992 File directory = new File(PathUtils.getDataDirectory()); | 1000 File directory = new File(PathUtils.getDataDirectory()); |
993 File netLogDir = new File(directory, "NetLog"); | 1001 File netLogDir = new File(directory, "NetLog"); |
994 assertFalse(netLogDir.exists()); | 1002 assertFalse(netLogDir.exists()); |
995 assertTrue(netLogDir.mkdir()); | 1003 assertTrue(netLogDir.mkdir()); |
996 File eventFile = new File(netLogDir, "event_file_0.json"); | 1004 File eventFile = new File(netLogDir, "event_file_0.json"); |
997 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); | 1005 testFramework.mCronetEngine.startNetLogToDisk(netLogDir.getPath(), false
, MAX_FILE_SIZE); |
998 // Start a request. | 1006 // Start a request. |
999 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1007 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1000 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 1008 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
1001 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 1009 mUrl, callback, callback.getExecutor()); |
1002 urlRequestBuilder.build().start(); | 1010 urlRequestBuilder.build().start(); |
1003 callback.blockForDone(); | 1011 callback.blockForDone(); |
1004 // Stop NetLog multiple times. This should be equivalent to stopping Net
Log once. | 1012 // Stop NetLog multiple times. This should be equivalent to stopping Net
Log once. |
1005 // Each subsequent stop (without calling startNetLogToDisk first) should
be a no-op. | 1013 // Each subsequent stop (without calling startNetLogToDisk first) should
be a no-op. |
1006 testFramework.mCronetEngine.stopNetLog(); | 1014 testFramework.mCronetEngine.stopNetLog(); |
1007 testFramework.mCronetEngine.stopNetLog(); | 1015 testFramework.mCronetEngine.stopNetLog(); |
1008 testFramework.mCronetEngine.stopNetLog(); | 1016 testFramework.mCronetEngine.stopNetLog(); |
1009 testFramework.mCronetEngine.stopNetLog(); | 1017 testFramework.mCronetEngine.stopNetLog(); |
1010 testFramework.mCronetEngine.stopNetLog(); | 1018 testFramework.mCronetEngine.stopNetLog(); |
1011 assertTrue(eventFile.exists()); | 1019 assertTrue(eventFile.exists()); |
1012 assertTrue(eventFile.length() != 0); | 1020 assertTrue(eventFile.length() != 0); |
1013 assertFalse(hasBytesInNetLog(eventFile)); | 1021 assertFalse(hasBytesInNetLog(eventFile)); |
1014 FileUtils.recursivelyDeleteFile(netLogDir); | 1022 FileUtils.recursivelyDeleteFile(netLogDir); |
1015 assertFalse(netLogDir.exists()); | 1023 assertFalse(netLogDir.exists()); |
1016 } | 1024 } |
1017 | 1025 |
1018 @SmallTest | 1026 @SmallTest |
1019 @Feature({"Cronet"}) | 1027 @Feature({"Cronet"}) |
1020 @OnlyRunNativeCronet | 1028 @OnlyRunNativeCronet |
1021 public void testNetLogWithBytes() throws Exception { | 1029 public void testNetLogWithBytes() throws Exception { |
1022 Context context = getContext(); | 1030 Context context = getContext(); |
1023 File directory = new File(PathUtils.getDataDirectory()); | 1031 File directory = new File(PathUtils.getDataDirectory()); |
1024 File file = File.createTempFile("cronet", "json", directory); | 1032 File file = File.createTempFile("cronet", "json", directory); |
1025 CronetEngine cronetEngine = new CronetUrlRequestContext( | 1033 CronetEngine cronetEngine = new CronetUrlRequestContext( |
1026 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 1034 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
1027 // Start NetLog with logAll as true. | 1035 // Start NetLog with logAll as true. |
1028 cronetEngine.startNetLogToFile(file.getPath(), true); | 1036 cronetEngine.startNetLogToFile(file.getPath(), true); |
1029 // Start a request. | 1037 // Start a request. |
1030 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1038 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1031 UrlRequest.Builder urlRequestBuilder = | 1039 UrlRequest.Builder urlRequestBuilder = |
1032 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 1040 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
1033 urlRequestBuilder.build().start(); | 1041 urlRequestBuilder.build().start(); |
1034 callback.blockForDone(); | 1042 callback.blockForDone(); |
1035 cronetEngine.stopNetLog(); | 1043 cronetEngine.stopNetLog(); |
1036 assertTrue(file.exists()); | 1044 assertTrue(file.exists()); |
1037 assertTrue(file.length() != 0); | 1045 assertTrue(file.length() != 0); |
1038 assertTrue(hasBytesInNetLog(file)); | 1046 assertTrue(hasBytesInNetLog(file)); |
1039 assertTrue(file.delete()); | 1047 assertTrue(file.delete()); |
1040 assertTrue(!file.exists()); | 1048 assertTrue(!file.exists()); |
1041 } | 1049 } |
1042 | 1050 |
1043 @SmallTest | 1051 @SmallTest |
1044 @Feature({"Cronet"}) | 1052 @Feature({"Cronet"}) |
1045 @OnlyRunNativeCronet | 1053 @OnlyRunNativeCronet |
1046 public void testBoundedFileNetLogWithBytes() throws Exception { | 1054 public void testBoundedFileNetLogWithBytes() throws Exception { |
1047 Context context = getContext(); | 1055 Context context = getContext(); |
1048 File directory = new File(PathUtils.getDataDirectory()); | 1056 File directory = new File(PathUtils.getDataDirectory()); |
1049 File netLogDir = new File(directory, "NetLog"); | 1057 File netLogDir = new File(directory, "NetLog"); |
1050 assertFalse(netLogDir.exists()); | 1058 assertFalse(netLogDir.exists()); |
1051 assertTrue(netLogDir.mkdir()); | 1059 assertTrue(netLogDir.mkdir()); |
1052 File eventFile = new File(netLogDir, "event_file_0.json"); | 1060 File eventFile = new File(netLogDir, "event_file_0.json"); |
1053 CronetUrlRequestContext cronetEngine = new CronetUrlRequestContext( | 1061 CronetUrlRequestContext cronetEngine = new CronetUrlRequestContext( |
1054 new CronetEngine.Builder(context).setLibraryName("cronet_tests")
); | 1062 new CronetEngineBuilderImpl(context).setLibraryName("cronet_test
s")); |
1055 // Start NetLog with logAll as true. | 1063 // Start NetLog with logAll as true. |
1056 cronetEngine.startNetLogToDisk(netLogDir.getPath(), true, MAX_FILE_SIZE)
; | 1064 cronetEngine.startNetLogToDisk(netLogDir.getPath(), true, MAX_FILE_SIZE)
; |
1057 // Start a request. | 1065 // Start a request. |
1058 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1066 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1059 UrlRequest.Builder urlRequestBuilder = | 1067 UrlRequest.Builder urlRequestBuilder = |
1060 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 1068 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
1061 urlRequestBuilder.build().start(); | 1069 urlRequestBuilder.build().start(); |
1062 callback.blockForDone(); | 1070 callback.blockForDone(); |
1063 cronetEngine.stopNetLog(); | 1071 cronetEngine.stopNetLog(); |
1064 | 1072 |
1065 assertTrue(eventFile.exists()); | 1073 assertTrue(eventFile.exists()); |
1066 assertTrue(eventFile.length() != 0); | 1074 assertTrue(eventFile.length() != 0); |
1067 assertTrue(hasBytesInNetLog(eventFile)); | 1075 assertTrue(hasBytesInNetLog(eventFile)); |
1068 FileUtils.recursivelyDeleteFile(netLogDir); | 1076 FileUtils.recursivelyDeleteFile(netLogDir); |
1069 assertFalse(netLogDir.exists()); | 1077 assertFalse(netLogDir.exists()); |
1070 } | 1078 } |
(...skipping 18 matching lines...) Expand all Loading... |
1089 } | 1097 } |
1090 | 1098 |
1091 /** | 1099 /** |
1092 * Helper method to make a request to {@code url}, wait for it to | 1100 * Helper method to make a request to {@code url}, wait for it to |
1093 * complete, and check that the status code is the same as {@code expectedSt
atusCode}. | 1101 * complete, and check that the status code is the same as {@code expectedSt
atusCode}. |
1094 */ | 1102 */ |
1095 private void makeRequestAndCheckStatus( | 1103 private void makeRequestAndCheckStatus( |
1096 CronetEngine engine, String url, int expectedStatusCode) { | 1104 CronetEngine engine, String url, int expectedStatusCode) { |
1097 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1105 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1098 UrlRequest request = | 1106 UrlRequest request = |
1099 new UrlRequest.Builder(url, callback, callback.getExecutor(), en
gine).build(); | 1107 engine.newUrlRequestBuilder(url, callback, callback.getExecutor(
)).build(); |
1100 request.start(); | 1108 request.start(); |
1101 callback.blockForDone(); | 1109 callback.blockForDone(); |
1102 assertEquals(expectedStatusCode, callback.mResponseInfo.getHttpStatusCod
e()); | 1110 assertEquals(expectedStatusCode, callback.mResponseInfo.getHttpStatusCod
e()); |
1103 } | 1111 } |
1104 | 1112 |
1105 private CronetTestFramework startCronetTestFrameworkWithCacheEnabled(int cac
heType) | 1113 private CronetTestFramework startCronetTestFrameworkWithCacheEnabled(int cac
heType) |
1106 throws Exception { | 1114 throws Exception { |
1107 String cacheTypeString = ""; | 1115 String cacheTypeString = ""; |
1108 if (cacheType == CronetEngine.Builder.HTTP_CACHE_DISK) { | 1116 if (cacheType == CronetEngine.Builder.HTTP_CACHE_DISK) { |
1109 cacheTypeString = CronetTestFramework.CACHE_DISK; | 1117 cacheTypeString = CronetTestFramework.CACHE_DISK; |
(...skipping 10 matching lines...) Expand all Loading... |
1120 } | 1128 } |
1121 | 1129 |
1122 private void checkRequestCaching(CronetEngine engine, String url, boolean ex
pectCached) { | 1130 private void checkRequestCaching(CronetEngine engine, String url, boolean ex
pectCached) { |
1123 checkRequestCaching(engine, url, expectCached, false); | 1131 checkRequestCaching(engine, url, expectCached, false); |
1124 } | 1132 } |
1125 | 1133 |
1126 private void checkRequestCaching( | 1134 private void checkRequestCaching( |
1127 CronetEngine engine, String url, boolean expectCached, boolean disab
leCache) { | 1135 CronetEngine engine, String url, boolean expectCached, boolean disab
leCache) { |
1128 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1136 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1129 UrlRequest.Builder urlRequestBuilder = | 1137 UrlRequest.Builder urlRequestBuilder = |
1130 new UrlRequest.Builder(url, callback, callback.getExecutor(), en
gine); | 1138 engine.newUrlRequestBuilder(url, callback, callback.getExecutor(
)); |
1131 if (disableCache) { | 1139 if (disableCache) { |
1132 urlRequestBuilder.disableCache(); | 1140 urlRequestBuilder.disableCache(); |
1133 } | 1141 } |
1134 urlRequestBuilder.build().start(); | 1142 urlRequestBuilder.build().start(); |
1135 callback.blockForDone(); | 1143 callback.blockForDone(); |
1136 assertEquals(expectCached, callback.mResponseInfo.wasCached()); | 1144 assertEquals(expectCached, callback.mResponseInfo.wasCached()); |
1137 assertEquals("this is a cacheable file\n", callback.mResponseAsString); | 1145 assertEquals("this is a cacheable file\n", callback.mResponseAsString); |
1138 } | 1146 } |
1139 | 1147 |
1140 @SmallTest | 1148 @SmallTest |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1199 // When cache is enabled, the second request is cached. | 1207 // When cache is enabled, the second request is cached. |
1200 checkRequestCaching(testFramework.mCronetEngine, url, false, true /** di
sable cache */); | 1208 checkRequestCaching(testFramework.mCronetEngine, url, false, true /** di
sable cache */); |
1201 checkRequestCaching(testFramework.mCronetEngine, url, true); | 1209 checkRequestCaching(testFramework.mCronetEngine, url, true); |
1202 | 1210 |
1203 // Shut down the server, next request should have a cached response. | 1211 // Shut down the server, next request should have a cached response. |
1204 NativeTestServer.shutdownNativeTestServer(); | 1212 NativeTestServer.shutdownNativeTestServer(); |
1205 checkRequestCaching(testFramework.mCronetEngine, url, true); | 1213 checkRequestCaching(testFramework.mCronetEngine, url, true); |
1206 | 1214 |
1207 // Cache is disabled after server is shut down, request should fail. | 1215 // Cache is disabled after server is shut down, request should fail. |
1208 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1216 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1209 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder( | 1217 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
1210 url, callback, callback.getExecutor(), testFramework.mCronetEngi
ne); | 1218 url, callback, callback.getExecutor()); |
1211 urlRequestBuilder.disableCache(); | 1219 urlRequestBuilder.disableCache(); |
1212 urlRequestBuilder.build().start(); | 1220 urlRequestBuilder.build().start(); |
1213 callback.blockForDone(); | 1221 callback.blockForDone(); |
1214 assertNotNull(callback.mError); | 1222 assertNotNull(callback.mError); |
1215 assertEquals("Exception in CronetUrlRequest: net::ERR_CONNECTION_REFUSED
", | 1223 assertEquals("Exception in CronetUrlRequest: net::ERR_CONNECTION_REFUSED
", |
1216 callback.mError.getMessage()); | 1224 callback.mError.getMessage()); |
1217 } | 1225 } |
1218 | 1226 |
1219 @SmallTest | 1227 @SmallTest |
1220 @Feature({"Cronet"}) | 1228 @Feature({"Cronet"}) |
1221 public void testEnableHttpCacheDiskNewEngine() throws Exception { | 1229 public void testEnableHttpCacheDiskNewEngine() throws Exception { |
1222 final CronetTestFramework testFramework = | 1230 final CronetTestFramework testFramework = |
1223 startCronetTestFrameworkWithCacheEnabled(CronetEngine.Builder.HT
TP_CACHE_DISK); | 1231 startCronetTestFrameworkWithCacheEnabled(CronetEngine.Builder.HT
TP_CACHE_DISK); |
1224 String url = NativeTestServer.getFileURL("/cacheable.txt"); | 1232 String url = NativeTestServer.getFileURL("/cacheable.txt"); |
1225 checkRequestCaching(testFramework.mCronetEngine, url, false); | 1233 checkRequestCaching(testFramework.mCronetEngine, url, false); |
1226 checkRequestCaching(testFramework.mCronetEngine, url, true); | 1234 checkRequestCaching(testFramework.mCronetEngine, url, true); |
1227 NativeTestServer.shutdownNativeTestServer(); | 1235 NativeTestServer.shutdownNativeTestServer(); |
1228 checkRequestCaching(testFramework.mCronetEngine, url, true); | 1236 checkRequestCaching(testFramework.mCronetEngine, url, true); |
1229 | 1237 |
1230 // Shutdown original context and create another that uses the same cache
. | 1238 // Shutdown original context and create another that uses the same cache
. |
1231 testFramework.mCronetEngine.shutdown(); | 1239 testFramework.mCronetEngine.shutdown(); |
1232 testFramework.mCronetEngine = testFramework.getCronetEngineBuilder().bui
ld(); | 1240 testFramework.mCronetEngine = |
| 1241 (CronetEngineBase) testFramework.getCronetEngineBuilder().build(
); |
1233 checkRequestCaching(testFramework.mCronetEngine, url, true); | 1242 checkRequestCaching(testFramework.mCronetEngine, url, true); |
1234 } | 1243 } |
1235 | 1244 |
1236 @SmallTest | 1245 @SmallTest |
1237 @Feature({"Cronet"}) | 1246 @Feature({"Cronet"}) |
1238 public void testInitEngineAndStartRequest() { | 1247 public void testInitEngineAndStartRequest() { |
1239 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); | 1248 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); |
1240 | 1249 |
1241 // Immediately make a request after initializing the engine. | 1250 // Immediately make a request after initializing the engine. |
1242 CronetEngine cronetEngine = testFramework.initCronetEngine(); | 1251 CronetEngine cronetEngine = testFramework.initCronetEngine(); |
1243 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1252 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1244 UrlRequest.Builder urlRequestBuilder = | 1253 UrlRequest.Builder urlRequestBuilder = |
1245 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 1254 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
1246 urlRequestBuilder.build().start(); | 1255 urlRequestBuilder.build().start(); |
1247 callback.blockForDone(); | 1256 callback.blockForDone(); |
1248 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); | 1257 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); |
1249 } | 1258 } |
1250 | 1259 |
1251 @SmallTest | 1260 @SmallTest |
1252 @Feature({"Cronet"}) | 1261 @Feature({"Cronet"}) |
1253 public void testEmptyGetCertVerifierData() { | 1262 public void testEmptyGetCertVerifierData() { |
1254 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); | 1263 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); |
1255 | 1264 |
1256 // Immediately make a request after initializing the engine. | 1265 // Immediately make a request after initializing the engine. |
1257 CronetEngine cronetEngine = testFramework.initCronetEngine(); | 1266 CronetEngine cronetEngine = testFramework.initCronetEngine(); |
1258 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1267 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1259 UrlRequest.Builder urlRequestBuilder = | 1268 UrlRequest.Builder urlRequestBuilder = |
1260 new UrlRequest.Builder(mUrl, callback, callback.getExecutor(), c
ronetEngine); | 1269 cronetEngine.newUrlRequestBuilder(mUrl, callback, callback.getEx
ecutor()); |
1261 urlRequestBuilder.build().start(); | 1270 urlRequestBuilder.build().start(); |
1262 callback.blockForDone(); | 1271 callback.blockForDone(); |
1263 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); | 1272 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); |
1264 | 1273 |
1265 try { | 1274 try { |
1266 cronetEngine.getCertVerifierData(-1); | 1275 cronetEngine.getCertVerifierData(-1); |
1267 fail("Should throw an exception"); | 1276 fail("Should throw an exception"); |
1268 } catch (Exception e) { | 1277 } catch (Exception e) { |
1269 assertEquals("timeout must be a positive value", e.getMessage()); | 1278 assertEquals("timeout must be a positive value", e.getMessage()); |
1270 } | 1279 } |
1271 // Because mUrl is http, getCertVerifierData() will return empty data. | 1280 // Because mUrl is http, getCertVerifierData() will return empty data. |
1272 String data = cronetEngine.getCertVerifierData(100); | 1281 String data = cronetEngine.getCertVerifierData(100); |
1273 assertTrue(data.isEmpty()); | 1282 assertTrue(data.isEmpty()); |
1274 } | 1283 } |
1275 | 1284 |
1276 @SmallTest | 1285 @SmallTest |
1277 @Feature({"Cronet"}) | 1286 @Feature({"Cronet"}) |
1278 public void testInitEngineStartTwoRequests() throws Exception { | 1287 public void testInitEngineStartTwoRequests() throws Exception { |
1279 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); | 1288 CronetTestFramework testFramework = startCronetTestFrameworkAndSkipLibra
ryInit(); |
1280 | 1289 |
1281 // Make two requests after initializing the context. | 1290 // Make two requests after initializing the context. |
1282 CronetEngine cronetEngine = testFramework.initCronetEngine(); | 1291 CronetEngine cronetEngine = testFramework.initCronetEngine(); |
1283 int[] statusCodes = {0, 0}; | 1292 int[] statusCodes = {0, 0}; |
1284 String[] urls = {mUrl, mUrl404}; | 1293 String[] urls = {mUrl, mUrl404}; |
1285 for (int i = 0; i < 2; i++) { | 1294 for (int i = 0; i < 2; i++) { |
1286 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1295 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1287 UrlRequest.Builder urlRequestBuilder = | 1296 UrlRequest.Builder urlRequestBuilder = |
1288 new UrlRequest.Builder(urls[i], callback, callback.getExecut
or(), cronetEngine); | 1297 cronetEngine.newUrlRequestBuilder(urls[i], callback, callbac
k.getExecutor()); |
1289 urlRequestBuilder.build().start(); | 1298 urlRequestBuilder.build().start(); |
1290 callback.blockForDone(); | 1299 callback.blockForDone(); |
1291 statusCodes[i] = callback.mResponseInfo.getHttpStatusCode(); | 1300 statusCodes[i] = callback.mResponseInfo.getHttpStatusCode(); |
1292 } | 1301 } |
1293 assertEquals(200, statusCodes[0]); | 1302 assertEquals(200, statusCodes[0]); |
1294 assertEquals(404, statusCodes[1]); | 1303 assertEquals(404, statusCodes[1]); |
1295 } | 1304 } |
1296 | 1305 |
1297 @SmallTest | 1306 @SmallTest |
1298 @Feature({"Cronet"}) | 1307 @Feature({"Cronet"}) |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1331 } | 1340 } |
1332 | 1341 |
1333 @SmallTest | 1342 @SmallTest |
1334 @Feature({"Cronet"}) | 1343 @Feature({"Cronet"}) |
1335 public void testInitDifferentEngines() throws Exception { | 1344 public void testInitDifferentEngines() throws Exception { |
1336 // Test that concurrently instantiating Cronet context's upon various | 1345 // Test that concurrently instantiating Cronet context's upon various |
1337 // different versions of the same Android Context does not cause crashes | 1346 // different versions of the same Android Context does not cause crashes |
1338 // like crbug.com/453845 | 1347 // like crbug.com/453845 |
1339 final CronetTestFramework testFramework = startCronetTestFramework(); | 1348 final CronetTestFramework testFramework = startCronetTestFramework(); |
1340 CronetEngine firstEngine = | 1349 CronetEngine firstEngine = |
1341 new CronetUrlRequestContext(testFramework.createCronetEngineBuil
der(getContext())); | 1350 new CronetUrlRequestContext(CronetTestUtil.getCronetEngineBuilde
rImpl( |
| 1351 testFramework.createCronetEngineBuilder(getContext()))); |
1342 CronetEngine secondEngine = new CronetUrlRequestContext( | 1352 CronetEngine secondEngine = new CronetUrlRequestContext( |
1343 testFramework.createCronetEngineBuilder(getContext().getApplicat
ionContext())); | 1353 CronetTestUtil.getCronetEngineBuilderImpl(testFramework.createCr
onetEngineBuilder( |
1344 CronetEngine thirdEngine = new CronetUrlRequestContext( | 1354 getContext().getApplicationContext()))); |
1345 testFramework.createCronetEngineBuilder(new ContextWrapper(getCo
ntext()))); | 1355 CronetEngine thirdEngine = |
| 1356 new CronetUrlRequestContext(CronetTestUtil.getCronetEngineBuilde
rImpl( |
| 1357 testFramework.createCronetEngineBuilder(getContext()))); |
1346 firstEngine.shutdown(); | 1358 firstEngine.shutdown(); |
1347 secondEngine.shutdown(); | 1359 secondEngine.shutdown(); |
1348 thirdEngine.shutdown(); | 1360 thirdEngine.shutdown(); |
1349 } | 1361 } |
1350 | 1362 |
1351 @SmallTest | 1363 @SmallTest |
1352 @Feature({"Cronet"}) | 1364 @Feature({"Cronet"}) |
1353 public void testGetGlobalMetricsDeltas() throws Exception { | 1365 public void testGetGlobalMetricsDeltas() throws Exception { |
1354 final CronetTestFramework testFramework = startCronetTestFramework(); | 1366 final CronetTestFramework testFramework = startCronetTestFramework(); |
1355 | 1367 |
1356 byte delta1[] = testFramework.mCronetEngine.getGlobalMetricsDeltas(); | 1368 byte delta1[] = testFramework.mCronetEngine.getGlobalMetricsDeltas(); |
1357 | 1369 |
1358 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1370 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1359 UrlRequest.Builder builder = new UrlRequest.Builder( | 1371 UrlRequest.Builder builder = testFramework.mCronetEngine.newUrlRequestBu
ilder( |
1360 mUrl, callback, callback.getExecutor(), testFramework.mCronetEng
ine); | 1372 mUrl, callback, callback.getExecutor()); |
1361 builder.build().start(); | 1373 builder.build().start(); |
1362 callback.blockForDone(); | 1374 callback.blockForDone(); |
1363 byte delta2[] = testFramework.mCronetEngine.getGlobalMetricsDeltas(); | 1375 byte delta2[] = testFramework.mCronetEngine.getGlobalMetricsDeltas(); |
1364 assertTrue(delta2.length != 0); | 1376 assertTrue(delta2.length != 0); |
1365 assertFalse(Arrays.equals(delta1, delta2)); | 1377 assertFalse(Arrays.equals(delta1, delta2)); |
1366 } | 1378 } |
1367 | 1379 |
1368 @SmallTest | 1380 @SmallTest |
1369 @Feature({"Cronet"}) | 1381 @Feature({"Cronet"}) |
1370 public void testCronetEngineBuilderConfig() throws Exception { | 1382 public void testCronetEngineBuilderConfig() throws Exception { |
1371 // This is to prompt load of native library. | 1383 // This is to prompt load of native library. |
1372 startCronetTestFramework(); | 1384 startCronetTestFramework(); |
1373 // Verify CronetEngine.Builder config is passed down accurately to nativ
e code. | 1385 // Verify CronetEngine.Builder config is passed down accurately to nativ
e code. |
1374 CronetEngine.Builder builder = new CronetEngine.Builder(getContext()); | 1386 CronetEngineBuilderImpl builder = new CronetEngineBuilderImpl(getContext
()); |
1375 builder.enableHttp2(false); | 1387 builder.enableHttp2(false); |
1376 builder.enableQuic(true); | 1388 builder.enableQuic(true); |
1377 builder.enableSdch(true); | 1389 builder.enableSdch(true); |
1378 builder.addQuicHint("example.com", 12, 34); | 1390 builder.addQuicHint("example.com", 12, 34); |
1379 builder.setCertVerifierData("test_cert_verifier_data"); | 1391 builder.setCertVerifierData("test_cert_verifier_data"); |
1380 builder.enableHttpCache(CronetEngine.Builder.HTTP_CACHE_IN_MEMORY, 54321
); | 1392 builder.enableHttpCache(CronetEngineBuilderImpl.HTTP_CACHE_IN_MEMORY, 54
321); |
1381 builder.enableDataReductionProxy("abcd"); | 1393 builder.enableDataReductionProxy("abcd"); |
1382 builder.setUserAgent("efgh"); | 1394 builder.setUserAgent("efgh"); |
1383 builder.setExperimentalOptions("ijkl"); | 1395 builder.setExperimentalOptions("ijkl"); |
1384 builder.setDataReductionProxyOptions("mnop", "qrst", "uvwx"); | 1396 builder.setDataReductionProxyOptions("mnop", "qrst", "uvwx"); |
1385 builder.setStoragePath(CronetTestFramework.getTestStorage(getContext()))
; | 1397 builder.setStoragePath(CronetTestFramework.getTestStorage(getContext()))
; |
1386 builder.enablePublicKeyPinningBypassForLocalTrustAnchors(false); | 1398 builder.enablePublicKeyPinningBypassForLocalTrustAnchors(false); |
1387 nativeVerifyUrlRequestContextConfig( | 1399 nativeVerifyUrlRequestContextConfig( |
1388 CronetUrlRequestContext.createNativeUrlRequestContextConfig(getC
ontext(), builder), | 1400 CronetUrlRequestContext.createNativeUrlRequestContextConfig(getC
ontext(), builder), |
1389 CronetTestFramework.getTestStorage(getContext())); | 1401 CronetTestFramework.getTestStorage(getContext())); |
1390 } | 1402 } |
(...skipping 12 matching lines...) Expand all Loading... |
1403 | 1415 |
1404 boolean wasCalled() { | 1416 boolean wasCalled() { |
1405 return mWasCalled; | 1417 return mWasCalled; |
1406 } | 1418 } |
1407 } | 1419 } |
1408 | 1420 |
1409 @SmallTest | 1421 @SmallTest |
1410 @Feature({"Cronet"}) | 1422 @Feature({"Cronet"}) |
1411 @OnlyRunNativeCronet | 1423 @OnlyRunNativeCronet |
1412 public void testSkipLibraryLoading() throws Exception { | 1424 public void testSkipLibraryLoading() throws Exception { |
1413 CronetEngine.Builder builder = new CronetEngine.Builder(getContext()); | 1425 CronetEngineBuilderImpl builder = new CronetEngineBuilderImpl(getContext
()); |
1414 TestBadLibraryLoader loader = new TestBadLibraryLoader(); | 1426 TestBadLibraryLoader loader = new TestBadLibraryLoader(); |
1415 builder.setLibraryLoader(loader).setLibraryName("cronet_tests"); | 1427 builder.setLibraryLoader(loader).setLibraryName("cronet_tests"); |
1416 try { | 1428 try { |
1417 // ensureInitialized() calls native code to check the version right
after library load | 1429 // ensureInitialized() calls native code to check the version right
after library load |
1418 // and will error with the message below if library loading was skip
ped | 1430 // and will error with the message below if library loading was skip
ped |
1419 CronetLibraryLoader.ensureInitialized(getContext(), builder); | 1431 CronetLibraryLoader.ensureInitialized(getContext(), builder); |
1420 fail("Native library should not be loaded"); | 1432 fail("Native library should not be loaded"); |
1421 } catch (UnsatisfiedLinkError e) { | 1433 } catch (UnsatisfiedLinkError e) { |
1422 assertTrue(loader.wasCalled()); | 1434 assertTrue(loader.wasCalled()); |
1423 } | 1435 } |
1424 } | 1436 } |
1425 | 1437 |
1426 // Creates a CronetEngine on another thread and then one on the main thread.
This shouldn't | 1438 // Creates a CronetEngine on another thread and then one on the main thread.
This shouldn't |
1427 // crash. | 1439 // crash. |
1428 @SmallTest | 1440 @SmallTest |
1429 @Feature({"Cronet"}) | 1441 @Feature({"Cronet"}) |
1430 public void testThreadedStartup() throws Exception { | 1442 public void testThreadedStartup() throws Exception { |
1431 final ConditionVariable otherThreadDone = new ConditionVariable(); | 1443 final ConditionVariable otherThreadDone = new ConditionVariable(); |
1432 final ConditionVariable uiThreadDone = new ConditionVariable(); | 1444 final ConditionVariable uiThreadDone = new ConditionVariable(); |
1433 new Handler(Looper.getMainLooper()).post(new Runnable() { | 1445 new Handler(Looper.getMainLooper()).post(new Runnable() { |
1434 public void run() { | 1446 public void run() { |
1435 final CronetEngine.Builder builder = | 1447 final CronetEngine.Builder builder = |
1436 new CronetEngine.Builder(getContext()).setLibraryName("c
ronet_tests"); | 1448 new ExperimentalCronetEngine.Builder(getContext()); |
| 1449 CronetTestUtil.setLibraryName(builder, "cronet_tests"); |
1437 new Thread() { | 1450 new Thread() { |
1438 public void run() { | 1451 public void run() { |
1439 CronetEngine cronetEngine = builder.build(); | 1452 CronetEngine cronetEngine = builder.build(); |
1440 otherThreadDone.open(); | 1453 otherThreadDone.open(); |
1441 cronetEngine.shutdown(); | 1454 cronetEngine.shutdown(); |
1442 } | 1455 } |
1443 }.start(); | 1456 }.start(); |
1444 otherThreadDone.block(); | 1457 otherThreadDone.block(); |
1445 builder.build().shutdown(); | 1458 builder.build().shutdown(); |
1446 uiThreadDone.open(); | 1459 uiThreadDone.open(); |
1447 } | 1460 } |
1448 }); | 1461 }); |
1449 assertTrue(uiThreadDone.block(1000)); | 1462 assertTrue(uiThreadDone.block(1000)); |
1450 } | 1463 } |
1451 | 1464 |
1452 @SmallTest | 1465 @SmallTest |
1453 @Feature({"Cronet"}) | 1466 @Feature({"Cronet"}) |
1454 public void testHostResolverRules() throws Exception { | 1467 public void testHostResolverRules() throws Exception { |
1455 String resolverTestHostname = "some-weird-hostname"; | 1468 String resolverTestHostname = "some-weird-hostname"; |
1456 URL testUrl = new URL(mUrl); | 1469 URL testUrl = new URL(mUrl); |
1457 CronetEngine.Builder cronetEngineBuilder = new CronetEngine.Builder(getC
ontext()); | 1470 ExperimentalCronetEngine.Builder cronetEngineBuilder = |
| 1471 new ExperimentalCronetEngine.Builder(getContext()); |
1458 JSONObject hostResolverRules = new JSONObject().put( | 1472 JSONObject hostResolverRules = new JSONObject().put( |
1459 "host_resolver_rules", "MAP " + resolverTestHostname + " " + tes
tUrl.getHost()); | 1473 "host_resolver_rules", "MAP " + resolverTestHostname + " " + tes
tUrl.getHost()); |
1460 JSONObject experimentalOptions = | 1474 JSONObject experimentalOptions = |
1461 new JSONObject().put("HostResolverRules", hostResolverRules); | 1475 new JSONObject().put("HostResolverRules", hostResolverRules); |
1462 cronetEngineBuilder.setExperimentalOptions(experimentalOptions.toString(
)); | 1476 cronetEngineBuilder.setExperimentalOptions(experimentalOptions.toString(
)); |
1463 | 1477 |
1464 final CronetTestFramework testFramework = | 1478 final CronetTestFramework testFramework = |
1465 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, cron
etEngineBuilder); | 1479 startCronetTestFrameworkWithUrlAndCronetEngineBuilder(null, cron
etEngineBuilder); |
1466 TestUrlRequestCallback callback = new TestUrlRequestCallback(); | 1480 TestUrlRequestCallback callback = new TestUrlRequestCallback(); |
1467 URL requestUrl = | 1481 URL requestUrl = |
1468 new URL("http", resolverTestHostname, testUrl.getPort(), testUrl
.getFile()); | 1482 new URL("http", resolverTestHostname, testUrl.getPort(), testUrl
.getFile()); |
1469 UrlRequest.Builder urlRequestBuilder = new UrlRequest.Builder(requestUrl
.toString(), | 1483 UrlRequest.Builder urlRequestBuilder = testFramework.mCronetEngine.newUr
lRequestBuilder( |
1470 callback, callback.getExecutor(), testFramework.mCronetEngine); | 1484 requestUrl.toString(), callback, callback.getExecutor()); |
1471 urlRequestBuilder.build().start(); | 1485 urlRequestBuilder.build().start(); |
1472 callback.blockForDone(); | 1486 callback.blockForDone(); |
1473 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); | 1487 assertEquals(200, callback.mResponseInfo.getHttpStatusCode()); |
1474 } | 1488 } |
1475 } | 1489 } |
OLD | NEW |