Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(8)

Side by Side Diff: chrome/browser/devtools/devtools_network_transaction.cc

Issue 324953002: DevToolsNetworkController: support "limit throughput" network condition. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed nits Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « chrome/browser/devtools/devtools_network_transaction.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "chrome/browser/devtools/devtools_network_transaction.h" 5 #include "chrome/browser/devtools/devtools_network_transaction.h"
6 6
7 #include "chrome/browser/devtools/devtools_network_controller.h" 7 #include "chrome/browser/devtools/devtools_network_controller.h"
8 #include "net/base/net_errors.h" 8 #include "net/base/net_errors.h"
9 #include "net/base/upload_progress.h" 9 #include "net/base/upload_progress.h"
10 #include "net/http/http_network_transaction.h" 10 #include "net/http/http_network_transaction.h"
11 #include "net/http/http_request_info.h" 11 #include "net/http/http_request_info.h"
12 12
13 DevToolsNetworkTransaction::DevToolsNetworkTransaction( 13 DevToolsNetworkTransaction::DevToolsNetworkTransaction(
14 DevToolsNetworkController* controller, 14 DevToolsNetworkController* controller,
15 scoped_ptr<net::HttpTransaction> network_transaction) 15 scoped_ptr<net::HttpTransaction> network_transaction)
16 : controller_(controller), 16 : controller_(controller),
17 network_transaction_(network_transaction.Pass()), 17 network_transaction_(network_transaction.Pass()),
18 request_(NULL), 18 request_(NULL),
19 failed_(false), 19 failed_(false),
20 throttled_byte_count_(0),
21 callback_type_(NONE),
20 proxy_callback_(base::Bind(&DevToolsNetworkTransaction::OnCallback, 22 proxy_callback_(base::Bind(&DevToolsNetworkTransaction::OnCallback,
21 base::Unretained(this))) { 23 base::Unretained(this))) {
22 DCHECK(controller); 24 DCHECK(controller);
23 controller->AddTransaction(this); 25 controller->AddTransaction(this);
24 } 26 }
25 27
26 DevToolsNetworkTransaction::~DevToolsNetworkTransaction() { 28 DevToolsNetworkTransaction::~DevToolsNetworkTransaction() {
27 controller_->RemoveTransaction(this); 29 controller_->RemoveTransaction(this);
28 } 30 }
29 31
32 void DevToolsNetworkTransaction::Throttle(int result) {
33 throttled_result_ = result;
34
35 if (callback_type_ == START)
36 throttled_byte_count_ += network_transaction_->GetTotalReceivedBytes();
37 if (result > 0)
38 throttled_byte_count_ += result;
39
40 controller_->ThrottleTransaction(this);
41 }
42
30 void DevToolsNetworkTransaction::OnCallback(int rv) { 43 void DevToolsNetworkTransaction::OnCallback(int rv) {
31 if (failed_) 44 if (failed_)
32 return; 45 return;
33 DCHECK(!callback_.is_null()); 46 DCHECK(!callback_.is_null());
47 if (callback_type_ == START || callback_type_ == READ) {
48 if (controller_->ShouldThrottle(request_)) {
49 Throttle(rv);
50 return;
51 }
52 }
34 net::CompletionCallback callback = callback_; 53 net::CompletionCallback callback = callback_;
35 callback_.Reset(); 54 callback_.Reset();
55 callback_type_ = NONE;
36 callback.Run(rv); 56 callback.Run(rv);
37 } 57 }
38 58
59 int DevToolsNetworkTransaction::SetupCallback(
60 net::CompletionCallback callback,
61 int result,
62 CallbackType callback_type) {
63 DCHECK(callback_type_ == NONE);
64
65 if (result == net::ERR_IO_PENDING) {
66 callback_type_ = callback_type;
67 callback_ = callback;
68 return result;
69 }
70
71 if (!controller_->ShouldThrottle(request_))
72 return result;
73
74 // Only START and READ operation throttling is supported.
75 if (callback_type != START && callback_type != READ)
76 return result;
77
78 // In case of error |throttled_byte_count_| is unknown.
79 if (result < 0)
80 return result;
81
82 // URLRequestJob relies on synchronous end-of-stream notification.
83 if (callback_type == READ && result == 0)
84 return result;
85
86 callback_type_ = callback_type;
87 callback_ = callback;
88 Throttle(result);
89 return net::ERR_IO_PENDING;
90 }
91
39 void DevToolsNetworkTransaction::Fail() { 92 void DevToolsNetworkTransaction::Fail() {
40 DCHECK(request_); 93 DCHECK(request_);
41 DCHECK(!failed_); 94 DCHECK(!failed_);
42 failed_ = true; 95 failed_ = true;
43 network_transaction_->SetBeforeNetworkStartCallback( 96 network_transaction_->SetBeforeNetworkStartCallback(
44 BeforeNetworkStartCallback()); 97 BeforeNetworkStartCallback());
45 if (callback_.is_null()) 98 if (callback_.is_null())
46 return; 99 return;
47 net::CompletionCallback callback = callback_; 100 net::CompletionCallback callback = callback_;
48 callback_.Reset(); 101 callback_.Reset();
102 callback_type_ = NONE;
49 callback.Run(net::ERR_INTERNET_DISCONNECTED); 103 callback.Run(net::ERR_INTERNET_DISCONNECTED);
50 } 104 }
51 105
52 int DevToolsNetworkTransaction::Start( 106 int DevToolsNetworkTransaction::Start(
53 const net::HttpRequestInfo* request, 107 const net::HttpRequestInfo* request,
54 const net::CompletionCallback& callback, 108 const net::CompletionCallback& callback,
55 const net::BoundNetLog& net_log) { 109 const net::BoundNetLog& net_log) {
56 DCHECK(request); 110 DCHECK(request);
57 request_ = request; 111 request_ = request;
58 112
59 if (controller_->ShouldFail(request_)) { 113 if (controller_->ShouldFail(request_)) {
60 failed_ = true; 114 failed_ = true;
61 network_transaction_->SetBeforeNetworkStartCallback( 115 network_transaction_->SetBeforeNetworkStartCallback(
62 BeforeNetworkStartCallback()); 116 BeforeNetworkStartCallback());
63 return net::ERR_INTERNET_DISCONNECTED; 117 return net::ERR_INTERNET_DISCONNECTED;
64 } 118 }
65 int rv = network_transaction_->Start(request, proxy_callback_, net_log); 119 int rv = network_transaction_->Start(request, proxy_callback_, net_log);
66 if (rv == net::ERR_IO_PENDING) 120 return SetupCallback(callback, rv, START);
67 callback_ = callback;
68 return rv;
69 } 121 }
70 122
71 int DevToolsNetworkTransaction::RestartIgnoringLastError( 123 int DevToolsNetworkTransaction::RestartIgnoringLastError(
72 const net::CompletionCallback& callback) { 124 const net::CompletionCallback& callback) {
73 if (failed_) 125 if (failed_)
74 return net::ERR_INTERNET_DISCONNECTED; 126 return net::ERR_INTERNET_DISCONNECTED;
75 int rv = network_transaction_->RestartIgnoringLastError(proxy_callback_); 127 int rv = network_transaction_->RestartIgnoringLastError(proxy_callback_);
76 if (rv == net::ERR_IO_PENDING) 128 return SetupCallback(callback, rv, RESTART_IGNORING_LAST_ERROR);
77 callback_ = callback;
78 return rv;
79 } 129 }
80 130
81 int DevToolsNetworkTransaction::RestartWithCertificate( 131 int DevToolsNetworkTransaction::RestartWithCertificate(
82 net::X509Certificate* client_cert, 132 net::X509Certificate* client_cert,
83 const net::CompletionCallback& callback) { 133 const net::CompletionCallback& callback) {
84 if (failed_) 134 if (failed_)
85 return net::ERR_INTERNET_DISCONNECTED; 135 return net::ERR_INTERNET_DISCONNECTED;
86 int rv = network_transaction_->RestartWithCertificate( 136 int rv = network_transaction_->RestartWithCertificate(
87 client_cert, proxy_callback_); 137 client_cert, proxy_callback_);
88 if (rv == net::ERR_IO_PENDING) 138 return SetupCallback(callback, rv, RESTART_WITH_CERTIFICATE);
89 callback_ = callback;
90 return rv;
91 } 139 }
92 140
93 int DevToolsNetworkTransaction::RestartWithAuth( 141 int DevToolsNetworkTransaction::RestartWithAuth(
94 const net::AuthCredentials& credentials, 142 const net::AuthCredentials& credentials,
95 const net::CompletionCallback& callback) { 143 const net::CompletionCallback& callback) {
96 if (failed_) 144 if (failed_)
97 return net::ERR_INTERNET_DISCONNECTED; 145 return net::ERR_INTERNET_DISCONNECTED;
98 int rv = network_transaction_->RestartWithAuth(credentials, proxy_callback_); 146 int rv = network_transaction_->RestartWithAuth(credentials, proxy_callback_);
99 if (rv == net::ERR_IO_PENDING) 147 return SetupCallback(callback, rv, RESTART_WITH_AUTH);
100 callback_ = callback;
101 return rv;
102 } 148 }
103 149
104 bool DevToolsNetworkTransaction::IsReadyToRestartForAuth() { 150 bool DevToolsNetworkTransaction::IsReadyToRestartForAuth() {
105 return network_transaction_->IsReadyToRestartForAuth(); 151 return network_transaction_->IsReadyToRestartForAuth();
106 } 152 }
107 153
108 int DevToolsNetworkTransaction::Read( 154 int DevToolsNetworkTransaction::Read(
109 net::IOBuffer* buf, 155 net::IOBuffer* buf,
110 int buf_len, 156 int buf_len,
111 const net::CompletionCallback& callback) { 157 const net::CompletionCallback& callback) {
112 if (failed_) 158 if (failed_)
113 return net::ERR_INTERNET_DISCONNECTED; 159 return net::ERR_INTERNET_DISCONNECTED;
114 int rv = network_transaction_->Read(buf, buf_len, proxy_callback_); 160 int rv = network_transaction_->Read(buf, buf_len, proxy_callback_);
115 if (rv == net::ERR_IO_PENDING) 161 return SetupCallback(callback, rv, READ);
116 callback_ = callback;
117 return rv;
118 } 162 }
119 163
120 void DevToolsNetworkTransaction::StopCaching() { 164 void DevToolsNetworkTransaction::StopCaching() {
121 network_transaction_->StopCaching(); 165 network_transaction_->StopCaching();
122 } 166 }
123 167
124 bool DevToolsNetworkTransaction::GetFullRequestHeaders( 168 bool DevToolsNetworkTransaction::GetFullRequestHeaders(
125 net::HttpRequestHeaders* headers) const { 169 net::HttpRequestHeaders* headers) const {
126 return network_transaction_->GetFullRequestHeaders(headers); 170 return network_transaction_->GetFullRequestHeaders(headers);
127 } 171 }
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
169 void DevToolsNetworkTransaction::SetBeforeNetworkStartCallback( 213 void DevToolsNetworkTransaction::SetBeforeNetworkStartCallback(
170 const BeforeNetworkStartCallback& callback) { 214 const BeforeNetworkStartCallback& callback) {
171 network_transaction_->SetBeforeNetworkStartCallback(callback); 215 network_transaction_->SetBeforeNetworkStartCallback(callback);
172 } 216 }
173 217
174 int DevToolsNetworkTransaction::ResumeNetworkStart() { 218 int DevToolsNetworkTransaction::ResumeNetworkStart() {
175 if (failed_) 219 if (failed_)
176 return net::ERR_INTERNET_DISCONNECTED; 220 return net::ERR_INTERNET_DISCONNECTED;
177 return network_transaction_->ResumeNetworkStart(); 221 return network_transaction_->ResumeNetworkStart();
178 } 222 }
223
224 void DevToolsNetworkTransaction::FireThrottledCallback() {
225 DCHECK(!callback_.is_null());
226 DCHECK(callback_type_ == READ || callback_type_ == START);
227 net::CompletionCallback callback = callback_;
228 callback_.Reset();
229 callback_type_ = NONE;
230 callback.Run(throttled_result_);
231 }
OLDNEW
« no previous file with comments | « chrome/browser/devtools/devtools_network_transaction.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698