| 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 "base/bind.h" | 5 #include "base/bind.h" |
| 6 #include "base/files/file_path.h" | 6 #include "base/files/file_path.h" |
| 7 #include "base/macros.h" | 7 #include "base/macros.h" |
| 8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
| 9 #include "chrome/browser/download/download_danger_prompt.h" | 9 #include "chrome/browser/download/download_danger_prompt.h" |
| 10 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
| 11 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 11 #include "chrome/browser/safe_browsing/test_safe_browsing_service.h" |
| 12 #include "chrome/browser/ui/browser.h" | 12 #include "chrome/browser/ui/browser.h" |
| 13 #include "chrome/browser/ui/browser_commands.h" | 13 #include "chrome/browser/ui/browser_commands.h" |
| 14 #include "chrome/browser/ui/browser_tabstrip.h" | 14 #include "chrome/browser/ui/browser_tabstrip.h" |
| 15 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 15 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 16 #include "chrome/common/safe_browsing/csd.pb.h" | 16 #include "chrome/common/safe_browsing/csd.pb.h" |
| 17 #include "chrome/test/base/in_process_browser_test.h" | 17 #include "chrome/test/base/in_process_browser_test.h" |
| 18 #include "chrome/test/base/ui_test_utils.h" | 18 #include "chrome/test/base/ui_test_utils.h" |
| 19 #include "components/safe_browsing_db/database_manager.h" | 19 #include "components/safe_browsing_db/database_manager.h" |
| 20 #include "content/public/test/mock_download_item.h" | 20 #include "content/public/test/mock_download_item.h" |
| 21 #include "testing/gmock/include/gmock/gmock.h" | 21 #include "testing/gmock/include/gmock/gmock.h" |
| 22 #include "testing/gtest/include/gtest/gtest.h" | 22 #include "testing/gtest/include/gtest/gtest.h" |
| 23 #include "url/gurl.h" | 23 #include "url/gurl.h" |
| 24 | 24 |
| 25 using ::testing::_; | 25 using ::testing::_; |
| 26 using ::testing::ByRef; | 26 using ::testing::ByRef; |
| 27 using ::testing::Eq; | 27 using ::testing::Eq; |
| 28 using ::testing::Return; | 28 using ::testing::Return; |
| 29 using ::testing::ReturnRef; | 29 using ::testing::ReturnRef; |
| 30 using ::testing::SaveArg; | 30 using ::testing::SaveArg; |
| 31 using safe_browsing::ClientDownloadResponse; | 31 using safe_browsing::ClientDownloadResponse; |
| 32 using safe_browsing::ClientSafeBrowsingReportRequest; | 32 using safe_browsing::ClientSafeBrowsingReportRequest; |
| 33 using safe_browsing::SafeBrowsingService; | 33 using safe_browsing::SafeBrowsingService; |
| 34 | 34 |
| 35 const char kTestDownloadUrl[] = "http://evildownload.com"; | 35 const char kTestDownloadUrl[] = "http://evildownload.com"; |
| 36 | 36 |
| 37 class FakeSafeBrowsingService : public SafeBrowsingService { | |
| 38 public: | |
| 39 FakeSafeBrowsingService() {} | |
| 40 | |
| 41 void SendSerializedDownloadReport(const std::string& report) override { | |
| 42 report_ = report; | |
| 43 } | |
| 44 | |
| 45 std::string GetDownloadRecoveryReport() const { return report_; } | |
| 46 | |
| 47 protected: | |
| 48 ~FakeSafeBrowsingService() override {} | |
| 49 | |
| 50 private: | |
| 51 std::string report_; | |
| 52 }; | |
| 53 | |
| 54 // Factory that creates FakeSafeBrowsingService instances. | |
| 55 class TestSafeBrowsingServiceFactory | |
| 56 : public safe_browsing::SafeBrowsingServiceFactory { | |
| 57 public: | |
| 58 TestSafeBrowsingServiceFactory() : fake_safe_browsing_service_(nullptr) {} | |
| 59 ~TestSafeBrowsingServiceFactory() override {} | |
| 60 | |
| 61 SafeBrowsingService* CreateSafeBrowsingService() override { | |
| 62 if (!fake_safe_browsing_service_) { | |
| 63 fake_safe_browsing_service_ = new FakeSafeBrowsingService(); | |
| 64 } | |
| 65 return fake_safe_browsing_service_.get(); | |
| 66 } | |
| 67 | |
| 68 scoped_refptr<FakeSafeBrowsingService> fake_safe_browsing_service() { | |
| 69 return fake_safe_browsing_service_; | |
| 70 } | |
| 71 | |
| 72 private: | |
| 73 scoped_refptr<FakeSafeBrowsingService> fake_safe_browsing_service_; | |
| 74 }; | |
| 75 | |
| 76 class DownloadDangerPromptTest : public InProcessBrowserTest { | 37 class DownloadDangerPromptTest : public InProcessBrowserTest { |
| 77 public: | 38 public: |
| 78 DownloadDangerPromptTest() | 39 DownloadDangerPromptTest() |
| 79 : prompt_(nullptr), | 40 : prompt_(nullptr), |
| 80 expected_action_(DownloadDangerPrompt::CANCEL), | 41 expected_action_(DownloadDangerPrompt::CANCEL), |
| 81 did_receive_callback_(false), | 42 did_receive_callback_(false), |
| 82 test_safe_browsing_factory_(new TestSafeBrowsingServiceFactory()), | 43 test_safe_browsing_factory_( |
| 83 report_sent_(false) {} | 44 new safe_browsing::TestSafeBrowsingServiceFactory()) {} |
| 84 | 45 |
| 85 ~DownloadDangerPromptTest() override {} | 46 ~DownloadDangerPromptTest() override {} |
| 86 | 47 |
| 87 void SetUp() override { | 48 void SetUp() override { |
| 88 SafeBrowsingService::RegisterFactory(test_safe_browsing_factory_.get()); | 49 SafeBrowsingService::RegisterFactory(test_safe_browsing_factory_.get()); |
| 89 InProcessBrowserTest::SetUp(); | 50 InProcessBrowserTest::SetUp(); |
| 90 } | 51 } |
| 91 | 52 |
| 92 void TearDown() override { | 53 void TearDown() override { |
| 93 SafeBrowsingService::RegisterFactory(nullptr); | 54 SafeBrowsingService::RegisterFactory(nullptr); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 108 void SetUpExpectations( | 69 void SetUpExpectations( |
| 109 const DownloadDangerPrompt::Action& expected_action, | 70 const DownloadDangerPrompt::Action& expected_action, |
| 110 const content::DownloadDangerType& danger_type, | 71 const content::DownloadDangerType& danger_type, |
| 111 const ClientDownloadResponse::Verdict& download_verdict) { | 72 const ClientDownloadResponse::Verdict& download_verdict) { |
| 112 did_receive_callback_ = false; | 73 did_receive_callback_ = false; |
| 113 expected_action_ = expected_action; | 74 expected_action_ = expected_action; |
| 114 SetUpDownloadItemExpectations(danger_type); | 75 SetUpDownloadItemExpectations(danger_type); |
| 115 SetUpSafeBrowsingReportExpectations( | 76 SetUpSafeBrowsingReportExpectations( |
| 116 expected_action == DownloadDangerPrompt::ACCEPT, download_verdict); | 77 expected_action == DownloadDangerPrompt::ACCEPT, download_verdict); |
| 117 CreatePrompt(); | 78 CreatePrompt(); |
| 118 report_sent_ = false; | |
| 119 } | 79 } |
| 120 | 80 |
| 121 void VerifyExpectations() { | 81 void VerifyExpectations(bool should_send_report) { |
| 122 content::RunAllPendingInMessageLoop(); | 82 content::RunAllPendingInMessageLoop(); |
| 123 // At the end of each test, we expect no more activity from the prompt. The | 83 // At the end of each test, we expect no more activity from the prompt. The |
| 124 // prompt shouldn't exist anymore either. | 84 // prompt shouldn't exist anymore either. |
| 125 EXPECT_TRUE(did_receive_callback_); | 85 EXPECT_TRUE(did_receive_callback_); |
| 126 EXPECT_FALSE(prompt_); | 86 EXPECT_FALSE(prompt_); |
| 87 |
| 88 if (should_send_report) { |
| 89 EXPECT_EQ(expected_serialized_report_, |
| 90 test_safe_browsing_factory_->test_safe_browsing_service() |
| 91 ->serilized_download_report()); |
| 92 } else { |
| 93 EXPECT_TRUE(test_safe_browsing_factory_->test_safe_browsing_service() |
| 94 ->serilized_download_report() |
| 95 .empty()); |
| 96 } |
| 127 testing::Mock::VerifyAndClearExpectations(&download_); | 97 testing::Mock::VerifyAndClearExpectations(&download_); |
| 128 if (report_sent_) { | 98 test_safe_browsing_factory_->test_safe_browsing_service() |
| 129 EXPECT_EQ(expected_serialized_report_, | 99 ->ClearDownloadReport(); |
| 130 test_safe_browsing_factory_->fake_safe_browsing_service() | |
| 131 ->GetDownloadRecoveryReport()); | |
| 132 } | |
| 133 } | 100 } |
| 134 | 101 |
| 135 void SimulatePromptAction(DownloadDangerPrompt::Action action) { | 102 void SimulatePromptAction(DownloadDangerPrompt::Action action) { |
| 136 prompt_->InvokeActionForTesting(action); | 103 prompt_->InvokeActionForTesting(action); |
| 137 report_sent_ = true; | |
| 138 } | 104 } |
| 139 | 105 |
| 140 content::MockDownloadItem& download() { return download_; } | 106 content::MockDownloadItem& download() { return download_; } |
| 141 | 107 |
| 142 DownloadDangerPrompt* prompt() { return prompt_; } | 108 DownloadDangerPrompt* prompt() { return prompt_; } |
| 143 | 109 |
| 144 private: | 110 private: |
| 145 void SetUpDownloadItemExpectations( | 111 void SetUpDownloadItemExpectations( |
| 146 const content::DownloadDangerType& danger_type) { | 112 const content::DownloadDangerType& danger_type) { |
| 147 EXPECT_CALL(download_, GetFileNameToReportUser()).WillRepeatedly(Return( | 113 EXPECT_CALL(download_, GetFileNameToReportUser()).WillRepeatedly(Return( |
| (...skipping 26 matching lines...) Expand all Loading... |
| 174 EXPECT_FALSE(did_receive_callback_); | 140 EXPECT_FALSE(did_receive_callback_); |
| 175 EXPECT_EQ(expected_action_, action); | 141 EXPECT_EQ(expected_action_, action); |
| 176 did_receive_callback_ = true; | 142 did_receive_callback_ = true; |
| 177 prompt_ = nullptr; | 143 prompt_ = nullptr; |
| 178 } | 144 } |
| 179 | 145 |
| 180 content::MockDownloadItem download_; | 146 content::MockDownloadItem download_; |
| 181 DownloadDangerPrompt* prompt_; | 147 DownloadDangerPrompt* prompt_; |
| 182 DownloadDangerPrompt::Action expected_action_; | 148 DownloadDangerPrompt::Action expected_action_; |
| 183 bool did_receive_callback_; | 149 bool did_receive_callback_; |
| 184 std::unique_ptr<TestSafeBrowsingServiceFactory> test_safe_browsing_factory_; | 150 std::unique_ptr<safe_browsing::TestSafeBrowsingServiceFactory> |
| 151 test_safe_browsing_factory_; |
| 185 std::string expected_serialized_report_; | 152 std::string expected_serialized_report_; |
| 186 bool report_sent_; | |
| 187 | 153 |
| 188 DISALLOW_COPY_AND_ASSIGN(DownloadDangerPromptTest); | 154 DISALLOW_COPY_AND_ASSIGN(DownloadDangerPromptTest); |
| 189 }; | 155 }; |
| 190 | 156 |
| 191 // Disabled for flaky timeouts on Windows. crbug.com/446696 | 157 // Disabled for flaky timeouts on Windows. crbug.com/446696 |
| 192 #if defined(OS_WIN) | 158 #if defined(OS_WIN) |
| 193 #define MAYBE_TestAll DISABLED_TestAll | 159 #define MAYBE_TestAll DISABLED_TestAll |
| 194 #else | 160 #else |
| 195 #define MAYBE_TestAll TestAll | 161 #define MAYBE_TestAll TestAll |
| 196 #endif | 162 #endif |
| 197 IN_PROC_BROWSER_TEST_F(DownloadDangerPromptTest, MAYBE_TestAll) { | 163 IN_PROC_BROWSER_TEST_F(DownloadDangerPromptTest, MAYBE_TestAll) { |
| 198 // ExperienceSampling: Set default actions for DownloadItem methods we need. | 164 // ExperienceSampling: Set default actions for DownloadItem methods we need. |
| 199 GURL download_url(kTestDownloadUrl); | 165 GURL download_url(kTestDownloadUrl); |
| 200 ON_CALL(download(), GetURL()).WillByDefault(ReturnRef(download_url)); | 166 ON_CALL(download(), GetURL()).WillByDefault(ReturnRef(download_url)); |
| 201 ON_CALL(download(), GetReferrerUrl()) | 167 ON_CALL(download(), GetReferrerUrl()) |
| 202 .WillByDefault(ReturnRef(GURL::EmptyGURL())); | 168 .WillByDefault(ReturnRef(GURL::EmptyGURL())); |
| 203 ON_CALL(download(), GetBrowserContext()) | 169 ON_CALL(download(), GetBrowserContext()) |
| 204 .WillByDefault(Return(browser()->profile())); | 170 .WillByDefault(Return(browser()->profile())); |
| 205 base::FilePath empty_file_path; | 171 base::FilePath empty_file_path; |
| 206 ON_CALL(download(), GetTargetFilePath()) | 172 ON_CALL(download(), GetTargetFilePath()) |
| 207 .WillByDefault(ReturnRef(empty_file_path)); | 173 .WillByDefault(ReturnRef(empty_file_path)); |
| 208 | 174 |
| 209 OpenNewTab(); | 175 OpenNewTab(); |
| 210 | 176 |
| 211 // Clicking the Accept button should invoke the ACCEPT action. | 177 // Clicking the Accept button should invoke the ACCEPT action. |
| 212 SetUpExpectations(DownloadDangerPrompt::ACCEPT, | 178 SetUpExpectations(DownloadDangerPrompt::ACCEPT, |
| 213 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL, | 179 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL, |
| 214 ClientDownloadResponse::DANGEROUS); | 180 ClientDownloadResponse::DANGEROUS); |
| 181 EXPECT_CALL(download(), IsDangerous()).WillRepeatedly(Return(true)); |
| 215 SimulatePromptAction(DownloadDangerPrompt::ACCEPT); | 182 SimulatePromptAction(DownloadDangerPrompt::ACCEPT); |
| 216 VerifyExpectations(); | 183 VerifyExpectations(true); |
| 217 | 184 |
| 218 // Clicking the Cancel button should invoke the CANCEL action. | 185 // Clicking the Cancel button should invoke the CANCEL action. |
| 219 SetUpExpectations(DownloadDangerPrompt::CANCEL, | 186 SetUpExpectations(DownloadDangerPrompt::CANCEL, |
| 220 content::DOWNLOAD_DANGER_TYPE_UNCOMMON_CONTENT, | 187 content::DOWNLOAD_DANGER_TYPE_UNCOMMON_CONTENT, |
| 221 ClientDownloadResponse::UNCOMMON); | 188 ClientDownloadResponse::UNCOMMON); |
| 189 EXPECT_CALL(download(), IsDangerous()).WillRepeatedly(Return(true)); |
| 222 SimulatePromptAction(DownloadDangerPrompt::CANCEL); | 190 SimulatePromptAction(DownloadDangerPrompt::CANCEL); |
| 223 VerifyExpectations(); | 191 VerifyExpectations(true); |
| 224 | 192 |
| 225 // If the download is no longer dangerous (because it was accepted), the | 193 // If the download is no longer dangerous (because it was accepted), the |
| 226 // dialog should DISMISS itself. | 194 // dialog should DISMISS itself. |
| 227 SetUpExpectations(DownloadDangerPrompt::DISMISS, | 195 SetUpExpectations(DownloadDangerPrompt::DISMISS, |
| 228 content::DOWNLOAD_DANGER_TYPE_POTENTIALLY_UNWANTED, | 196 content::DOWNLOAD_DANGER_TYPE_POTENTIALLY_UNWANTED, |
| 229 ClientDownloadResponse::POTENTIALLY_UNWANTED); | 197 ClientDownloadResponse::POTENTIALLY_UNWANTED); |
| 230 EXPECT_CALL(download(), IsDangerous()).WillOnce(Return(false)); | 198 EXPECT_CALL(download(), IsDangerous()).WillRepeatedly(Return(false)); |
| 231 download().NotifyObserversDownloadUpdated(); | 199 download().NotifyObserversDownloadUpdated(); |
| 232 VerifyExpectations(); | 200 VerifyExpectations(false); |
| 233 | 201 |
| 234 // If the download is in a terminal state then the dialog should DISMISS | 202 // If the download is in a terminal state then the dialog should DISMISS |
| 235 // itself. | 203 // itself. |
| 236 SetUpExpectations(DownloadDangerPrompt::DISMISS, | 204 SetUpExpectations(DownloadDangerPrompt::DISMISS, |
| 237 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_HOST, | 205 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_HOST, |
| 238 ClientDownloadResponse::DANGEROUS_HOST); | 206 ClientDownloadResponse::DANGEROUS_HOST); |
| 239 EXPECT_CALL(download(), IsDangerous()).WillOnce(Return(true)); | 207 EXPECT_CALL(download(), IsDangerous()).WillRepeatedly(Return(true)); |
| 240 EXPECT_CALL(download(), IsDone()).WillOnce(Return(true)); | 208 EXPECT_CALL(download(), IsDone()).WillRepeatedly(Return(true)); |
| 241 download().NotifyObserversDownloadUpdated(); | 209 download().NotifyObserversDownloadUpdated(); |
| 242 VerifyExpectations(); | 210 VerifyExpectations(false); |
| 243 | 211 |
| 244 // If the download is dangerous and is not in a terminal state, don't dismiss | 212 // If the download is dangerous and is not in a terminal state, don't dismiss |
| 245 // the dialog. | 213 // the dialog. |
| 246 SetUpExpectations(DownloadDangerPrompt::ACCEPT, | 214 SetUpExpectations(DownloadDangerPrompt::ACCEPT, |
| 247 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_CONTENT, | 215 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_CONTENT, |
| 248 ClientDownloadResponse::DANGEROUS); | 216 ClientDownloadResponse::DANGEROUS); |
| 249 EXPECT_CALL(download(), IsDangerous()).WillOnce(Return(true)); | 217 EXPECT_CALL(download(), IsDangerous()).WillRepeatedly(Return(true)); |
| 250 EXPECT_CALL(download(), IsDone()).WillOnce(Return(false)); | 218 EXPECT_CALL(download(), IsDone()).WillRepeatedly(Return(false)); |
| 251 download().NotifyObserversDownloadUpdated(); | 219 download().NotifyObserversDownloadUpdated(); |
| 220 EXPECT_TRUE(prompt()); |
| 252 SimulatePromptAction(DownloadDangerPrompt::ACCEPT); | 221 SimulatePromptAction(DownloadDangerPrompt::ACCEPT); |
| 253 VerifyExpectations(); | 222 VerifyExpectations(true); |
| 223 |
| 224 // If the download is not dangerous, no report will be sent. |
| 225 SetUpExpectations(DownloadDangerPrompt::ACCEPT, |
| 226 content::DOWNLOAD_DANGER_TYPE_NOT_DANGEROUS, |
| 227 ClientDownloadResponse::SAFE); |
| 228 SimulatePromptAction(DownloadDangerPrompt::ACCEPT); |
| 229 VerifyExpectations(false); |
| 254 | 230 |
| 255 // If the containing tab is closed, the dialog should DISMISS itself. | 231 // If the containing tab is closed, the dialog should DISMISS itself. |
| 256 OpenNewTab(); | 232 OpenNewTab(); |
| 257 SetUpExpectations(DownloadDangerPrompt::DISMISS, | 233 SetUpExpectations(DownloadDangerPrompt::DISMISS, |
| 258 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL, | 234 content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL, |
| 259 ClientDownloadResponse::DANGEROUS); | 235 ClientDownloadResponse::DANGEROUS); |
| 260 chrome::CloseTab(browser()); | 236 chrome::CloseTab(browser()); |
| 261 VerifyExpectations(); | 237 VerifyExpectations(false); |
| 262 } | 238 } |
| OLD | NEW |