OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "net/test/embedded_test_server/embedded_test_server.h" | 5 #include "net/test/embedded_test_server/embedded_test_server.h" |
6 | 6 |
7 #include "base/path_service.h" | 7 #include "base/path_service.h" |
8 #include "base/strings/stringprintf.h" | 8 #include "base/strings/stringprintf.h" |
9 #include "base/threading/thread.h" | 9 #include "base/threading/thread.h" |
10 #include "net/http/http_response_headers.h" | 10 #include "net/http/http_response_headers.h" |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
48 : num_responses_received_(0), | 48 : num_responses_received_(0), |
49 num_responses_expected_(0), | 49 num_responses_expected_(0), |
50 io_thread_("io_thread") { | 50 io_thread_("io_thread") { |
51 } | 51 } |
52 | 52 |
53 void SetUp() override { | 53 void SetUp() override { |
54 base::Thread::Options thread_options; | 54 base::Thread::Options thread_options; |
55 thread_options.message_loop_type = base::MessageLoop::TYPE_IO; | 55 thread_options.message_loop_type = base::MessageLoop::TYPE_IO; |
56 ASSERT_TRUE(io_thread_.StartWithOptions(thread_options)); | 56 ASSERT_TRUE(io_thread_.StartWithOptions(thread_options)); |
57 | 57 |
58 request_context_getter_ = new TestURLRequestContextGetter( | 58 request_context_getter_ = |
59 io_thread_.message_loop_proxy()); | 59 new TestURLRequestContextGetter(io_thread_.task_runner()); |
60 | 60 |
61 server_.reset(new EmbeddedTestServer); | 61 server_.reset(new EmbeddedTestServer); |
62 ASSERT_TRUE(server_->InitializeAndWaitUntilReady()); | 62 ASSERT_TRUE(server_->InitializeAndWaitUntilReady()); |
63 } | 63 } |
64 | 64 |
65 void TearDown() override { | 65 void TearDown() override { |
66 ASSERT_TRUE(server_->ShutdownAndWaitUntilComplete()); | 66 ASSERT_TRUE(server_->ShutdownAndWaitUntilComplete()); |
67 } | 67 } |
68 | 68 |
69 // URLFetcherDelegate override. | 69 // URLFetcherDelegate override. |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
254 : message_loop_present_on_initialize_(message_loop_present_on_initialize), | 254 : message_loop_present_on_initialize_(message_loop_present_on_initialize), |
255 message_loop_present_on_shutdown_(message_loop_present_on_shutdown) {} | 255 message_loop_present_on_shutdown_(message_loop_present_on_shutdown) {} |
256 | 256 |
257 // base::PlatformThread::Delegate: | 257 // base::PlatformThread::Delegate: |
258 void ThreadMain() override { | 258 void ThreadMain() override { |
259 scoped_refptr<base::SingleThreadTaskRunner> io_thread_runner; | 259 scoped_refptr<base::SingleThreadTaskRunner> io_thread_runner; |
260 base::Thread io_thread("io_thread"); | 260 base::Thread io_thread("io_thread"); |
261 base::Thread::Options thread_options; | 261 base::Thread::Options thread_options; |
262 thread_options.message_loop_type = base::MessageLoop::TYPE_IO; | 262 thread_options.message_loop_type = base::MessageLoop::TYPE_IO; |
263 ASSERT_TRUE(io_thread.StartWithOptions(thread_options)); | 263 ASSERT_TRUE(io_thread.StartWithOptions(thread_options)); |
264 io_thread_runner = io_thread.message_loop_proxy(); | 264 io_thread_runner = io_thread.task_runner(); |
265 | 265 |
266 scoped_ptr<base::MessageLoop> loop; | 266 scoped_ptr<base::MessageLoop> loop; |
267 if (message_loop_present_on_initialize_) | 267 if (message_loop_present_on_initialize_) |
268 loop.reset(new base::MessageLoopForIO); | 268 loop.reset(new base::MessageLoopForIO); |
269 | 269 |
270 // Create the test server instance. | 270 // Create the test server instance. |
271 EmbeddedTestServer server; | 271 EmbeddedTestServer server; |
272 base::FilePath src_dir; | 272 base::FilePath src_dir; |
273 ASSERT_TRUE(PathService::Get(base::DIR_SOURCE_ROOT, &src_dir)); | 273 ASSERT_TRUE(PathService::Get(base::DIR_SOURCE_ROOT, &src_dir)); |
274 ASSERT_TRUE(server.InitializeAndWaitUntilReady()); | 274 ASSERT_TRUE(server.InitializeAndWaitUntilReady()); |
275 | 275 |
276 // Make a request and wait for the reply. | 276 // Make a request and wait for the reply. |
277 if (!loop) | 277 if (!loop) |
278 loop.reset(new base::MessageLoopForIO); | 278 loop.reset(new base::MessageLoopForIO); |
279 | 279 |
280 scoped_ptr<URLFetcher> fetcher = | 280 scoped_ptr<URLFetcher> fetcher = |
281 URLFetcher::Create(server.GetURL("/test?q=foo"), URLFetcher::GET, this); | 281 URLFetcher::Create(server.GetURL("/test?q=foo"), URLFetcher::GET, this); |
282 fetcher->SetRequestContext( | 282 fetcher->SetRequestContext( |
283 new TestURLRequestContextGetter(loop->message_loop_proxy())); | 283 new TestURLRequestContextGetter(loop->task_runner())); |
284 fetcher->Start(); | 284 fetcher->Start(); |
285 loop->Run(); | 285 loop->Run(); |
286 fetcher.reset(); | 286 fetcher.reset(); |
287 | 287 |
288 // Shut down. | 288 // Shut down. |
289 if (message_loop_present_on_shutdown_) | 289 if (message_loop_present_on_shutdown_) |
290 loop.reset(); | 290 loop.reset(); |
291 | 291 |
292 ASSERT_TRUE(server.ShutdownAndWaitUntilComplete()); | 292 ASSERT_TRUE(server.ShutdownAndWaitUntilComplete()); |
293 } | 293 } |
(...skipping 21 matching lines...) Expand all Loading... |
315 ASSERT_TRUE(base::PlatformThread::Create(0, &delegate, &thread_handle)); | 315 ASSERT_TRUE(base::PlatformThread::Create(0, &delegate, &thread_handle)); |
316 base::PlatformThread::Join(thread_handle); | 316 base::PlatformThread::Join(thread_handle); |
317 } | 317 } |
318 | 318 |
319 INSTANTIATE_TEST_CASE_P(EmbeddedTestServerThreadingTestInstantiation, | 319 INSTANTIATE_TEST_CASE_P(EmbeddedTestServerThreadingTestInstantiation, |
320 EmbeddedTestServerThreadingTest, | 320 EmbeddedTestServerThreadingTest, |
321 testing::Combine(testing::Bool(), testing::Bool())); | 321 testing::Combine(testing::Bool(), testing::Bool())); |
322 | 322 |
323 } // namespace test_server | 323 } // namespace test_server |
324 } // namespace net | 324 } // namespace net |
OLD | NEW |