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 #include "components/cronet/android/cronet_url_request_adapter.h" | 5 #include "components/cronet/android/cronet_url_request_adapter.h" |
6 | 6 |
7 #include <limits> | 7 #include <limits> |
8 #include <utility> | 8 #include <utility> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 26 matching lines...) Expand all Loading... | |
37 bool CronetUrlRequestAdapterRegisterJni(JNIEnv* env) { | 37 bool CronetUrlRequestAdapterRegisterJni(JNIEnv* env) { |
38 return RegisterNativesImpl(env); | 38 return RegisterNativesImpl(env); |
39 } | 39 } |
40 | 40 |
41 static jlong CreateRequestAdapter(JNIEnv* env, | 41 static jlong CreateRequestAdapter(JNIEnv* env, |
42 const JavaParamRef<jobject>& jurl_request, | 42 const JavaParamRef<jobject>& jurl_request, |
43 jlong jurl_request_context_adapter, | 43 jlong jurl_request_context_adapter, |
44 const JavaParamRef<jstring>& jurl_string, | 44 const JavaParamRef<jstring>& jurl_string, |
45 jint jpriority, | 45 jint jpriority, |
46 jboolean jdisable_cache, | 46 jboolean jdisable_cache, |
47 jboolean jdisable_connection_migration) { | 47 jboolean jdisable_connection_migration, |
48 jboolean jenable_metrics) { | |
48 CronetURLRequestContextAdapter* context_adapter = | 49 CronetURLRequestContextAdapter* context_adapter = |
49 reinterpret_cast<CronetURLRequestContextAdapter*>( | 50 reinterpret_cast<CronetURLRequestContextAdapter*>( |
50 jurl_request_context_adapter); | 51 jurl_request_context_adapter); |
51 DCHECK(context_adapter); | 52 DCHECK(context_adapter); |
52 | 53 |
53 GURL url(base::android::ConvertJavaStringToUTF8(env, jurl_string)); | 54 GURL url(base::android::ConvertJavaStringToUTF8(env, jurl_string)); |
54 | 55 |
55 VLOG(1) << "New chromium network request_adapter: " | 56 VLOG(1) << "New chromium network request_adapter: " |
56 << url.possibly_invalid_spec(); | 57 << url.possibly_invalid_spec(); |
57 | 58 |
58 CronetURLRequestAdapter* adapter = new CronetURLRequestAdapter( | 59 CronetURLRequestAdapter* adapter = new CronetURLRequestAdapter( |
59 context_adapter, env, jurl_request, url, | 60 context_adapter, env, jurl_request, url, |
60 static_cast<net::RequestPriority>(jpriority), jdisable_cache, | 61 static_cast<net::RequestPriority>(jpriority), jdisable_cache, |
61 jdisable_connection_migration); | 62 jdisable_connection_migration, jenable_metrics); |
62 | 63 |
63 return reinterpret_cast<jlong>(adapter); | 64 return reinterpret_cast<jlong>(adapter); |
64 } | 65 } |
65 | 66 |
66 CronetURLRequestAdapter::CronetURLRequestAdapter( | 67 CronetURLRequestAdapter::CronetURLRequestAdapter( |
67 CronetURLRequestContextAdapter* context, | 68 CronetURLRequestContextAdapter* context, |
68 JNIEnv* env, | 69 JNIEnv* env, |
69 jobject jurl_request, | 70 jobject jurl_request, |
70 const GURL& url, | 71 const GURL& url, |
71 net::RequestPriority priority, | 72 net::RequestPriority priority, |
72 jboolean jdisable_cache, | 73 jboolean jdisable_cache, |
73 jboolean jdisable_connection_migration) | 74 jboolean jdisable_connection_migration, |
75 jboolean jenable_metrics) | |
74 : context_(context), | 76 : context_(context), |
75 initial_url_(url), | 77 initial_url_(url), |
76 initial_priority_(priority), | 78 initial_priority_(priority), |
77 initial_method_("GET"), | 79 initial_method_("GET"), |
78 load_flags_(context->default_load_flags()) { | 80 load_flags_(context->default_load_flags()) { |
79 DCHECK(!context_->IsOnNetworkThread()); | 81 DCHECK(!context_->IsOnNetworkThread()); |
80 owner_.Reset(env, jurl_request); | 82 owner_.Reset(env, jurl_request); |
81 if (jdisable_cache == JNI_TRUE) | 83 if (jdisable_cache == JNI_TRUE) |
82 load_flags_ |= net::LOAD_DISABLE_CACHE; | 84 load_flags_ |= net::LOAD_DISABLE_CACHE; |
83 if (jdisable_connection_migration == JNI_TRUE) | 85 if (jdisable_connection_migration == JNI_TRUE) |
84 load_flags_ |= net::LOAD_DISABLE_CONNECTION_MIGRATION; | 86 load_flags_ |= net::LOAD_DISABLE_CONNECTION_MIGRATION; |
87 enable_metrics_ = (jenable_metrics == JNI_TRUE); | |
85 } | 88 } |
86 | 89 |
87 CronetURLRequestAdapter::~CronetURLRequestAdapter() { | 90 CronetURLRequestAdapter::~CronetURLRequestAdapter() { |
88 DCHECK(context_->IsOnNetworkThread()); | 91 DCHECK(context_->IsOnNetworkThread()); |
89 } | 92 } |
90 | 93 |
91 jboolean CronetURLRequestAdapter::SetHttpMethod( | 94 jboolean CronetURLRequestAdapter::SetHttpMethod( |
92 JNIEnv* env, | 95 JNIEnv* env, |
93 const JavaParamRef<jobject>& jcaller, | 96 const JavaParamRef<jobject>& jcaller, |
94 const JavaParamRef<jstring>& jmethod) { | 97 const JavaParamRef<jstring>& jmethod) { |
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
225 } | 228 } |
226 | 229 |
227 void CronetURLRequestAdapter::OnSSLCertificateError( | 230 void CronetURLRequestAdapter::OnSSLCertificateError( |
228 net::URLRequest* request, | 231 net::URLRequest* request, |
229 const net::SSLInfo& ssl_info, | 232 const net::SSLInfo& ssl_info, |
230 bool fatal) { | 233 bool fatal) { |
231 DCHECK(context_->IsOnNetworkThread()); | 234 DCHECK(context_->IsOnNetworkThread()); |
232 request->Cancel(); | 235 request->Cancel(); |
233 int net_error = net::MapCertStatusToNetError(ssl_info.cert_status); | 236 int net_error = net::MapCertStatusToNetError(ssl_info.cert_status); |
234 JNIEnv* env = base::android::AttachCurrentThread(); | 237 JNIEnv* env = base::android::AttachCurrentThread(); |
238 MaybeReportMetrics(request); | |
235 cronet::Java_CronetUrlRequest_onError( | 239 cronet::Java_CronetUrlRequest_onError( |
236 env, owner_.obj(), NetErrorToUrlRequestError(net_error), net_error, | 240 env, owner_.obj(), NetErrorToUrlRequestError(net_error), net_error, |
237 net::QUIC_NO_ERROR, | 241 net::QUIC_NO_ERROR, |
238 ConvertUTF8ToJavaString(env, net::ErrorToString(net_error)).obj(), | 242 ConvertUTF8ToJavaString(env, net::ErrorToString(net_error)).obj(), |
239 request->GetTotalReceivedBytes()); | 243 request->GetTotalReceivedBytes()); |
240 } | 244 } |
241 | 245 |
242 void CronetURLRequestAdapter::OnResponseStarted(net::URLRequest* request) { | 246 void CronetURLRequestAdapter::OnResponseStarted(net::URLRequest* request) { |
243 DCHECK(context_->IsOnNetworkThread()); | 247 DCHECK(context_->IsOnNetworkThread()); |
244 if (MaybeReportError(request)) | 248 if (MaybeReportError(request)) |
(...skipping 21 matching lines...) Expand all Loading... | |
266 if (bytes_read != 0) { | 270 if (bytes_read != 0) { |
267 JNIEnv* env = base::android::AttachCurrentThread(); | 271 JNIEnv* env = base::android::AttachCurrentThread(); |
268 cronet::Java_CronetUrlRequest_onReadCompleted( | 272 cronet::Java_CronetUrlRequest_onReadCompleted( |
269 env, owner_.obj(), read_buffer_->byte_buffer(), bytes_read, | 273 env, owner_.obj(), read_buffer_->byte_buffer(), bytes_read, |
270 read_buffer_->initial_position(), read_buffer_->initial_limit(), | 274 read_buffer_->initial_position(), read_buffer_->initial_limit(), |
271 request->GetTotalReceivedBytes()); | 275 request->GetTotalReceivedBytes()); |
272 // Free the read buffer. This lets the Java ByteBuffer be freed, if the | 276 // Free the read buffer. This lets the Java ByteBuffer be freed, if the |
273 // embedder releases it, too. | 277 // embedder releases it, too. |
274 read_buffer_ = nullptr; | 278 read_buffer_ = nullptr; |
275 } else { | 279 } else { |
280 MaybeReportMetrics(request); | |
276 JNIEnv* env = base::android::AttachCurrentThread(); | 281 JNIEnv* env = base::android::AttachCurrentThread(); |
277 cronet::Java_CronetUrlRequest_onSucceeded( | 282 cronet::Java_CronetUrlRequest_onSucceeded( |
278 env, owner_.obj(), url_request_->GetTotalReceivedBytes()); | 283 env, owner_.obj(), url_request_->GetTotalReceivedBytes()); |
279 } | 284 } |
280 } | 285 } |
281 | 286 |
282 void CronetURLRequestAdapter::StartOnNetworkThread() { | 287 void CronetURLRequestAdapter::StartOnNetworkThread() { |
283 DCHECK(context_->IsOnNetworkThread()); | 288 DCHECK(context_->IsOnNetworkThread()); |
284 VLOG(1) << "Starting chromium request: " | 289 VLOG(1) << "Starting chromium request: " |
285 << initial_url_.possibly_invalid_spec().c_str() | 290 << initial_url_.possibly_invalid_spec().c_str() |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
349 // If IO is pending, wait for the URLRequest to call OnReadCompleted. | 354 // If IO is pending, wait for the URLRequest to call OnReadCompleted. |
350 if (url_request_->status().is_io_pending()) | 355 if (url_request_->status().is_io_pending()) |
351 return; | 356 return; |
352 | 357 |
353 OnReadCompleted(url_request_.get(), bytes_read); | 358 OnReadCompleted(url_request_.get(), bytes_read); |
354 } | 359 } |
355 | 360 |
356 void CronetURLRequestAdapter::DestroyOnNetworkThread(bool send_on_canceled) { | 361 void CronetURLRequestAdapter::DestroyOnNetworkThread(bool send_on_canceled) { |
357 DCHECK(context_->IsOnNetworkThread()); | 362 DCHECK(context_->IsOnNetworkThread()); |
358 if (send_on_canceled) { | 363 if (send_on_canceled) { |
364 MaybeReportMetrics(url_request_.get()); | |
359 JNIEnv* env = base::android::AttachCurrentThread(); | 365 JNIEnv* env = base::android::AttachCurrentThread(); |
360 cronet::Java_CronetUrlRequest_onCanceled(env, owner_.obj()); | 366 cronet::Java_CronetUrlRequest_onCanceled(env, owner_.obj()); |
361 } | 367 } |
362 delete this; | 368 delete this; |
363 } | 369 } |
364 | 370 |
365 bool CronetURLRequestAdapter::MaybeReportError(net::URLRequest* request) const { | 371 bool CronetURLRequestAdapter::MaybeReportError(net::URLRequest* request) const { |
366 DCHECK_NE(net::URLRequestStatus::IO_PENDING, url_request_->status().status()); | 372 DCHECK_NE(net::URLRequestStatus::IO_PENDING, url_request_->status().status()); |
367 DCHECK_EQ(request, url_request_.get()); | 373 DCHECK_EQ(request, url_request_.get()); |
368 if (url_request_->status().is_success()) | 374 if (url_request_->status().is_success()) |
369 return false; | 375 return false; |
370 int net_error = url_request_->status().error(); | 376 int net_error = url_request_->status().error(); |
371 net::NetErrorDetails net_error_details; | 377 net::NetErrorDetails net_error_details; |
372 url_request_->PopulateNetErrorDetails(&net_error_details); | 378 url_request_->PopulateNetErrorDetails(&net_error_details); |
373 VLOG(1) << "Error " << net::ErrorToString(net_error) | 379 VLOG(1) << "Error " << net::ErrorToString(net_error) |
374 << " on chromium request: " << initial_url_.possibly_invalid_spec(); | 380 << " on chromium request: " << initial_url_.possibly_invalid_spec(); |
381 MaybeReportMetrics(request); | |
375 JNIEnv* env = base::android::AttachCurrentThread(); | 382 JNIEnv* env = base::android::AttachCurrentThread(); |
376 cronet::Java_CronetUrlRequest_onError( | 383 cronet::Java_CronetUrlRequest_onError( |
377 env, owner_.obj(), NetErrorToUrlRequestError(net_error), net_error, | 384 env, owner_.obj(), NetErrorToUrlRequestError(net_error), net_error, |
378 net_error_details.quic_connection_error, | 385 net_error_details.quic_connection_error, |
379 ConvertUTF8ToJavaString(env, net::ErrorToString(net_error)).obj(), | 386 ConvertUTF8ToJavaString(env, net::ErrorToString(net_error)).obj(), |
380 request->GetTotalReceivedBytes()); | 387 request->GetTotalReceivedBytes()); |
381 return true; | 388 return true; |
382 } | 389 } |
383 | 390 |
391 void CronetURLRequestAdapter::MaybeReportMetrics( | |
392 net::URLRequest* request) const { | |
393 if (!enable_metrics_) { | |
394 return; | |
395 } | |
396 net::LoadTimingInfo metrics; | |
397 request->GetLoadTimingInfo(&metrics); | |
398 JNIEnv* env = base::android::AttachCurrentThread(); | |
xunjieli
2016/09/20 21:53:33
How about passing |env| as an argument of MaybeRep
mgersh
2016/09/30 23:47:14
Done.
| |
399 base::Time start_time = metrics.request_start_time; | |
400 base::TimeTicks start_ticks = metrics.request_start; | |
401 cronet::Java_CronetUrlRequest_onMetricsCollected( | |
xunjieli
2016/09/20 14:32:46
Can we combine this with onError, onSucceeded, onC
mgersh
2016/09/20 20:48:24
The reason for this was to avoid adding 15 more ar
xunjieli
2016/09/20 21:53:33
Acknowledged. That's a good point.
| |
402 env, owner_.obj(), start_time.ToJavaTime(), | |
403 ConvertTime(metrics.connect_timing.dns_start, start_time, start_ticks), | |
404 ConvertTime(metrics.connect_timing.dns_end, start_time, start_ticks), | |
405 ConvertTime(metrics.connect_timing.connect_start, start_time, | |
406 start_ticks), | |
407 ConvertTime(metrics.connect_timing.connect_end, start_time, start_ticks), | |
408 ConvertTime(metrics.connect_timing.ssl_start, start_time, start_ticks), | |
409 ConvertTime(metrics.connect_timing.ssl_end, start_time, start_ticks), | |
410 ConvertTime(metrics.send_start, start_time, start_ticks), | |
411 ConvertTime(metrics.send_end, start_time, start_ticks), | |
412 ConvertTime(metrics.push_start, start_time, start_ticks), | |
413 ConvertTime(metrics.push_end, start_time, start_ticks), | |
414 ConvertTime(metrics.receive_headers_end, start_time, start_ticks), | |
415 ConvertTime(base::TimeTicks::Now(), start_time, start_ticks), | |
416 metrics.socket_reused, 0, request->GetTotalReceivedBytes()); | |
417 } | |
418 | |
419 int64_t CronetURLRequestAdapter::ConvertTime( | |
420 base::TimeTicks ticks, | |
xunjieli
2016/09/20 14:32:46
const base::TimeTicks& ?
mgersh
2016/09/20 20:48:24
TimeTicks and Time are stored as a single int64_t
xunjieli
2016/09/20 21:53:33
That's a good point. I was looking at
https://cs.
mgersh
2016/09/30 23:47:14
Done.
| |
421 base::Time start_time, | |
422 base::TimeTicks start_ticks) const { | |
423 if (ticks.is_null()) { | |
424 return -1; | |
425 } | |
426 return (start_time + (ticks - start_ticks)).ToJavaTime(); | |
427 } | |
428 | |
384 net::URLRequest* CronetURLRequestAdapter::GetURLRequestForTesting() { | 429 net::URLRequest* CronetURLRequestAdapter::GetURLRequestForTesting() { |
385 return url_request_.get(); | 430 return url_request_.get(); |
386 } | 431 } |
387 | 432 |
388 } // namespace cronet | 433 } // namespace cronet |
OLD | NEW |