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

Side by Side Diff: content/browser/loader/test_resource_handler.cc

Issue 2526983002: Refactor ResourceHandler API. (Closed)
Patch Set: Fix Created 4 years 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "content/browser/loader/test_resource_handler.h" 5 #include "content/browser/loader/test_resource_handler.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "content/browser/loader/resource_controller.h" 8 #include "content/browser/loader/resource_controller.h"
9 #include "content/public/common/resource_response.h" 9 #include "content/public/common/resource_response.h"
10 #include "testing/gtest/include/gtest/gtest.h" 10 #include "testing/gtest/include/gtest/gtest.h"
(...skipping 29 matching lines...) Expand all
40 body_ptr_(body), 40 body_ptr_(body),
41 deferred_run_loop_(new base::RunLoop()) { 41 deferred_run_loop_(new base::RunLoop()) {
42 SetBufferSize(2048); 42 SetBufferSize(2048);
43 } 43 }
44 44
45 TestResourceHandler::TestResourceHandler() 45 TestResourceHandler::TestResourceHandler()
46 : TestResourceHandler(nullptr, nullptr) {} 46 : TestResourceHandler(nullptr, nullptr) {}
47 47
48 TestResourceHandler::~TestResourceHandler() {} 48 TestResourceHandler::~TestResourceHandler() {}
49 49
50 void TestResourceHandler::SetController(ResourceController* controller) { 50 void TestResourceHandler::OnRequestRedirected(
51 controller_ = controller;
52 }
53
54 bool TestResourceHandler::OnRequestRedirected(
55 const net::RedirectInfo& redirect_info, 51 const net::RedirectInfo& redirect_info,
56 ResourceResponse* response, 52 ResourceResponse* response,
57 bool* defer) { 53 std::unique_ptr<ResourceController> controller) {
58 EXPECT_FALSE(canceled_); 54 EXPECT_FALSE(canceled_);
59 EXPECT_EQ(1, on_will_start_called_); 55 EXPECT_EQ(1, on_will_start_called_);
60 EXPECT_EQ(0, on_response_started_called_); 56 EXPECT_EQ(0, on_response_started_called_);
61 EXPECT_EQ(0, on_response_completed_called_); 57 EXPECT_EQ(0, on_response_completed_called_);
62 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 58 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
63 59
64 ++on_request_redirected_called_; 60 ++on_request_redirected_called_;
65 61
66 if (!on_request_redirected_result_) { 62 if (!on_request_redirected_result_) {
67 canceled_ = true; 63 canceled_ = true;
68 return false; 64 controller->Cancel();
65 return;
69 } 66 }
70 67
71 *defer = defer_on_request_redirected_; 68 if (defer_on_request_redirected_) {
72 defer_on_request_redirected_ = false; 69 defer_on_request_redirected_ = false;
73 if (*defer) 70 set_controller(std::move(controller));
74 deferred_run_loop_->Quit(); 71 deferred_run_loop_->Quit();
75 return true; 72 return;
73 }
74
75 controller->Resume();
76 } 76 }
77 77
78 bool TestResourceHandler::OnResponseStarted(ResourceResponse* response, 78 void TestResourceHandler::OnResponseStarted(
79 bool* defer) { 79 ResourceResponse* response,
80 std::unique_ptr<ResourceController> controller) {
80 EXPECT_FALSE(canceled_); 81 EXPECT_FALSE(canceled_);
81 EXPECT_EQ(1, on_will_start_called_); 82 EXPECT_EQ(1, on_will_start_called_);
82 EXPECT_EQ(0, on_response_started_called_); 83 EXPECT_EQ(0, on_response_started_called_);
83 EXPECT_EQ(0, on_response_completed_called_); 84 EXPECT_EQ(0, on_response_completed_called_);
84 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 85 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
85 86
86 ++on_response_started_called_; 87 ++on_response_started_called_;
87 88
88 EXPECT_FALSE(resource_response_); 89 EXPECT_FALSE(resource_response_);
89 resource_response_ = response; 90 resource_response_ = response;
90 91
91 if (!on_response_started_result_) { 92 if (!on_response_started_result_) {
92 canceled_ = true; 93 canceled_ = true;
93 return false; 94 controller->Cancel();
95 return;
94 } 96 }
95 97
96 *defer = defer_on_response_started_; 98 if (!on_request_redirected_result_) {
97 defer_on_response_started_ = false; 99 controller->Cancel();
98 if (*defer) 100 return;
101 }
102
103 if (defer_on_response_started_) {
104 defer_on_response_started_ = false;
105 set_controller(std::move(controller));
99 deferred_run_loop_->Quit(); 106 deferred_run_loop_->Quit();
100 return true; 107 return;
108 }
109
110 controller->Resume();
101 } 111 }
102 112
103 bool TestResourceHandler::OnWillStart(const GURL& url, bool* defer) { 113 void TestResourceHandler::OnWillStart(
114 const GURL& url,
115 std::unique_ptr<ResourceController> controller) {
104 EXPECT_FALSE(canceled_); 116 EXPECT_FALSE(canceled_);
105 EXPECT_EQ(0, on_response_started_called_); 117 EXPECT_EQ(0, on_response_started_called_);
106 EXPECT_EQ(0, on_will_start_called_); 118 EXPECT_EQ(0, on_will_start_called_);
107 EXPECT_EQ(0, on_response_completed_called_); 119 EXPECT_EQ(0, on_response_completed_called_);
108 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 120 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
109 121
110 ++on_will_start_called_; 122 ++on_will_start_called_;
111 123
112 start_url_ = url; 124 start_url_ = url;
113 125
114 if (!on_will_start_result_) { 126 if (!on_will_start_result_) {
115 canceled_ = true; 127 canceled_ = true;
116 return false; 128 controller->Cancel();
129 return;
117 } 130 }
118 131
119 *defer = defer_on_will_start_; 132 if (defer_on_will_start_) {
120 if (*defer) 133 defer_on_will_start_ = false;
134 set_controller(std::move(controller));
121 deferred_run_loop_->Quit(); 135 deferred_run_loop_->Quit();
122 return true; 136 return;
137 }
138
139 controller->Resume();
123 } 140 }
124 141
125 bool TestResourceHandler::OnWillRead(scoped_refptr<net::IOBuffer>* buf, 142 bool TestResourceHandler::OnWillRead(scoped_refptr<net::IOBuffer>* buf,
126 int* buf_size, 143 int* buf_size,
127 int min_size) { 144 int min_size) {
128 EXPECT_FALSE(canceled_); 145 EXPECT_FALSE(canceled_);
129 EXPECT_FALSE(expect_on_data_downloaded_); 146 EXPECT_FALSE(expect_on_data_downloaded_);
130 EXPECT_EQ(0, on_response_completed_called_); 147 EXPECT_EQ(0, on_response_completed_called_);
131 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 148 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
132 149
133 ++on_will_read_called_; 150 ++on_will_read_called_;
134 151
135 *buf = buffer_; 152 *buf = buffer_;
136 *buf_size = buffer_size_; 153 *buf_size = buffer_size_;
137 memset(buffer_->data(), '\0', buffer_size_); 154 memset(buffer_->data(), '\0', buffer_size_);
138 if (!on_will_read_result_) 155 if (!on_will_read_result_)
139 canceled_ = true; 156 canceled_ = true;
140 return on_will_read_result_; 157 return on_will_read_result_;
141 } 158 }
142 159
143 bool TestResourceHandler::OnReadCompleted(int bytes_read, bool* defer) { 160 void TestResourceHandler::OnReadCompleted(
161 int bytes_read,
162 std::unique_ptr<ResourceController> controller) {
144 EXPECT_FALSE(canceled_); 163 EXPECT_FALSE(canceled_);
145 EXPECT_FALSE(expect_on_data_downloaded_); 164 EXPECT_FALSE(expect_on_data_downloaded_);
146 EXPECT_EQ(1, on_will_start_called_); 165 EXPECT_EQ(1, on_will_start_called_);
147 EXPECT_EQ(1, on_response_started_called_); 166 EXPECT_EQ(1, on_response_started_called_);
148 EXPECT_EQ(0, on_response_completed_called_); 167 EXPECT_EQ(0, on_response_completed_called_);
149 EXPECT_EQ(0, on_read_eof_); 168 EXPECT_EQ(0, on_read_eof_);
150 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 169 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
151 170
152 ++on_read_completed_called_; 171 ++on_read_completed_called_;
153 if (bytes_read == 0) 172 if (bytes_read == 0)
154 ++on_read_eof_; 173 ++on_read_eof_;
155 174
156 EXPECT_LE(static_cast<size_t>(bytes_read), buffer_size_); 175 EXPECT_LE(static_cast<size_t>(bytes_read), buffer_size_);
157 if (body_ptr_) 176 if (body_ptr_)
158 body_ptr_->append(buffer_->data(), bytes_read); 177 body_ptr_->append(buffer_->data(), bytes_read);
159 body_.append(buffer_->data(), bytes_read); 178 body_.append(buffer_->data(), bytes_read);
160 179
161 if (!on_read_completed_result_ || (!on_read_eof_result_ && bytes_read == 0)) { 180 if (!on_read_completed_result_ || (!on_read_eof_result_ && bytes_read == 0)) {
162 canceled_ = true; 181 canceled_ = true;
163 return false; 182 controller->Cancel();
183 return;
164 } 184 }
165 185
166 *defer = defer_on_read_completed_; 186 if (defer_on_read_completed_ || (bytes_read == 0 && defer_on_read_eof_)) {
167 defer_on_read_completed_ = false; 187 defer_on_read_completed_ = false;
168 if (bytes_read == 0 && defer_on_read_eof_) 188 set_controller(std::move(controller));
169 *defer = true; 189 deferred_run_loop_->Quit();
190 return;
191 }
170 192
171 if (*defer) 193 controller->Resume();
172 deferred_run_loop_->Quit();
173
174 return true;
175 } 194 }
176 195
177 void TestResourceHandler::OnResponseCompleted( 196 void TestResourceHandler::OnResponseCompleted(
178 const net::URLRequestStatus& status, 197 const net::URLRequestStatus& status,
179 bool* defer) { 198 std::unique_ptr<ResourceController> controller) {
180 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 199 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
181 200
182 EXPECT_EQ(0, on_response_completed_called_); 201 EXPECT_EQ(0, on_response_completed_called_);
183 if (status.is_success() && !expect_on_data_downloaded_ && expect_eof_read_) 202 if (status.is_success() && !expect_on_data_downloaded_ && expect_eof_read_)
184 EXPECT_EQ(1, on_read_eof_); 203 EXPECT_EQ(1, on_read_eof_);
185 204
186 ++on_response_completed_called_; 205 ++on_response_completed_called_;
187 206
188 if (request_status_ptr_) 207 if (request_status_ptr_)
189 *request_status_ptr_ = status; 208 *request_status_ptr_ = status;
190 final_status_ = status; 209 final_status_ = status;
191 *defer = defer_on_response_completed_;
192 defer_on_response_completed_ = false;
193 210
194 if (*defer) 211 // Consider response completed. Even if deferring, the TestResourceHandler
212 // won't be called again.
213 response_complete_run_loop_.Quit();
214
215 if (defer_on_response_completed_) {
216 defer_on_response_completed_ = false;
217 set_controller(std::move(controller));
195 deferred_run_loop_->Quit(); 218 deferred_run_loop_->Quit();
196 response_complete_run_loop_.Quit(); 219 return;
220 }
221
222 controller->Resume();
197 } 223 }
198 224
199 void TestResourceHandler::OnDataDownloaded(int bytes_downloaded) { 225 void TestResourceHandler::OnDataDownloaded(int bytes_downloaded) {
200 EXPECT_TRUE(expect_on_data_downloaded_); 226 EXPECT_TRUE(expect_on_data_downloaded_);
201 total_bytes_downloaded_ += bytes_downloaded; 227 total_bytes_downloaded_ += bytes_downloaded;
202 } 228 }
203 229
204 void TestResourceHandler::Resume() { 230 void TestResourceHandler::Resume() {
205 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 231 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
206 controller_->Resume(); 232 ResourceHandler::Resume();
207 } 233 }
208 234
209 void TestResourceHandler::CancelWithError(net::Error net_error) { 235 void TestResourceHandler::CancelWithError(net::Error net_error) {
210 ScopedCallDepthTracker call_depth_tracker(&call_depth_); 236 ScopedCallDepthTracker call_depth_tracker(&call_depth_);
211 canceled_ = true; 237 canceled_ = true;
212 controller_->CancelWithError(net_error); 238 ResourceHandler::CancelWithError(net_error);
213 } 239 }
214 240
215 void TestResourceHandler::SetBufferSize(int buffer_size) { 241 void TestResourceHandler::SetBufferSize(int buffer_size) {
216 buffer_ = new net::IOBuffer(buffer_size); 242 buffer_ = new net::IOBuffer(buffer_size);
217 buffer_size_ = buffer_size; 243 buffer_size_ = buffer_size;
218 memset(buffer_->data(), '\0', buffer_size); 244 memset(buffer_->data(), '\0', buffer_size);
219 } 245 }
220 246
221 void TestResourceHandler::WaitUntilDeferred() { 247 void TestResourceHandler::WaitUntilDeferred() {
222 deferred_run_loop_->Run(); 248 deferred_run_loop_->Run();
223 deferred_run_loop_.reset(new base::RunLoop()); 249 deferred_run_loop_.reset(new base::RunLoop());
224 } 250 }
225 251
226 void TestResourceHandler::WaitUntilResponseComplete() { 252 void TestResourceHandler::WaitUntilResponseComplete() {
227 response_complete_run_loop_.Run(); 253 response_complete_run_loop_.Run();
228 } 254 }
229 255
230 } // namespace content 256 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698