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 |