OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 <string> | 5 #include <string> |
6 #include <set> | 6 #include <set> |
7 | 7 |
8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
9 #include "base/i18n/number_formatting.h" | 9 #include "base/i18n/number_formatting.h" |
10 #include "base/i18n/rtl.h" | 10 #include "base/i18n/rtl.h" |
(...skipping 13 matching lines...) Expand all Loading... |
24 #include "chrome/test/base/testing_profile.h" | 24 #include "chrome/test/base/testing_profile.h" |
25 #include "content/browser/browser_thread.h" | 25 #include "content/browser/browser_thread.h" |
26 #include "content/browser/download/download_create_info.h" | 26 #include "content/browser/download/download_create_info.h" |
27 #include "content/browser/download/download_file.h" | 27 #include "content/browser/download/download_file.h" |
28 #include "content/browser/download/download_file_manager.h" | 28 #include "content/browser/download/download_file_manager.h" |
29 #include "content/browser/download/download_item.h" | 29 #include "content/browser/download/download_item.h" |
30 #include "content/browser/download/download_manager.h" | 30 #include "content/browser/download/download_manager.h" |
31 #include "content/browser/download/download_status_updater.h" | 31 #include "content/browser/download/download_status_updater.h" |
32 #include "content/browser/download/mock_download_manager.h" | 32 #include "content/browser/download/mock_download_manager.h" |
33 #include "grit/generated_resources.h" | 33 #include "grit/generated_resources.h" |
| 34 #include "net/base/io_buffer.h" |
| 35 #include "net/base/mock_file_stream.h" |
34 #include "testing/gmock/include/gmock/gmock.h" | 36 #include "testing/gmock/include/gmock/gmock.h" |
35 #include "testing/gmock_mutant.h" | 37 #include "testing/gmock_mutant.h" |
36 #include "testing/gtest/include/gtest/gtest.h" | 38 #include "testing/gtest/include/gtest/gtest.h" |
37 #include "ui/base/l10n/l10n_util.h" | 39 #include "ui/base/l10n/l10n_util.h" |
38 #include "ui/base/text/bytes_formatting.h" | 40 #include "ui/base/text/bytes_formatting.h" |
39 | 41 |
40 class DownloadManagerTest : public TestingBrowserProcessTest { | 42 class DownloadManagerTest : public TestingBrowserProcessTest { |
41 public: | 43 public: |
42 static const char* kTestData; | 44 static const char* kTestData; |
43 static const size_t kTestDataLen; | 45 static const size_t kTestDataLen; |
(...skipping 17 matching lines...) Expand all Loading... |
61 download_manager_ = NULL; | 63 download_manager_ = NULL; |
62 download_manager_delegate_ = NULL; | 64 download_manager_delegate_ = NULL; |
63 profile_.reset(NULL); | 65 profile_.reset(NULL); |
64 message_loop_.RunAllPending(); | 66 message_loop_.RunAllPending(); |
65 } | 67 } |
66 | 68 |
67 void AddDownloadToFileManager(int id, DownloadFile* download_file) { | 69 void AddDownloadToFileManager(int id, DownloadFile* download_file) { |
68 file_manager()->downloads_[id] = download_file; | 70 file_manager()->downloads_[id] = download_file; |
69 } | 71 } |
70 | 72 |
71 void OnAllDataSaved(int32 download_id, int64 size, const std::string& hash) { | 73 void OnResponseCompleted(int32 download_id, int64 size, |
72 download_manager_->OnAllDataSaved(download_id, size, hash); | 74 const std::string& hash) { |
| 75 download_manager_->OnResponseCompleted(download_id, size, hash); |
73 } | 76 } |
74 | 77 |
75 void FileSelected(const FilePath& path, void* params) { | 78 void FileSelected(const FilePath& path, void* params) { |
76 download_manager_->FileSelected(path, params); | 79 download_manager_->FileSelected(path, params); |
77 } | 80 } |
78 | 81 |
79 void ContinueDownloadWithPath(DownloadItem* download, const FilePath& path) { | 82 void ContinueDownloadWithPath(DownloadItem* download, const FilePath& path) { |
80 download_manager_->ContinueDownloadWithPath(download, path); | 83 download_manager_->ContinueDownloadWithPath(download, path); |
81 } | 84 } |
82 | 85 |
| 86 void UpdateData(int32 id, const void* data, size_t length) { |
| 87 // We are passing ownership of this buffer to the download file manager. |
| 88 net::IOBuffer* io_buffer = new net::IOBuffer(length); |
| 89 // We need |AddRef()| because io_buffer is not a |scoped_refptr|, and we |
| 90 // will do a |Release()| in |UpdateDownload()|. |
| 91 io_buffer->AddRef(); |
| 92 memcpy(io_buffer->data(), data, length); |
| 93 |
| 94 { |
| 95 base::AutoLock auto_lock(download_buffer_.lock); |
| 96 |
| 97 download_buffer_.contents.push_back( |
| 98 std::make_pair(io_buffer, length)); |
| 99 } |
| 100 |
| 101 BrowserThread::PostTask( |
| 102 BrowserThread::FILE, FROM_HERE, |
| 103 NewRunnableMethod(file_manager_.get(), |
| 104 &DownloadFileManager::UpdateDownload, |
| 105 id, |
| 106 &download_buffer_)); |
| 107 |
| 108 message_loop_.RunAllPending(); |
| 109 } |
| 110 |
83 void OnDownloadError(int32 download_id, int64 size, int os_error) { | 111 void OnDownloadError(int32 download_id, int64 size, int os_error) { |
84 download_manager_->OnDownloadError(download_id, size, os_error); | 112 download_manager_->OnDownloadError(download_id, size, os_error); |
85 } | 113 } |
86 | 114 |
87 // Get the download item with ID |id|. | 115 // Get the download item with ID |id|. |
88 DownloadItem* GetActiveDownloadItem(int32 id) { | 116 DownloadItem* GetActiveDownloadItem(int32 id) { |
89 if (ContainsKey(download_manager_->active_downloads_, id)) | 117 if (ContainsKey(download_manager_->active_downloads_, id)) |
90 return download_manager_->active_downloads_[id]; | 118 return download_manager_->active_downloads_[id]; |
91 return NULL; | 119 return NULL; |
92 } | 120 } |
93 | 121 |
94 protected: | 122 protected: |
95 DownloadStatusUpdater download_status_updater_; | 123 DownloadStatusUpdater download_status_updater_; |
96 scoped_ptr<TestingProfile> profile_; | 124 scoped_ptr<TestingProfile> profile_; |
97 scoped_refptr<ChromeDownloadManagerDelegate> download_manager_delegate_; | 125 scoped_refptr<ChromeDownloadManagerDelegate> download_manager_delegate_; |
98 scoped_refptr<DownloadManager> download_manager_; | 126 scoped_refptr<DownloadManager> download_manager_; |
99 scoped_refptr<DownloadFileManager> file_manager_; | 127 scoped_refptr<DownloadFileManager> file_manager_; |
100 MessageLoopForUI message_loop_; | 128 MessageLoopForUI message_loop_; |
101 BrowserThread ui_thread_; | 129 BrowserThread ui_thread_; |
102 BrowserThread file_thread_; | 130 BrowserThread file_thread_; |
| 131 DownloadBuffer download_buffer_; |
103 | 132 |
104 DownloadFileManager* file_manager() { | 133 DownloadFileManager* file_manager() { |
105 if (!file_manager_) { | 134 if (!file_manager_) { |
106 file_manager_ = new DownloadFileManager(NULL); | 135 file_manager_ = new DownloadFileManager(NULL); |
107 download_manager_->file_manager_ = file_manager_; | 136 download_manager_->file_manager_ = file_manager_; |
108 } | 137 } |
109 return file_manager_; | 138 return file_manager_; |
110 } | 139 } |
111 | 140 |
112 // Make sure download item |id| was set with correct safety state for | 141 // Make sure download item |id| was set with correct safety state for |
113 // given |is_dangerous_file| and |is_dangerous_url|. | 142 // given |is_dangerous_file| and |is_dangerous_url|. |
114 bool VerifySafetyState(bool is_dangerous_file, | 143 bool VerifySafetyState(bool is_dangerous_file, |
115 bool is_dangerous_url, | 144 bool is_dangerous_url, |
116 int id) { | 145 int id) { |
117 DownloadItem::SafetyState safety_state = | 146 DownloadItem::SafetyState safety_state = |
118 download_manager_->GetDownloadItem(id)->safety_state(); | 147 download_manager_->GetDownloadItem(id)->safety_state(); |
119 return (is_dangerous_file || is_dangerous_url) ? | 148 return (is_dangerous_file || is_dangerous_url) ? |
120 safety_state != DownloadItem::SAFE : safety_state == DownloadItem::SAFE; | 149 safety_state != DownloadItem::SAFE : safety_state == DownloadItem::SAFE; |
121 } | 150 } |
122 | 151 |
123 DISALLOW_COPY_AND_ASSIGN(DownloadManagerTest); | 152 DISALLOW_COPY_AND_ASSIGN(DownloadManagerTest); |
124 }; | 153 }; |
125 | 154 |
126 const char* DownloadManagerTest::kTestData = "a;sdlfalsdfjalsdkfjad"; | 155 const char* DownloadManagerTest::kTestData = "a;sdlfalsdfjalsdkfjad"; |
127 const size_t DownloadManagerTest::kTestDataLen = | 156 const size_t DownloadManagerTest::kTestDataLen = |
128 strlen(DownloadManagerTest::kTestData); | 157 strlen(DownloadManagerTest::kTestData); |
129 | 158 |
| 159 // A DownloadFile that we can inject errors into. Uses MockFileStream. |
| 160 // Note: This can't be in an anonymous namespace because it must be declared |
| 161 // as a friend of |DownloadFile| in order to access its private members. |
| 162 class DownloadFileWithMockStream : public DownloadFile { |
| 163 public: |
| 164 DownloadFileWithMockStream(DownloadCreateInfo* info, DownloadManager* manager) |
| 165 : DownloadFile(info, manager) { |
| 166 } |
| 167 virtual ~DownloadFileWithMockStream() { |
| 168 } |
| 169 |
| 170 void SetForcedError(int error) |
| 171 { |
| 172 testing::MockFileStream* mock_stream = |
| 173 static_cast<testing::MockFileStream *>(file_stream_.get()); |
| 174 mock_stream->set_forced_error(error); |
| 175 } |
| 176 |
| 177 protected: |
| 178 // This version creates a |MockFileStream| instead of a |FileStream|. |
| 179 virtual void CreateFileStream() { |
| 180 file_stream_.reset(new testing::MockFileStream); |
| 181 } |
| 182 }; |
| 183 |
130 namespace { | 184 namespace { |
131 | 185 |
132 const struct { | 186 const struct { |
133 const char* url; | 187 const char* url; |
134 const char* mime_type; | 188 const char* mime_type; |
135 bool save_as; | 189 bool save_as; |
136 bool prompt_for_download; | 190 bool prompt_for_download; |
137 bool expected_save_as; | 191 bool expected_save_as; |
138 } kStartDownloadCases[] = { | 192 } kStartDownloadCases[] = { |
139 { "http://www.foo.com/dont-open.html", | 193 { "http://www.foo.com/dont-open.html", |
(...skipping 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
378 DownloadItem* download = GetActiveDownloadItem(i); | 432 DownloadItem* download = GetActiveDownloadItem(i); |
379 ASSERT_TRUE(download != NULL); | 433 ASSERT_TRUE(download != NULL); |
380 if (kDownloadRenameCases[i].is_dangerous_file) | 434 if (kDownloadRenameCases[i].is_dangerous_file) |
381 download->MarkFileDangerous(); | 435 download->MarkFileDangerous(); |
382 if (kDownloadRenameCases[i].is_dangerous_url) | 436 if (kDownloadRenameCases[i].is_dangerous_url) |
383 download->MarkUrlDangerous(); | 437 download->MarkUrlDangerous(); |
384 | 438 |
385 int32* id_ptr = new int32; | 439 int32* id_ptr = new int32; |
386 *id_ptr = i; // Deleted in FileSelected(). | 440 *id_ptr = i; // Deleted in FileSelected(). |
387 if (kDownloadRenameCases[i].finish_before_rename) { | 441 if (kDownloadRenameCases[i].finish_before_rename) { |
388 OnAllDataSaved(i, 1024, std::string("fake_hash")); | 442 OnResponseCompleted(i, 1024, std::string("fake_hash")); |
389 message_loop_.RunAllPending(); | 443 message_loop_.RunAllPending(); |
390 FileSelected(new_path, id_ptr); | 444 FileSelected(new_path, id_ptr); |
391 } else { | 445 } else { |
392 FileSelected(new_path, id_ptr); | 446 FileSelected(new_path, id_ptr); |
393 message_loop_.RunAllPending(); | 447 message_loop_.RunAllPending(); |
394 OnAllDataSaved(i, 1024, std::string("fake_hash")); | 448 OnResponseCompleted(i, 1024, std::string("fake_hash")); |
395 } | 449 } |
396 | 450 |
397 message_loop_.RunAllPending(); | 451 message_loop_.RunAllPending(); |
398 EXPECT_TRUE(VerifySafetyState(kDownloadRenameCases[i].is_dangerous_file, | 452 EXPECT_TRUE(VerifySafetyState(kDownloadRenameCases[i].is_dangerous_file, |
399 kDownloadRenameCases[i].is_dangerous_url, | 453 kDownloadRenameCases[i].is_dangerous_url, |
400 i)); | 454 i)); |
401 } | 455 } |
402 } | 456 } |
403 | 457 |
404 TEST_F(DownloadManagerTest, DownloadInterruptTest) { | 458 TEST_F(DownloadManagerTest, DownloadInterruptTest) { |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
476 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); | 530 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); |
477 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); | 531 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
478 EXPECT_TRUE(observer->was_updated()); | 532 EXPECT_TRUE(observer->was_updated()); |
479 EXPECT_FALSE(observer->was_opened()); | 533 EXPECT_FALSE(observer->was_opened()); |
480 EXPECT_FALSE(download->file_externally_removed()); | 534 EXPECT_FALSE(download->file_externally_removed()); |
481 EXPECT_EQ(DownloadItem::INTERRUPTED, download->state()); | 535 EXPECT_EQ(DownloadItem::INTERRUPTED, download->state()); |
482 EXPECT_EQ(download->received_bytes(), error_size); | 536 EXPECT_EQ(download->received_bytes(), error_size); |
483 EXPECT_EQ(download->total_bytes(), static_cast<int64>(kTestDataLen)); | 537 EXPECT_EQ(download->total_bytes(), static_cast<int64>(kTestDataLen)); |
484 } | 538 } |
485 | 539 |
| 540 TEST_F(DownloadManagerTest, DownloadFileErrorTest) { |
| 541 using ::testing::_; |
| 542 using ::testing::CreateFunctor; |
| 543 using ::testing::Invoke; |
| 544 using ::testing::Return; |
| 545 |
| 546 // Normally, the download system takes ownership of info, and is |
| 547 // responsible for deleting it. In these unit tests, however, we |
| 548 // don't call the function that deletes it, so we do so ourselves. |
| 549 scoped_ptr<DownloadCreateInfo> info(new DownloadCreateInfo); |
| 550 int32 id = 0; |
| 551 info->download_id = id; |
| 552 info->prompt_user_for_save_location = false; |
| 553 info->url_chain.push_back(GURL()); |
| 554 info->total_bytes = static_cast<int64>(kTestDataLen * 3); |
| 555 FilePath path; |
| 556 ASSERT_TRUE(file_util::CreateTemporaryFile(&path)); |
| 557 testing::MockFileStream* mock_stream = new testing::MockFileStream; |
| 558 linked_ptr<net::FileStream> stream(mock_stream); |
| 559 ASSERT_EQ(0, mock_stream->Open( |
| 560 path, |
| 561 base::PLATFORM_FILE_OPEN_ALWAYS | base::PLATFORM_FILE_WRITE)); |
| 562 info->save_info.file_path = path; |
| 563 info->save_info.file_stream = stream; |
| 564 |
| 565 DownloadFileWithMockStream* download_file(new DownloadFileWithMockStream( |
| 566 info.get(), download_manager_)); |
| 567 AddDownloadToFileManager(id, download_file); |
| 568 |
| 569 // |download_file| is owned by DownloadFileManager. |
| 570 ::testing::Mock::AllowLeak(download_file); |
| 571 download_manager_->CreateDownloadItem(info.get()); |
| 572 |
| 573 DownloadItem* download = GetActiveDownloadItem(0); |
| 574 ASSERT_TRUE(download != NULL); |
| 575 scoped_ptr<DownloadItemModel> download_item_model( |
| 576 new DownloadItemModel(download)); |
| 577 |
| 578 EXPECT_EQ(DownloadItem::IN_PROGRESS, download->state()); |
| 579 scoped_ptr<ItemObserver> observer(new ItemObserver(download)); |
| 580 |
| 581 UpdateData(id, kTestData, kTestDataLen); |
| 582 |
| 583 ContinueDownloadWithPath(download, path); |
| 584 message_loop_.RunAllPending(); |
| 585 EXPECT_TRUE(GetActiveDownloadItem(0) != NULL); |
| 586 |
| 587 UpdateData(id, kTestData, kTestDataLen); |
| 588 |
| 589 download_file->SetForcedError(net::ERR_FAILED); |
| 590 UpdateData(id, kTestData, kTestDataLen); |
| 591 |
| 592 EXPECT_TRUE(GetActiveDownloadItem(0) == NULL); |
| 593 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); |
| 594 EXPECT_TRUE(observer->hit_state(DownloadItem::INTERRUPTED)); |
| 595 EXPECT_FALSE(observer->hit_state(DownloadItem::COMPLETE)); |
| 596 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); |
| 597 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
| 598 EXPECT_TRUE(observer->was_updated()); |
| 599 EXPECT_FALSE(observer->was_opened()); |
| 600 EXPECT_FALSE(download->file_externally_removed()); |
| 601 EXPECT_EQ(DownloadItem::INTERRUPTED, download->state()); |
| 602 |
| 603 size_t error_size = kTestDataLen * 3; |
| 604 ui::DataUnits amount_units = ui::GetByteDisplayUnits(kTestDataLen); |
| 605 string16 simple_size = |
| 606 ui::FormatBytesWithUnits(error_size, amount_units, false); |
| 607 string16 simple_total = base::i18n::GetDisplayStringInLTRDirectionality( |
| 608 ui::FormatBytesWithUnits(error_size, amount_units, true)); |
| 609 EXPECT_EQ(l10n_util::GetStringFUTF16(IDS_DOWNLOAD_STATUS_INTERRUPTED, |
| 610 simple_size, |
| 611 simple_total), |
| 612 download_item_model->GetStatusText()); |
| 613 |
| 614 download->Cancel(true); |
| 615 |
| 616 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); |
| 617 EXPECT_TRUE(observer->hit_state(DownloadItem::INTERRUPTED)); |
| 618 EXPECT_FALSE(observer->hit_state(DownloadItem::COMPLETE)); |
| 619 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); |
| 620 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
| 621 EXPECT_TRUE(observer->was_updated()); |
| 622 EXPECT_FALSE(observer->was_opened()); |
| 623 EXPECT_FALSE(download->file_externally_removed()); |
| 624 EXPECT_EQ(DownloadItem::INTERRUPTED, download->state()); |
| 625 EXPECT_EQ(static_cast<int64>(error_size), download->received_bytes()); |
| 626 EXPECT_EQ(static_cast<int64>(kTestDataLen) * 3, download->total_bytes()); |
| 627 } |
| 628 |
486 TEST_F(DownloadManagerTest, DownloadCancelTest) { | 629 TEST_F(DownloadManagerTest, DownloadCancelTest) { |
487 using ::testing::_; | 630 using ::testing::_; |
488 using ::testing::CreateFunctor; | 631 using ::testing::CreateFunctor; |
489 using ::testing::Invoke; | 632 using ::testing::Invoke; |
490 using ::testing::Return; | 633 using ::testing::Return; |
491 | 634 |
492 // Normally, the download system takes ownership of info, and is | 635 // Normally, the download system takes ownership of info, and is |
493 // responsible for deleting it. In these unit tests, however, we | 636 // responsible for deleting it. In these unit tests, however, we |
494 // don't call the function that deletes it, so we do so ourselves. | 637 // don't call the function that deletes it, so we do so ourselves. |
495 scoped_ptr<DownloadCreateInfo> info(new DownloadCreateInfo); | 638 scoped_ptr<DownloadCreateInfo> info(new DownloadCreateInfo); |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
603 // |download_file| is owned by DownloadFileManager. | 746 // |download_file| is owned by DownloadFileManager. |
604 AddDownloadToFileManager(info->download_id, download_file); | 747 AddDownloadToFileManager(info->download_id, download_file); |
605 | 748 |
606 ContinueDownloadWithPath(download, new_path); | 749 ContinueDownloadWithPath(download, new_path); |
607 message_loop_.RunAllPending(); | 750 message_loop_.RunAllPending(); |
608 EXPECT_TRUE(GetActiveDownloadItem(0) != NULL); | 751 EXPECT_TRUE(GetActiveDownloadItem(0) != NULL); |
609 | 752 |
610 download_file->AppendDataToFile(kTestData, kTestDataLen); | 753 download_file->AppendDataToFile(kTestData, kTestDataLen); |
611 | 754 |
612 // Finish the download. | 755 // Finish the download. |
613 OnAllDataSaved(0, kTestDataLen, ""); | 756 OnResponseCompleted(0, kTestDataLen, ""); |
614 message_loop_.RunAllPending(); | 757 message_loop_.RunAllPending(); |
615 | 758 |
616 // Download is complete. | 759 // Download is complete. |
617 EXPECT_TRUE(GetActiveDownloadItem(0) == NULL); | 760 EXPECT_TRUE(GetActiveDownloadItem(0) == NULL); |
618 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); | 761 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); |
619 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); | 762 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); |
620 EXPECT_FALSE(observer->hit_state(DownloadItem::INTERRUPTED)); | 763 EXPECT_FALSE(observer->hit_state(DownloadItem::INTERRUPTED)); |
621 EXPECT_TRUE(observer->hit_state(DownloadItem::COMPLETE)); | 764 EXPECT_TRUE(observer->hit_state(DownloadItem::COMPLETE)); |
622 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); | 765 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
623 EXPECT_TRUE(observer->was_updated()); | 766 EXPECT_TRUE(observer->was_updated()); |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
679 // |download_file| is owned by DownloadFileManager. | 822 // |download_file| is owned by DownloadFileManager. |
680 AddDownloadToFileManager(info->download_id, download_file); | 823 AddDownloadToFileManager(info->download_id, download_file); |
681 | 824 |
682 ContinueDownloadWithPath(download, new_path); | 825 ContinueDownloadWithPath(download, new_path); |
683 message_loop_.RunAllPending(); | 826 message_loop_.RunAllPending(); |
684 EXPECT_TRUE(GetActiveDownloadItem(0) != NULL); | 827 EXPECT_TRUE(GetActiveDownloadItem(0) != NULL); |
685 | 828 |
686 download_file->AppendDataToFile(kTestData, kTestDataLen); | 829 download_file->AppendDataToFile(kTestData, kTestDataLen); |
687 | 830 |
688 // Finish the download. | 831 // Finish the download. |
689 OnAllDataSaved(0, kTestDataLen, ""); | 832 OnResponseCompleted(0, kTestDataLen, ""); |
690 message_loop_.RunAllPending(); | 833 message_loop_.RunAllPending(); |
691 | 834 |
692 // Download is complete. | 835 // Download is complete. |
693 EXPECT_TRUE(GetActiveDownloadItem(0) == NULL); | 836 EXPECT_TRUE(GetActiveDownloadItem(0) == NULL); |
694 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); | 837 EXPECT_TRUE(observer->hit_state(DownloadItem::IN_PROGRESS)); |
695 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); | 838 EXPECT_FALSE(observer->hit_state(DownloadItem::CANCELLED)); |
696 EXPECT_FALSE(observer->hit_state(DownloadItem::INTERRUPTED)); | 839 EXPECT_FALSE(observer->hit_state(DownloadItem::INTERRUPTED)); |
697 EXPECT_TRUE(observer->hit_state(DownloadItem::COMPLETE)); | 840 EXPECT_TRUE(observer->hit_state(DownloadItem::COMPLETE)); |
698 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); | 841 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
699 EXPECT_TRUE(observer->was_updated()); | 842 EXPECT_TRUE(observer->was_updated()); |
(...skipping 18 matching lines...) Expand all Loading... |
718 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); | 861 EXPECT_FALSE(observer->hit_state(DownloadItem::REMOVING)); |
719 EXPECT_TRUE(observer->was_updated()); | 862 EXPECT_TRUE(observer->was_updated()); |
720 EXPECT_FALSE(observer->was_opened()); | 863 EXPECT_FALSE(observer->was_opened()); |
721 EXPECT_TRUE(download->file_externally_removed()); | 864 EXPECT_TRUE(download->file_externally_removed()); |
722 EXPECT_EQ(DownloadItem::COMPLETE, download->state()); | 865 EXPECT_EQ(DownloadItem::COMPLETE, download->state()); |
723 EXPECT_EQ(download_item_model->GetStatusText(), | 866 EXPECT_EQ(download_item_model->GetStatusText(), |
724 l10n_util::GetStringUTF16(IDS_DOWNLOAD_STATUS_REMOVED)); | 867 l10n_util::GetStringUTF16(IDS_DOWNLOAD_STATUS_REMOVED)); |
725 | 868 |
726 EXPECT_FALSE(file_util::PathExists(new_path)); | 869 EXPECT_FALSE(file_util::PathExists(new_path)); |
727 } | 870 } |
OLD | NEW |