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 "content/browser/appcache/appcache_request_handler.h" | 5 #include "content/browser/appcache/appcache_request_handler.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 |
8 #include <stack> | 9 #include <stack> |
9 #include <string> | 10 #include <string> |
10 #include <utility> | 11 #include <utility> |
11 #include <vector> | 12 #include <vector> |
12 | 13 |
13 #include "base/bind.h" | 14 #include "base/bind.h" |
14 #include "base/bind_helpers.h" | 15 #include "base/bind_helpers.h" |
15 #include "base/callback.h" | 16 #include "base/callback.h" |
16 #include "base/location.h" | 17 #include "base/location.h" |
17 #include "base/macros.h" | 18 #include "base/macros.h" |
| 19 #include "base/memory/ptr_util.h" |
18 #include "base/memory/weak_ptr.h" | 20 #include "base/memory/weak_ptr.h" |
19 #include "base/single_thread_task_runner.h" | 21 #include "base/single_thread_task_runner.h" |
20 #include "base/synchronization/waitable_event.h" | 22 #include "base/synchronization/waitable_event.h" |
21 #include "base/thread_task_runner_handle.h" | 23 #include "base/thread_task_runner_handle.h" |
22 #include "base/threading/thread.h" | 24 #include "base/threading/thread.h" |
23 #include "content/browser/appcache/appcache.h" | 25 #include "content/browser/appcache/appcache.h" |
24 #include "content/browser/appcache/appcache_backend_impl.h" | 26 #include "content/browser/appcache/appcache_backend_impl.h" |
25 #include "content/browser/appcache/appcache_url_request_job.h" | 27 #include "content/browser/appcache/appcache_url_request_job.h" |
26 #include "content/browser/appcache/mock_appcache_policy.h" | 28 #include "content/browser/appcache/mock_appcache_policy.h" |
27 #include "content/browser/appcache/mock_appcache_service.h" | 29 #include "content/browser/appcache/mock_appcache_service.h" |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
113 bool has_response_info_; | 115 bool has_response_info_; |
114 net::HttpResponseInfo response_info_; | 116 net::HttpResponseInfo response_info_; |
115 }; | 117 }; |
116 | 118 |
117 class MockURLRequestJobFactory : public net::URLRequestJobFactory { | 119 class MockURLRequestJobFactory : public net::URLRequestJobFactory { |
118 public: | 120 public: |
119 MockURLRequestJobFactory() {} | 121 MockURLRequestJobFactory() {} |
120 | 122 |
121 ~MockURLRequestJobFactory() override { DCHECK(!job_); } | 123 ~MockURLRequestJobFactory() override { DCHECK(!job_); } |
122 | 124 |
123 void SetJob(scoped_ptr<net::URLRequestJob> job) { job_ = std::move(job); } | 125 void SetJob(std::unique_ptr<net::URLRequestJob> job) { |
| 126 job_ = std::move(job); |
| 127 } |
124 | 128 |
125 net::URLRequestJob* MaybeCreateJobWithProtocolHandler( | 129 net::URLRequestJob* MaybeCreateJobWithProtocolHandler( |
126 const std::string& scheme, | 130 const std::string& scheme, |
127 net::URLRequest* request, | 131 net::URLRequest* request, |
128 net::NetworkDelegate* network_delegate) const override { | 132 net::NetworkDelegate* network_delegate) const override { |
129 if (job_) | 133 if (job_) |
130 return job_.release(); | 134 return job_.release(); |
131 | 135 |
132 // Some of these tests trigger UpdateJobs which start URLRequests. | 136 // Some of these tests trigger UpdateJobs which start URLRequests. |
133 // We short circuit those be returning error jobs. | 137 // We short circuit those be returning error jobs. |
(...skipping 20 matching lines...) Expand all Loading... |
154 | 158 |
155 bool IsHandledURL(const GURL& url) const override { | 159 bool IsHandledURL(const GURL& url) const override { |
156 return url.SchemeIs("http"); | 160 return url.SchemeIs("http"); |
157 } | 161 } |
158 | 162 |
159 bool IsSafeRedirectTarget(const GURL& location) const override { | 163 bool IsSafeRedirectTarget(const GURL& location) const override { |
160 return false; | 164 return false; |
161 } | 165 } |
162 | 166 |
163 private: | 167 private: |
164 mutable scoped_ptr<net::URLRequestJob> job_; | 168 mutable std::unique_ptr<net::URLRequestJob> job_; |
165 }; | 169 }; |
166 | 170 |
167 static void SetUpTestCase() { | 171 static void SetUpTestCase() { |
168 io_thread_.reset(new base::Thread("AppCacheRequestHandlerTest Thread")); | 172 io_thread_.reset(new base::Thread("AppCacheRequestHandlerTest Thread")); |
169 base::Thread::Options options(base::MessageLoop::TYPE_IO, 0); | 173 base::Thread::Options options(base::MessageLoop::TYPE_IO, 0); |
170 io_thread_->StartWithOptions(options); | 174 io_thread_->StartWithOptions(options); |
171 } | 175 } |
172 | 176 |
173 static void TearDownTestCase() { | 177 static void TearDownTestCase() { |
174 io_thread_.reset(NULL); | 178 io_thread_.reset(NULL); |
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
273 EXPECT_FALSE(job_->is_waiting()); | 277 EXPECT_FALSE(job_->is_waiting()); |
274 EXPECT_TRUE(job_->is_delivering_network_response()); | 278 EXPECT_TRUE(job_->is_delivering_network_response()); |
275 | 279 |
276 int64_t cache_id = kAppCacheNoCacheId; | 280 int64_t cache_id = kAppCacheNoCacheId; |
277 GURL manifest_url; | 281 GURL manifest_url; |
278 handler_->GetExtraResponseInfo(&cache_id, &manifest_url); | 282 handler_->GetExtraResponseInfo(&cache_id, &manifest_url); |
279 EXPECT_EQ(kAppCacheNoCacheId, cache_id); | 283 EXPECT_EQ(kAppCacheNoCacheId, cache_id); |
280 EXPECT_EQ(GURL(), manifest_url); | 284 EXPECT_EQ(GURL(), manifest_url); |
281 EXPECT_EQ(0, handler_->found_group_id_); | 285 EXPECT_EQ(0, handler_->found_group_id_); |
282 | 286 |
283 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 287 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
284 handler_->MaybeLoadFallbackForRedirect( | 288 handler_->MaybeLoadFallbackForRedirect( |
285 request_.get(), request_->context()->network_delegate(), | 289 request_.get(), request_->context()->network_delegate(), |
286 GURL("http://blah/redirect"))); | 290 GURL("http://blah/redirect"))); |
287 EXPECT_FALSE(fallback_job); | 291 EXPECT_FALSE(fallback_job); |
288 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 292 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
289 request_.get(), request_->context()->network_delegate())); | 293 request_.get(), request_->context()->network_delegate())); |
290 EXPECT_FALSE(fallback_job); | 294 EXPECT_FALSE(fallback_job); |
291 | 295 |
292 EXPECT_TRUE(host_->preferred_manifest_url().is_empty()); | 296 EXPECT_TRUE(host_->preferred_manifest_url().is_empty()); |
293 | 297 |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
326 EXPECT_FALSE(job_->is_waiting()); | 330 EXPECT_FALSE(job_->is_waiting()); |
327 EXPECT_TRUE(job_->is_delivering_appcache_response()); | 331 EXPECT_TRUE(job_->is_delivering_appcache_response()); |
328 | 332 |
329 int64_t cache_id = kAppCacheNoCacheId; | 333 int64_t cache_id = kAppCacheNoCacheId; |
330 GURL manifest_url; | 334 GURL manifest_url; |
331 handler_->GetExtraResponseInfo(&cache_id, &manifest_url); | 335 handler_->GetExtraResponseInfo(&cache_id, &manifest_url); |
332 EXPECT_EQ(1, cache_id); | 336 EXPECT_EQ(1, cache_id); |
333 EXPECT_EQ(GURL("http://blah/manifest/"), manifest_url); | 337 EXPECT_EQ(GURL("http://blah/manifest/"), manifest_url); |
334 EXPECT_EQ(2, handler_->found_group_id_); | 338 EXPECT_EQ(2, handler_->found_group_id_); |
335 | 339 |
336 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 340 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
337 handler_->MaybeLoadFallbackForResponse( | 341 handler_->MaybeLoadFallbackForResponse( |
338 request_.get(), request_->context()->network_delegate())); | 342 request_.get(), request_->context()->network_delegate())); |
339 EXPECT_FALSE(fallback_job); | 343 EXPECT_FALSE(fallback_job); |
340 | 344 |
341 EXPECT_EQ(GURL("http://blah/manifest/"), | 345 EXPECT_EQ(GURL("http://blah/manifest/"), |
342 host_->preferred_manifest_url()); | 346 host_->preferred_manifest_url()); |
343 | 347 |
344 TestFinished(); | 348 TestFinished(); |
345 } | 349 } |
346 | 350 |
(...skipping 20 matching lines...) Expand all Loading... |
367 job_.reset(handler_->MaybeLoadResource( | 371 job_.reset(handler_->MaybeLoadResource( |
368 request_.get(), request_->context()->network_delegate())); | 372 request_.get(), request_->context()->network_delegate())); |
369 EXPECT_TRUE(job_.get()); | 373 EXPECT_TRUE(job_.get()); |
370 EXPECT_TRUE(job_->is_waiting()); | 374 EXPECT_TRUE(job_->is_waiting()); |
371 | 375 |
372 // We have to wait for completion of storage->FindResponseForMainRequest. | 376 // We have to wait for completion of storage->FindResponseForMainRequest. |
373 ScheduleNextTask(); | 377 ScheduleNextTask(); |
374 } | 378 } |
375 | 379 |
376 void SimulateResponseCode(int response_code) { | 380 void SimulateResponseCode(int response_code) { |
377 job_factory_->SetJob(make_scoped_ptr(new MockURLRequestJob( | 381 job_factory_->SetJob(base::WrapUnique(new MockURLRequestJob( |
378 request_.get(), request_->context()->network_delegate(), | 382 request_.get(), request_->context()->network_delegate(), |
379 response_code))); | 383 response_code))); |
380 request_->Start(); | 384 request_->Start(); |
381 // All our simulation needs to satisfy are the following two DCHECKs | 385 // All our simulation needs to satisfy are the following two DCHECKs |
382 DCHECK(request_->status().is_success()); | 386 DCHECK(request_->status().is_success()); |
383 DCHECK_EQ(response_code, request_->GetResponseCode()); | 387 DCHECK_EQ(response_code, request_->GetResponseCode()); |
384 } | 388 } |
385 | 389 |
386 void SimulateResponseInfo(const net::HttpResponseInfo& info) { | 390 void SimulateResponseInfo(const net::HttpResponseInfo& info) { |
387 job_factory_->SetJob(make_scoped_ptr(new MockURLRequestJob( | 391 job_factory_->SetJob(base::WrapUnique(new MockURLRequestJob( |
388 request_.get(), request_->context()->network_delegate(), info))); | 392 request_.get(), request_->context()->network_delegate(), info))); |
389 request_->Start(); | 393 request_->Start(); |
390 } | 394 } |
391 | 395 |
392 void Verify_MainResource_Fallback() { | 396 void Verify_MainResource_Fallback() { |
393 EXPECT_FALSE(job_->is_waiting()); | 397 EXPECT_FALSE(job_->is_waiting()); |
394 EXPECT_TRUE(job_->is_delivering_network_response()); | 398 EXPECT_TRUE(job_->is_delivering_network_response()); |
395 | 399 |
396 // The handler expects to the job to tell it that the request is going to | 400 // The handler expects to the job to tell it that the request is going to |
397 // be restarted before it sees the next request. | 401 // be restarted before it sees the next request. |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
524 handler_.reset(host_->CreateRequestHandler(request_.get(), | 528 handler_.reset(host_->CreateRequestHandler(request_.get(), |
525 RESOURCE_TYPE_SUB_RESOURCE, | 529 RESOURCE_TYPE_SUB_RESOURCE, |
526 false)); | 530 false)); |
527 EXPECT_TRUE(handler_.get()); | 531 EXPECT_TRUE(handler_.get()); |
528 | 532 |
529 job_.reset(handler_->MaybeLoadResource( | 533 job_.reset(handler_->MaybeLoadResource( |
530 request_.get(), request_->context()->network_delegate())); | 534 request_.get(), request_->context()->network_delegate())); |
531 EXPECT_TRUE(job_.get()); | 535 EXPECT_TRUE(job_.get()); |
532 EXPECT_TRUE(job_->is_delivering_error_response()); | 536 EXPECT_TRUE(job_->is_delivering_error_response()); |
533 | 537 |
534 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 538 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
535 handler_->MaybeLoadFallbackForRedirect( | 539 handler_->MaybeLoadFallbackForRedirect( |
536 request_.get(), request_->context()->network_delegate(), | 540 request_.get(), request_->context()->network_delegate(), |
537 GURL("http://blah/redirect"))); | 541 GURL("http://blah/redirect"))); |
538 EXPECT_FALSE(fallback_job); | 542 EXPECT_FALSE(fallback_job); |
539 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 543 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
540 request_.get(), request_->context()->network_delegate())); | 544 request_.get(), request_->context()->network_delegate())); |
541 EXPECT_FALSE(fallback_job); | 545 EXPECT_FALSE(fallback_job); |
542 | 546 |
543 TestFinished(); | 547 TestFinished(); |
544 } | 548 } |
(...skipping 14 matching lines...) Expand all Loading... |
559 EXPECT_TRUE(handler_.get()); | 563 EXPECT_TRUE(handler_.get()); |
560 job_.reset(handler_->MaybeLoadResource( | 564 job_.reset(handler_->MaybeLoadResource( |
561 request_.get(), request_->context()->network_delegate())); | 565 request_.get(), request_->context()->network_delegate())); |
562 EXPECT_TRUE(job_.get()); | 566 EXPECT_TRUE(job_.get()); |
563 EXPECT_TRUE(job_->is_waiting()); | 567 EXPECT_TRUE(job_->is_waiting()); |
564 | 568 |
565 host_->FinishCacheSelection(cache.get(), NULL); | 569 host_->FinishCacheSelection(cache.get(), NULL); |
566 EXPECT_FALSE(job_->is_waiting()); | 570 EXPECT_FALSE(job_->is_waiting()); |
567 EXPECT_TRUE(job_->is_delivering_error_response()); | 571 EXPECT_TRUE(job_->is_delivering_error_response()); |
568 | 572 |
569 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 573 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
570 handler_->MaybeLoadFallbackForRedirect( | 574 handler_->MaybeLoadFallbackForRedirect( |
571 request_.get(), request_->context()->network_delegate(), | 575 request_.get(), request_->context()->network_delegate(), |
572 GURL("http://blah/redirect"))); | 576 GURL("http://blah/redirect"))); |
573 EXPECT_FALSE(fallback_job); | 577 EXPECT_FALSE(fallback_job); |
574 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 578 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
575 request_.get(), request_->context()->network_delegate())); | 579 request_.get(), request_->context()->network_delegate())); |
576 EXPECT_FALSE(fallback_job); | 580 EXPECT_FALSE(fallback_job); |
577 | 581 |
578 TestFinished(); | 582 TestFinished(); |
579 } | 583 } |
(...skipping 10 matching lines...) Expand all Loading... |
590 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); | 594 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); |
591 handler_.reset(host_->CreateRequestHandler(request_.get(), | 595 handler_.reset(host_->CreateRequestHandler(request_.get(), |
592 RESOURCE_TYPE_SUB_RESOURCE, | 596 RESOURCE_TYPE_SUB_RESOURCE, |
593 false)); | 597 false)); |
594 EXPECT_TRUE(handler_.get()); | 598 EXPECT_TRUE(handler_.get()); |
595 job_.reset(handler_->MaybeLoadResource( | 599 job_.reset(handler_->MaybeLoadResource( |
596 request_.get(), request_->context()->network_delegate())); | 600 request_.get(), request_->context()->network_delegate())); |
597 EXPECT_TRUE(job_.get()); | 601 EXPECT_TRUE(job_.get()); |
598 EXPECT_TRUE(job_->is_delivering_appcache_response()); | 602 EXPECT_TRUE(job_->is_delivering_appcache_response()); |
599 | 603 |
600 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 604 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
601 handler_->MaybeLoadFallbackForRedirect( | 605 handler_->MaybeLoadFallbackForRedirect( |
602 request_.get(), request_->context()->network_delegate(), | 606 request_.get(), request_->context()->network_delegate(), |
603 GURL("http://blah/redirect"))); | 607 GURL("http://blah/redirect"))); |
604 EXPECT_FALSE(fallback_job); | 608 EXPECT_FALSE(fallback_job); |
605 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 609 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
606 request_.get(), request_->context()->network_delegate())); | 610 request_.get(), request_->context()->network_delegate())); |
607 EXPECT_FALSE(fallback_job); | 611 EXPECT_FALSE(fallback_job); |
608 | 612 |
609 TestFinished(); | 613 TestFinished(); |
610 } | 614 } |
(...skipping 17 matching lines...) Expand all Loading... |
628 job_.reset(handler_->MaybeLoadResource( | 632 job_.reset(handler_->MaybeLoadResource( |
629 request_.get(), request_->context()->network_delegate())); | 633 request_.get(), request_->context()->network_delegate())); |
630 EXPECT_FALSE(job_.get()); | 634 EXPECT_FALSE(job_.get()); |
631 | 635 |
632 job_.reset(handler_->MaybeLoadFallbackForRedirect( | 636 job_.reset(handler_->MaybeLoadFallbackForRedirect( |
633 request_.get(), request_->context()->network_delegate(), | 637 request_.get(), request_->context()->network_delegate(), |
634 GURL("http://not_blah/redirect"))); | 638 GURL("http://not_blah/redirect"))); |
635 EXPECT_TRUE(job_.get()); | 639 EXPECT_TRUE(job_.get()); |
636 EXPECT_TRUE(job_->is_delivering_appcache_response()); | 640 EXPECT_TRUE(job_->is_delivering_appcache_response()); |
637 | 641 |
638 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 642 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
639 handler_->MaybeLoadFallbackForResponse( | 643 handler_->MaybeLoadFallbackForResponse( |
640 request_.get(), request_->context()->network_delegate())); | 644 request_.get(), request_->context()->network_delegate())); |
641 EXPECT_FALSE(fallback_job); | 645 EXPECT_FALSE(fallback_job); |
642 | 646 |
643 TestFinished(); | 647 TestFinished(); |
644 } | 648 } |
645 | 649 |
646 // SubResource_NoRedirectFallback ----------------------------- | 650 // SubResource_NoRedirectFallback ----------------------------- |
647 | 651 |
648 void SubResource_NoRedirectFallback() { | 652 void SubResource_NoRedirectFallback() { |
649 // Redirects to resources in the same-origin are not subject to | 653 // Redirects to resources in the same-origin are not subject to |
650 // fallback namespaces. | 654 // fallback namespaces. |
651 host_->AssociateCompleteCache(MakeNewCache()); | 655 host_->AssociateCompleteCache(MakeNewCache()); |
652 | 656 |
653 mock_storage()->SimulateFindSubResource( | 657 mock_storage()->SimulateFindSubResource( |
654 AppCacheEntry(), AppCacheEntry(AppCacheEntry::EXPLICIT, 1), false); | 658 AppCacheEntry(), AppCacheEntry(AppCacheEntry::EXPLICIT, 1), false); |
655 | 659 |
656 request_ = empty_context_.CreateRequest( | 660 request_ = empty_context_.CreateRequest( |
657 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); | 661 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); |
658 handler_.reset(host_->CreateRequestHandler(request_.get(), | 662 handler_.reset(host_->CreateRequestHandler(request_.get(), |
659 RESOURCE_TYPE_SUB_RESOURCE, | 663 RESOURCE_TYPE_SUB_RESOURCE, |
660 false)); | 664 false)); |
661 EXPECT_TRUE(handler_.get()); | 665 EXPECT_TRUE(handler_.get()); |
662 job_.reset(handler_->MaybeLoadResource( | 666 job_.reset(handler_->MaybeLoadResource( |
663 request_.get(), request_->context()->network_delegate())); | 667 request_.get(), request_->context()->network_delegate())); |
664 EXPECT_FALSE(job_.get()); | 668 EXPECT_FALSE(job_.get()); |
665 | 669 |
666 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 670 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
667 handler_->MaybeLoadFallbackForRedirect( | 671 handler_->MaybeLoadFallbackForRedirect( |
668 request_.get(), request_->context()->network_delegate(), | 672 request_.get(), request_->context()->network_delegate(), |
669 GURL("http://blah/redirect"))); | 673 GURL("http://blah/redirect"))); |
670 EXPECT_FALSE(fallback_job); | 674 EXPECT_FALSE(fallback_job); |
671 | 675 |
672 SimulateResponseCode(200); | 676 SimulateResponseCode(200); |
673 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 677 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
674 request_.get(), request_->context()->network_delegate())); | 678 request_.get(), request_->context()->network_delegate())); |
675 EXPECT_FALSE(fallback_job); | 679 EXPECT_FALSE(fallback_job); |
676 | 680 |
(...skipping 14 matching lines...) Expand all Loading... |
691 request_ = empty_context_.CreateRequest( | 695 request_ = empty_context_.CreateRequest( |
692 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); | 696 GURL("http://blah/"), net::DEFAULT_PRIORITY, &delegate_); |
693 handler_.reset(host_->CreateRequestHandler(request_.get(), | 697 handler_.reset(host_->CreateRequestHandler(request_.get(), |
694 RESOURCE_TYPE_SUB_RESOURCE, | 698 RESOURCE_TYPE_SUB_RESOURCE, |
695 false)); | 699 false)); |
696 EXPECT_TRUE(handler_.get()); | 700 EXPECT_TRUE(handler_.get()); |
697 job_.reset(handler_->MaybeLoadResource( | 701 job_.reset(handler_->MaybeLoadResource( |
698 request_.get(), request_->context()->network_delegate())); | 702 request_.get(), request_->context()->network_delegate())); |
699 EXPECT_FALSE(job_.get()); | 703 EXPECT_FALSE(job_.get()); |
700 | 704 |
701 scoped_ptr<AppCacheURLRequestJob> fallback_job( | 705 std::unique_ptr<AppCacheURLRequestJob> fallback_job( |
702 handler_->MaybeLoadFallbackForRedirect( | 706 handler_->MaybeLoadFallbackForRedirect( |
703 request_.get(), request_->context()->network_delegate(), | 707 request_.get(), request_->context()->network_delegate(), |
704 GURL("http://blah/redirect"))); | 708 GURL("http://blah/redirect"))); |
705 EXPECT_FALSE(fallback_job); | 709 EXPECT_FALSE(fallback_job); |
706 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( | 710 fallback_job.reset(handler_->MaybeLoadFallbackForResponse( |
707 request_.get(), request_->context()->network_delegate())); | 711 request_.get(), request_->context()->network_delegate())); |
708 EXPECT_FALSE(fallback_job); | 712 EXPECT_FALSE(fallback_job); |
709 | 713 |
710 TestFinished(); | 714 TestFinished(); |
711 } | 715 } |
(...skipping 217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
929 group->AddCache(cache); | 933 group->AddCache(cache); |
930 return cache; | 934 return cache; |
931 } | 935 } |
932 | 936 |
933 MockAppCacheStorage* mock_storage() { | 937 MockAppCacheStorage* mock_storage() { |
934 return reinterpret_cast<MockAppCacheStorage*>(mock_service_->storage()); | 938 return reinterpret_cast<MockAppCacheStorage*>(mock_service_->storage()); |
935 } | 939 } |
936 | 940 |
937 // Data members -------------------------------------------------- | 941 // Data members -------------------------------------------------- |
938 | 942 |
939 scoped_ptr<base::WaitableEvent> test_finished_event_; | 943 std::unique_ptr<base::WaitableEvent> test_finished_event_; |
940 std::stack<base::Closure> task_stack_; | 944 std::stack<base::Closure> task_stack_; |
941 scoped_ptr<MockAppCacheService> mock_service_; | 945 std::unique_ptr<MockAppCacheService> mock_service_; |
942 scoped_ptr<AppCacheBackendImpl> backend_impl_; | 946 std::unique_ptr<AppCacheBackendImpl> backend_impl_; |
943 scoped_ptr<MockFrontend> mock_frontend_; | 947 std::unique_ptr<MockFrontend> mock_frontend_; |
944 scoped_ptr<MockAppCachePolicy> mock_policy_; | 948 std::unique_ptr<MockAppCachePolicy> mock_policy_; |
945 AppCacheHost* host_; | 949 AppCacheHost* host_; |
946 net::URLRequestContext empty_context_; | 950 net::URLRequestContext empty_context_; |
947 scoped_ptr<MockURLRequestJobFactory> job_factory_; | 951 std::unique_ptr<MockURLRequestJobFactory> job_factory_; |
948 MockURLRequestDelegate delegate_; | 952 MockURLRequestDelegate delegate_; |
949 scoped_ptr<net::URLRequest> request_; | 953 std::unique_ptr<net::URLRequest> request_; |
950 scoped_ptr<AppCacheRequestHandler> handler_; | 954 std::unique_ptr<AppCacheRequestHandler> handler_; |
951 scoped_ptr<AppCacheURLRequestJob> job_; | 955 std::unique_ptr<AppCacheURLRequestJob> job_; |
952 | 956 |
953 static scoped_ptr<base::Thread> io_thread_; | 957 static std::unique_ptr<base::Thread> io_thread_; |
954 }; | 958 }; |
955 | 959 |
956 // static | 960 // static |
957 scoped_ptr<base::Thread> AppCacheRequestHandlerTest::io_thread_; | 961 std::unique_ptr<base::Thread> AppCacheRequestHandlerTest::io_thread_; |
958 | 962 |
959 TEST_F(AppCacheRequestHandlerTest, MainResource_Miss) { | 963 TEST_F(AppCacheRequestHandlerTest, MainResource_Miss) { |
960 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Miss); | 964 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Miss); |
961 } | 965 } |
962 | 966 |
963 TEST_F(AppCacheRequestHandlerTest, MainResource_Hit) { | 967 TEST_F(AppCacheRequestHandlerTest, MainResource_Hit) { |
964 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Hit); | 968 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Hit); |
965 } | 969 } |
966 | 970 |
967 TEST_F(AppCacheRequestHandlerTest, MainResource_Fallback) { | 971 TEST_F(AppCacheRequestHandlerTest, MainResource_Fallback) { |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1024 | 1028 |
1025 TEST_F(AppCacheRequestHandlerTest, WorkerRequest) { | 1029 TEST_F(AppCacheRequestHandlerTest, WorkerRequest) { |
1026 RunTestOnIOThread(&AppCacheRequestHandlerTest::WorkerRequest); | 1030 RunTestOnIOThread(&AppCacheRequestHandlerTest::WorkerRequest); |
1027 } | 1031 } |
1028 | 1032 |
1029 TEST_F(AppCacheRequestHandlerTest, MainResource_Blocked) { | 1033 TEST_F(AppCacheRequestHandlerTest, MainResource_Blocked) { |
1030 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Blocked); | 1034 RunTestOnIOThread(&AppCacheRequestHandlerTest::MainResource_Blocked); |
1031 } | 1035 } |
1032 | 1036 |
1033 } // namespace content | 1037 } // namespace content |
OLD | NEW |