| 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 "chrome/browser/ui/page_info/page_info.h" | 5 #include "chrome/browser/ui/page_info/page_info.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/at_exit.h" | 10 #include "base/at_exit.h" |
| 11 #include "base/bind.h" | 11 #include "base/bind.h" |
| 12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
| 13 #include "base/message_loop/message_loop.h" | 13 #include "base/message_loop/message_loop.h" |
| 14 #include "base/strings/string16.h" | 14 #include "base/strings/string16.h" |
| 15 #include "base/strings/utf_string_conversions.h" | 15 #include "base/strings/utf_string_conversions.h" |
| 16 #include "base/test/histogram_tester.h" | 16 #include "base/test/histogram_tester.h" |
| 17 #include "base/test/scoped_feature_list.h" |
| 17 #include "build/build_config.h" | 18 #include "build/build_config.h" |
| 18 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 19 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| 19 #include "chrome/browser/infobars/infobar_service.h" | 20 #include "chrome/browser/infobars/infobar_service.h" |
| 20 #include "chrome/browser/ui/page_info/page_info_ui.h" | 21 #include "chrome/browser/ui/page_info/page_info_ui.h" |
| 21 #include "chrome/browser/usb/usb_chooser_context.h" | 22 #include "chrome/browser/usb/usb_chooser_context.h" |
| 22 #include "chrome/browser/usb/usb_chooser_context_factory.h" | 23 #include "chrome/browser/usb/usb_chooser_context_factory.h" |
| 23 #include "chrome/test/base/chrome_render_view_host_test_harness.h" | 24 #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
| 24 #include "chrome/test/base/testing_profile.h" | 25 #include "chrome/test/base/testing_profile.h" |
| 25 #include "components/content_settings/core/browser/host_content_settings_map.h" | 26 #include "components/content_settings/core/browser/host_content_settings_map.h" |
| 26 #include "components/content_settings/core/common/content_settings.h" | 27 #include "components/content_settings/core/common/content_settings.h" |
| 27 #include "components/content_settings/core/common/content_settings_types.h" | 28 #include "components/content_settings/core/common/content_settings_types.h" |
| 28 #include "components/infobars/core/infobar.h" | 29 #include "components/infobars/core/infobar.h" |
| 30 #include "components/subresource_filter/core/browser/subresource_filter_features
.h" |
| 29 #include "content/public/browser/ssl_status.h" | 31 #include "content/public/browser/ssl_status.h" |
| 32 #include "content/public/common/content_switches.h" |
| 30 #include "device/base/mock_device_client.h" | 33 #include "device/base/mock_device_client.h" |
| 31 #include "device/usb/mock_usb_device.h" | 34 #include "device/usb/mock_usb_device.h" |
| 32 #include "device/usb/mock_usb_service.h" | 35 #include "device/usb/mock_usb_service.h" |
| 33 #include "net/cert/cert_status_flags.h" | 36 #include "net/cert/cert_status_flags.h" |
| 34 #include "net/cert/x509_certificate.h" | 37 #include "net/cert/x509_certificate.h" |
| 35 #include "net/ssl/ssl_connection_status_flags.h" | 38 #include "net/ssl/ssl_connection_status_flags.h" |
| 36 #include "net/test/cert_test_util.h" | 39 #include "net/test/cert_test_util.h" |
| 37 #include "net/test/test_certificate_data.h" | 40 #include "net/test/test_certificate_data.h" |
| 38 #include "net/test/test_data_directory.h" | 41 #include "net/test/test_data_directory.h" |
| 39 #include "ppapi/features/features.h" | 42 #include "ppapi/features/features.h" |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 107 | 110 |
| 108 // Create the certificate. | 111 // Create the certificate. |
| 109 cert_ = | 112 cert_ = |
| 110 net::ImportCertFromFile(net::GetTestCertsDirectory(), "ok_cert.pem"); | 113 net::ImportCertFromFile(net::GetTestCertsDirectory(), "ok_cert.pem"); |
| 111 ASSERT_TRUE(cert_); | 114 ASSERT_TRUE(cert_); |
| 112 | 115 |
| 113 TabSpecificContentSettings::CreateForWebContents(web_contents()); | 116 TabSpecificContentSettings::CreateForWebContents(web_contents()); |
| 114 InfoBarService::CreateForWebContents(web_contents()); | 117 InfoBarService::CreateForWebContents(web_contents()); |
| 115 | 118 |
| 116 // Setup mock ui. | 119 // Setup mock ui. |
| 117 mock_ui_.reset(new MockPageInfoUI()); | 120 ResetMockUI(); |
| 118 // Use this rather than gmock's ON_CALL.WillByDefault(Invoke(... because | |
| 119 // gmock doesn't handle move-only types well. | |
| 120 mock_ui_->set_permission_info_callback_ = | |
| 121 base::Bind(&PageInfoTest::SetPermissionInfo, base::Unretained(this)); | |
| 122 } | 121 } |
| 123 | 122 |
| 124 void TearDown() override { | 123 void TearDown() override { |
| 125 ASSERT_TRUE(page_info_.get()) << "No PageInfo instance created."; | 124 ASSERT_TRUE(page_info_.get()) << "No PageInfo instance created."; |
| 126 RenderViewHostTestHarness::TearDown(); | 125 RenderViewHostTestHarness::TearDown(); |
| 127 page_info_.reset(); | 126 page_info_.reset(); |
| 128 } | 127 } |
| 129 | 128 |
| 130 void SetDefaultUIExpectations(MockPageInfoUI* mock_ui) { | 129 void SetDefaultUIExpectations(MockPageInfoUI* mock_ui) { |
| 131 // During creation |PageInfo| makes the following calls to the ui. | 130 // During creation |PageInfo| makes the following calls to the ui. |
| 132 EXPECT_CALL(*mock_ui, SetPermissionInfoStub()); | 131 EXPECT_CALL(*mock_ui, SetPermissionInfoStub()); |
| 133 EXPECT_CALL(*mock_ui, SetIdentityInfo(_)); | 132 EXPECT_CALL(*mock_ui, SetIdentityInfo(_)); |
| 134 EXPECT_CALL(*mock_ui, SetCookieInfo(_)); | 133 EXPECT_CALL(*mock_ui, SetCookieInfo(_)); |
| 135 } | 134 } |
| 136 | 135 |
| 137 void SetURL(const std::string& url) { url_ = GURL(url); } | 136 void SetURL(const std::string& url) { url_ = GURL(url); } |
| 138 | 137 |
| 139 void SetPermissionInfo(const PermissionInfoList& permission_info_list, | 138 void SetPermissionInfo(const PermissionInfoList& permission_info_list, |
| 140 ChosenObjectInfoList chosen_object_info_list) { | 139 ChosenObjectInfoList chosen_object_info_list) { |
| 141 last_chosen_object_info_.clear(); | 140 last_chosen_object_info_.clear(); |
| 142 for (auto& chosen_object_info : chosen_object_info_list) | 141 for (auto& chosen_object_info : chosen_object_info_list) |
| 143 last_chosen_object_info_.push_back(std::move(chosen_object_info)); | 142 last_chosen_object_info_.push_back(std::move(chosen_object_info)); |
| 143 last_permission_info_list_ = permission_info_list; |
| 144 } | 144 } |
| 145 | 145 |
| 146 void ResetMockUI() { mock_ui_.reset(new MockPageInfoUI()); } | 146 void ResetMockUI() { |
| 147 mock_ui_.reset(new MockPageInfoUI()); |
| 148 // Use this rather than gmock's ON_CALL.WillByDefault(Invoke(... because |
| 149 // gmock doesn't handle move-only types well. |
| 150 mock_ui_->set_permission_info_callback_ = |
| 151 base::Bind(&PageInfoTest::SetPermissionInfo, base::Unretained(this)); |
| 152 } |
| 153 |
| 147 | 154 |
| 148 void ClearPageInfo() { page_info_.reset(nullptr); } | 155 void ClearPageInfo() { page_info_.reset(nullptr); } |
| 149 | 156 |
| 150 const GURL& url() const { return url_; } | 157 const GURL& url() const { return url_; } |
| 151 scoped_refptr<net::X509Certificate> cert() { return cert_; } | 158 scoped_refptr<net::X509Certificate> cert() { return cert_; } |
| 152 MockPageInfoUI* mock_ui() { return mock_ui_.get(); } | 159 MockPageInfoUI* mock_ui() { return mock_ui_.get(); } |
| 153 const security_state::SecurityInfo& security_info() { return security_info_; } | 160 const security_state::SecurityInfo& security_info() { return security_info_; } |
| 154 const std::vector<std::unique_ptr<PageInfoUI::ChosenObjectInfo>>& | 161 const std::vector<std::unique_ptr<PageInfoUI::ChosenObjectInfo>>& |
| 155 last_chosen_object_info() { | 162 last_chosen_object_info() { |
| 156 return last_chosen_object_info_; | 163 return last_chosen_object_info_; |
| 157 } | 164 } |
| 165 const PermissionInfoList& last_permission_info_list() { |
| 166 return last_permission_info_list_; |
| 167 } |
| 158 TabSpecificContentSettings* tab_specific_content_settings() { | 168 TabSpecificContentSettings* tab_specific_content_settings() { |
| 159 return TabSpecificContentSettings::FromWebContents(web_contents()); | 169 return TabSpecificContentSettings::FromWebContents(web_contents()); |
| 160 } | 170 } |
| 161 InfoBarService* infobar_service() { | 171 InfoBarService* infobar_service() { |
| 162 return InfoBarService::FromWebContents(web_contents()); | 172 return InfoBarService::FromWebContents(web_contents()); |
| 163 } | 173 } |
| 164 | 174 |
| 165 PageInfo* page_info() { | 175 PageInfo* page_info() { |
| 166 if (!page_info_.get()) { | 176 if (!page_info_.get()) { |
| 167 page_info_.reset(new PageInfo(mock_ui(), profile(), | 177 page_info_.reset(new PageInfo(mock_ui(), profile(), |
| (...skipping 10 matching lines...) Expand all Loading... |
| 178 security_state::SecurityInfo security_info_; | 188 security_state::SecurityInfo security_info_; |
| 179 | 189 |
| 180 private: | 190 private: |
| 181 device::MockDeviceClient device_client_; | 191 device::MockDeviceClient device_client_; |
| 182 std::unique_ptr<PageInfo> page_info_; | 192 std::unique_ptr<PageInfo> page_info_; |
| 183 std::unique_ptr<MockPageInfoUI> mock_ui_; | 193 std::unique_ptr<MockPageInfoUI> mock_ui_; |
| 184 scoped_refptr<net::X509Certificate> cert_; | 194 scoped_refptr<net::X509Certificate> cert_; |
| 185 GURL url_; | 195 GURL url_; |
| 186 std::vector<std::unique_ptr<PageInfoUI::ChosenObjectInfo>> | 196 std::vector<std::unique_ptr<PageInfoUI::ChosenObjectInfo>> |
| 187 last_chosen_object_info_; | 197 last_chosen_object_info_; |
| 198 PermissionInfoList last_permission_info_list_; |
| 188 }; | 199 }; |
| 189 | 200 |
| 190 } // namespace | 201 } // namespace |
| 191 | 202 |
| 192 TEST_F(PageInfoTest, OnPermissionsChanged) { | 203 TEST_F(PageInfoTest, OnPermissionsChanged) { |
| 193 // Setup site permissions. | 204 // Setup site permissions. |
| 194 HostContentSettingsMap* content_settings = | 205 HostContentSettingsMap* content_settings = |
| 195 HostContentSettingsMapFactory::GetForProfile(profile()); | 206 HostContentSettingsMapFactory::GetForProfile(profile()); |
| 196 ContentSetting setting = content_settings->GetContentSetting( | 207 ContentSetting setting = content_settings->GetContentSetting( |
| 197 url(), url(), CONTENT_SETTINGS_TYPE_POPUPS, std::string()); | 208 url(), url(), CONTENT_SETTINGS_TYPE_POPUPS, std::string()); |
| (...skipping 552 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 750 // call, so it is called twice in total. | 761 // call, so it is called twice in total. |
| 751 histograms.ExpectTotalCount(kGenericHistogram, 2); | 762 histograms.ExpectTotalCount(kGenericHistogram, 2); |
| 752 histograms.ExpectBucketCount(kGenericHistogram, | 763 histograms.ExpectBucketCount(kGenericHistogram, |
| 753 PageInfo::PageInfoAction::PAGE_INFO_OPENED, 2); | 764 PageInfo::PageInfoAction::PAGE_INFO_OPENED, 2); |
| 754 | 765 |
| 755 histograms.ExpectTotalCount(test.histogram_name, 2); | 766 histograms.ExpectTotalCount(test.histogram_name, 2); |
| 756 histograms.ExpectBucketCount(test.histogram_name, | 767 histograms.ExpectBucketCount(test.histogram_name, |
| 757 PageInfo::PageInfoAction::PAGE_INFO_OPENED, 2); | 768 PageInfo::PageInfoAction::PAGE_INFO_OPENED, 2); |
| 758 } | 769 } |
| 759 } | 770 } |
| 771 |
| 772 // Tests that the SubresourceFilter setting is omitted correctly. |
| 773 TEST_F(PageInfoTest, SubresourceFilterSetting_MatchesActivation) { |
| 774 base::test::ScopedFeatureList feature_list; |
| 775 feature_list.InitAndEnableFeature( |
| 776 subresource_filter::kSafeBrowsingSubresourceFilterExperimentalUI); |
| 777 auto showing_setting = [](const PermissionInfoList& permissions) { |
| 778 for (const auto& permission : permissions) { |
| 779 if (permission.type == CONTENT_SETTINGS_TYPE_SUBRESOURCE_FILTER) |
| 780 return true; |
| 781 } |
| 782 return false; |
| 783 }; |
| 784 |
| 785 // By default, the setting should not appear at all. |
| 786 SetURL("https://example.test/"); |
| 787 SetDefaultUIExpectations(mock_ui()); |
| 788 page_info(); |
| 789 EXPECT_FALSE(showing_setting(last_permission_info_list())); |
| 790 |
| 791 // Reset state. |
| 792 ResetMockUI(); |
| 793 ClearPageInfo(); |
| 794 SetDefaultUIExpectations(mock_ui()); |
| 795 |
| 796 // Now, simulate activation on that origin, which is encoded by the existence |
| 797 // of the website setting. The setting should then appear in page_info. |
| 798 HostContentSettingsMap* content_settings = |
| 799 HostContentSettingsMapFactory::GetForProfile(profile()); |
| 800 content_settings->SetWebsiteSettingDefaultScope( |
| 801 url(), GURL(), CONTENT_SETTINGS_TYPE_SUBRESOURCE_FILTER_DATA, |
| 802 std::string(), base::MakeUnique<base::DictionaryValue>()); |
| 803 page_info(); |
| 804 EXPECT_TRUE(showing_setting(last_permission_info_list())); |
| 805 } |
| OLD | NEW |