| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "components/password_manager/core/browser/suppressed_https_form_fetcher
.h" | 5 #include "components/password_manager/core/browser/suppressed_form_fetcher.h" |
| 6 | 6 |
| 7 #include "base/macros.h" | 7 #include "base/macros.h" |
| 8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
| 10 #include "components/password_manager/core/browser/mock_password_store.h" | 10 #include "components/password_manager/core/browser/mock_password_store.h" |
| 11 #include "components/password_manager/core/browser/password_manager_test_utils.h
" | 11 #include "components/password_manager/core/browser/password_manager_test_utils.h
" |
| 12 #include "components/password_manager/core/browser/stub_password_manager_client.
h" | 12 #include "components/password_manager/core/browser/stub_password_manager_client.
h" |
| 13 #include "testing/gmock/include/gmock/gmock.h" | 13 #include "testing/gmock/include/gmock/gmock.h" |
| 14 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 15 | 15 |
| 16 namespace password_manager { | 16 namespace password_manager { |
| 17 namespace { | 17 namespace { |
| 18 | 18 |
| 19 using autofill::PasswordForm; | 19 using autofill::PasswordForm; |
| 20 using testing::_; | 20 using testing::_; |
| 21 | 21 |
| 22 constexpr const char kTestHttpURL[] = "http://one.example.com/"; | 22 constexpr const char kTestHttpURL[] = "http://one.example.com/"; |
| 23 constexpr const char kTestHttpsURL[] = "https://one.example.com/"; | 23 constexpr const char kTestHttpsURL[] = "https://one.example.com/"; |
| 24 constexpr const char kTestPSLMatchingHttpURL[] = "http://psl.example.com/"; | 24 constexpr const char kTestPSLMatchingHttpURL[] = "http://psl.example.com/"; |
| 25 constexpr const char kTestPSLMatchingHttpsURL[] = "https://psl.example.com/"; | 25 constexpr const char kTestPSLMatchingHttpsURL[] = "https://psl.example.com/"; |
| 26 constexpr const char kTestHttpSameOrgNameURL[] = "http://login.example.co.uk/"; | 26 constexpr const char kTestHttpSameOrgNameURL[] = "http://login.example.co.uk/"; |
| 27 constexpr const char kTestHttpsSameOrgNameURL[] = | 27 constexpr const char kTestHttpsSameOrgNameURL[] = |
| 28 "https://login.example.co.uk/"; | 28 "https://login.example.co.uk/"; |
| 29 | 29 |
| 30 class MockConsumer : public SuppressedHTTPSFormFetcher::Consumer { | 30 class MockConsumer : public SuppressedFormFetcher::Consumer { |
| 31 public: | 31 public: |
| 32 MockConsumer() = default; | 32 MockConsumer() = default; |
| 33 ~MockConsumer() = default; | 33 ~MockConsumer() = default; |
| 34 | 34 |
| 35 // GMock still cannot mock methods with move-only args. | 35 // GMock still cannot mock methods with move-only args. |
| 36 MOCK_METHOD1(ProcessSuppressedHTTPSFormsConstRef, | 36 MOCK_METHOD1(ProcessSuppressedHTTPSFormsConstRef, |
| 37 void(const std::vector<std::unique_ptr<PasswordForm>>&)); | 37 void(const std::vector<std::unique_ptr<PasswordForm>>&)); |
| 38 | 38 |
| 39 protected: | 39 protected: |
| 40 // SuppressedHTTPSFormFetcher::Consumer: | 40 // SuppressedFormFetcher::Consumer: |
| 41 void ProcessSuppressedHTTPSForms( | 41 void ProcessSuppressedForms( |
| 42 std::vector<std::unique_ptr<PasswordForm>> forms) override { | 42 std::vector<std::unique_ptr<PasswordForm>> forms) override { |
| 43 ProcessSuppressedHTTPSFormsConstRef(forms); | 43 ProcessSuppressedHTTPSFormsConstRef(forms); |
| 44 } | 44 } |
| 45 | 45 |
| 46 private: | 46 private: |
| 47 DISALLOW_COPY_AND_ASSIGN(MockConsumer); | 47 DISALLOW_COPY_AND_ASSIGN(MockConsumer); |
| 48 }; | 48 }; |
| 49 | 49 |
| 50 class PasswordManagerClientWithMockStore : public StubPasswordManagerClient { | 50 class PasswordManagerClientWithMockStore : public StubPasswordManagerClient { |
| 51 public: | 51 public: |
| (...skipping 10 matching lines...) Expand all Loading... |
| 62 PasswordStore* GetPasswordStore() const override { return mock_store_.get(); } | 62 PasswordStore* GetPasswordStore() const override { return mock_store_.get(); } |
| 63 | 63 |
| 64 private: | 64 private: |
| 65 scoped_refptr<MockPasswordStore> mock_store_; | 65 scoped_refptr<MockPasswordStore> mock_store_; |
| 66 | 66 |
| 67 DISALLOW_COPY_AND_ASSIGN(PasswordManagerClientWithMockStore); | 67 DISALLOW_COPY_AND_ASSIGN(PasswordManagerClientWithMockStore); |
| 68 }; | 68 }; |
| 69 | 69 |
| 70 } // namespace | 70 } // namespace |
| 71 | 71 |
| 72 class SuppressedHTTPSFormFetcherTest : public testing::Test { | 72 class SuppressedFormFetcherTest : public testing::Test { |
| 73 public: | 73 public: |
| 74 SuppressedHTTPSFormFetcherTest() = default; | 74 SuppressedFormFetcherTest() = default; |
| 75 ~SuppressedHTTPSFormFetcherTest() override = default; | 75 ~SuppressedFormFetcherTest() override = default; |
| 76 | 76 |
| 77 MockConsumer* mock_consumer() { return &consumer_; } | 77 MockConsumer* mock_consumer() { return &consumer_; } |
| 78 MockPasswordStore* mock_store() { return &client_.mock_password_store(); } | 78 MockPasswordStore* mock_store() { return &client_.mock_password_store(); } |
| 79 PasswordManagerClientWithMockStore* mock_client() { return &client_; } | 79 PasswordManagerClientWithMockStore* mock_client() { return &client_; } |
| 80 | 80 |
| 81 private: | 81 private: |
| 82 base::MessageLoop message_loop_; // Needed by the MockPasswordStore. | 82 base::MessageLoop message_loop_; // Needed by the MockPasswordStore. |
| 83 | 83 |
| 84 MockConsumer consumer_; | 84 MockConsumer consumer_; |
| 85 PasswordManagerClientWithMockStore client_; | 85 PasswordManagerClientWithMockStore client_; |
| 86 | 86 |
| 87 DISALLOW_COPY_AND_ASSIGN(SuppressedHTTPSFormFetcherTest); | 87 DISALLOW_COPY_AND_ASSIGN(SuppressedFormFetcherTest); |
| 88 }; | 88 }; |
| 89 | 89 |
| 90 TEST_F(SuppressedHTTPSFormFetcherTest, EmptyStore) { | 90 TEST_F(SuppressedFormFetcherTest, EmptyStore) { |
| 91 EXPECT_CALL(*mock_store(), GetLoginsForSameOrganizationName(kTestHttpURL, _)); | 91 EXPECT_CALL(*mock_store(), GetLoginsForSameOrganizationName(kTestHttpURL, _)); |
| 92 SuppressedHTTPSFormFetcher suppressed_form_fetcher( | 92 SuppressedFormFetcher suppressed_form_fetcher(kTestHttpURL, mock_client(), |
| 93 kTestHttpURL, mock_client(), mock_consumer()); | 93 mock_consumer()); |
| 94 EXPECT_CALL(*mock_consumer(), | 94 EXPECT_CALL(*mock_consumer(), |
| 95 ProcessSuppressedHTTPSFormsConstRef(::testing::IsEmpty())); | 95 ProcessSuppressedHTTPSFormsConstRef(::testing::IsEmpty())); |
| 96 suppressed_form_fetcher.OnGetPasswordStoreResults( | 96 suppressed_form_fetcher.OnGetPasswordStoreResults( |
| 97 std::vector<std::unique_ptr<PasswordForm>>()); | 97 std::vector<std::unique_ptr<PasswordForm>>()); |
| 98 } | 98 } |
| 99 | 99 |
| 100 TEST_F(SuppressedHTTPSFormFetcherTest, FullStore) { | 100 TEST_F(SuppressedFormFetcherTest, FullStore) { |
| 101 static constexpr const PasswordFormData kSuppressedHTTPSCredentials[] = { | 101 static constexpr const PasswordFormData kSuppressedCredentials[] = { |
| 102 // Credential that is for the HTTPS counterpart of the observed form. | 102 // Credential that is for the HTTPS counterpart of the observed form. |
| 103 {PasswordForm::SCHEME_HTML, kTestHttpsURL, kTestHttpsURL, "", L"", L"", | 103 {PasswordForm::SCHEME_HTML, kTestHttpsURL, kTestHttpsURL, "", L"", L"", |
| 104 L"", L"username_value_1", L"password_value_1", true, 1}, | 104 L"", L"username_value_1", L"password_value_1", true, 1}, |
| 105 // Once again, but with a different username/password. | 105 // Once again, but with a different username/password. |
| 106 {PasswordForm::SCHEME_HTML, kTestHttpsURL, kTestHttpsURL, "", L"", L"", | 106 {PasswordForm::SCHEME_HTML, kTestHttpsURL, kTestHttpsURL, "", L"", L"", |
| 107 L"", L"username_value_2", L"password_value_2", true, 1}, | 107 L"", L"username_value_2", L"password_value_2", true, 1}, |
| 108 }; | |
| 109 | |
| 110 static constexpr const PasswordFormData kOtherCredentials[] = { | |
| 111 // Credential exactly matching the observed form. | |
| 112 {PasswordForm::SCHEME_HTML, kTestHttpURL, kTestHttpURL, "", L"", L"", L"", | |
| 113 L"username_value_1", L"password_value_1", true, 1}, | |
| 114 // A PSL match to the observed form. | 108 // A PSL match to the observed form. |
| 115 {PasswordForm::SCHEME_HTML, kTestPSLMatchingHttpURL, | 109 {PasswordForm::SCHEME_HTML, kTestPSLMatchingHttpURL, |
| 116 kTestPSLMatchingHttpURL, "", L"", L"", L"", L"username_value_2", | 110 kTestPSLMatchingHttpURL, "", L"", L"", L"", L"username_value_2", |
| 117 L"password_value_2", true, 1}, | 111 L"password_value_2", true, 1}, |
| 118 // A PSL match to the HTTPS counterpart of the observed form. | 112 // A PSL match to the HTTPS counterpart of the observed form. Note that |
| 113 // this is *not* a PSL match to the observed form, but a same organization |
| 114 // name match. |
| 119 {PasswordForm::SCHEME_HTML, kTestPSLMatchingHttpsURL, | 115 {PasswordForm::SCHEME_HTML, kTestPSLMatchingHttpsURL, |
| 120 kTestPSLMatchingHttpsURL, "", L"", L"", L"", L"username_value_3", | 116 kTestPSLMatchingHttpsURL, "", L"", L"", L"", L"username_value_3", |
| 121 L"password_value_3", true, 1}, | 117 L"password_value_3", true, 1}, |
| 122 // Credentials for a HTTP origin with the same organization | 118 // Credentials for a HTTP origin with the same organization |
| 123 // identifying name. | 119 // identifying name. |
| 124 {PasswordForm::SCHEME_HTML, kTestHttpSameOrgNameURL, | 120 {PasswordForm::SCHEME_HTML, kTestHttpSameOrgNameURL, |
| 125 kTestHttpSameOrgNameURL, "", L"", L"", L"", L"username_value_4", | 121 kTestHttpSameOrgNameURL, "", L"", L"", L"", L"username_value_4", |
| 126 L"password_value_4", true, 1}, | 122 L"password_value_4", true, 1}, |
| 127 // Credentials for a HTTPS origin with the same organization | 123 // Credentials for a HTTPS origin with the same organization |
| 128 // identifying name. | 124 // identifying name. |
| 129 {PasswordForm::SCHEME_HTML, kTestHttpsSameOrgNameURL, | 125 {PasswordForm::SCHEME_HTML, kTestHttpsSameOrgNameURL, |
| 130 kTestHttpsSameOrgNameURL, "", L"", L"", L"", L"username_value_5", | 126 kTestHttpsSameOrgNameURL, "", L"", L"", L"", L"username_value_5", |
| 131 L"password_value_5", true, 1}}; | 127 L"password_value_5", true, 1}}; |
| 132 | 128 |
| 129 static const PasswordFormData kNotSuppressedCredentials[] = { |
| 130 // Credential exactly matching the observed form. |
| 131 {PasswordForm::SCHEME_HTML, kTestHttpURL, kTestHttpURL, "", L"", L"", L"", |
| 132 L"username_value_1", L"password_value_1", true, 1}, |
| 133 }; |
| 134 |
| 133 std::vector<std::unique_ptr<PasswordForm>> simulated_store_results; | 135 std::vector<std::unique_ptr<PasswordForm>> simulated_store_results; |
| 134 std::vector<std::unique_ptr<PasswordForm>> expected_results; | 136 std::vector<std::unique_ptr<PasswordForm>> expected_results; |
| 135 for (const auto& form_data : kSuppressedHTTPSCredentials) { | 137 for (const auto& form_data : kSuppressedCredentials) { |
| 136 expected_results.push_back(CreatePasswordFormFromDataForTesting(form_data)); | 138 expected_results.push_back(CreatePasswordFormFromDataForTesting(form_data)); |
| 137 simulated_store_results.push_back( | 139 simulated_store_results.push_back( |
| 138 CreatePasswordFormFromDataForTesting(form_data)); | 140 CreatePasswordFormFromDataForTesting(form_data)); |
| 139 } | 141 } |
| 140 for (const auto& form_data : kOtherCredentials) { | 142 for (const auto& form_data : kNotSuppressedCredentials) { |
| 141 simulated_store_results.push_back( | 143 simulated_store_results.push_back( |
| 142 CreatePasswordFormFromDataForTesting(form_data)); | 144 CreatePasswordFormFromDataForTesting(form_data)); |
| 143 } | 145 } |
| 144 | 146 |
| 145 EXPECT_CALL(*mock_store(), GetLoginsForSameOrganizationName(kTestHttpURL, _)); | 147 EXPECT_CALL(*mock_store(), GetLoginsForSameOrganizationName(kTestHttpURL, _)); |
| 146 SuppressedHTTPSFormFetcher suppressed_form_fetcher( | 148 SuppressedFormFetcher suppressed_form_fetcher(kTestHttpURL, mock_client(), |
| 147 kTestHttpURL, mock_client(), mock_consumer()); | 149 mock_consumer()); |
| 148 EXPECT_CALL(*mock_consumer(), | 150 EXPECT_CALL(*mock_consumer(), |
| 149 ProcessSuppressedHTTPSFormsConstRef( | 151 ProcessSuppressedHTTPSFormsConstRef( |
| 150 UnorderedPasswordFormElementsAre(&expected_results))); | 152 UnorderedPasswordFormElementsAre(&expected_results))); |
| 151 suppressed_form_fetcher.OnGetPasswordStoreResults( | 153 suppressed_form_fetcher.OnGetPasswordStoreResults( |
| 152 std::move(simulated_store_results)); | 154 std::move(simulated_store_results)); |
| 153 } | 155 } |
| 154 | 156 |
| 155 } // namespace password_manager | 157 } // namespace password_manager |
| OLD | NEW |