Chromium Code Reviews| 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 "base/strings/nullable_string16.h" | |
| 5 #include "base/strings/string16.h" | 6 #include "base/strings/string16.h" |
| 6 #include "base/strings/string_util.h" | 7 #include "base/strings/string_util.h" |
| 7 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 8 #include "chrome/browser/webshare/share_target_pref_helper.h" | 9 #include "chrome/browser/webshare/share_target_pref_helper.h" |
| 9 #include "chrome/common/pref_names.h" | 10 #include "chrome/common/pref_names.h" |
| 10 #include "chrome/test/base/testing_profile.h" | 11 #include "chrome/test/base/testing_profile.h" |
| 11 #include "components/prefs/pref_registry_simple.h" | 12 #include "components/prefs/pref_registry_simple.h" |
| 12 #include "components/prefs/testing_pref_service.h" | 13 #include "components/prefs/testing_pref_service.h" |
| 13 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 14 | 15 |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 26 pref_service_->registry()->RegisterDictionaryPref( | 27 pref_service_->registry()->RegisterDictionaryPref( |
| 27 prefs::kWebShareVisitedTargets); | 28 prefs::kWebShareVisitedTargets); |
| 28 } | 29 } |
| 29 | 30 |
| 30 PrefService* pref_service() { return pref_service_.get(); } | 31 PrefService* pref_service() { return pref_service_.get(); } |
| 31 | 32 |
| 32 private: | 33 private: |
| 33 std::unique_ptr<TestingPrefServiceSimple> pref_service_; | 34 std::unique_ptr<TestingPrefServiceSimple> pref_service_; |
| 34 }; | 35 }; |
| 35 | 36 |
| 37 constexpr char kNameKey[] = "name"; | |
| 36 constexpr char kUrlTemplateKey[] = "url_template"; | 38 constexpr char kUrlTemplateKey[] = "url_template"; |
| 37 | 39 |
| 38 TEST_F(ShareTargetPrefHelperUnittest, AddMultipleShareTargets) { | 40 TEST_F(ShareTargetPrefHelperUnittest, AddMultipleShareTargets) { |
| 39 // Add a share target to prefs that wasn't previously stored. | 41 // Add a share target to prefs that wasn't previously stored. |
| 40 std::string manifest_url = "https://www.sharetarget.com/manifest.json"; | 42 GURL manifest_url("https://www.sharetarget.com/manifest.json"); |
| 41 base::Optional<std::string> url_template = | 43 content::Manifest::ShareTarget share_target; |
| 42 base::Optional<std::string>("share/?title={title}"); | 44 std::string url_template = "share/?title={title}"; |
| 45 share_target.url_template = | |
| 46 base::NullableString16(base::ASCIIToUTF16(url_template), false); | |
| 47 content::Manifest manifest; | |
| 48 manifest.share_target = | |
| 49 base::Optional<content::Manifest::ShareTarget>(share_target); | |
| 43 | 50 |
| 44 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 51 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 45 | 52 |
| 46 const base::DictionaryValue* share_target_dict = | 53 const base::DictionaryValue* share_target_dict = |
| 47 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 54 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 48 EXPECT_EQ(1UL, share_target_dict->size()); | 55 EXPECT_EQ(1UL, share_target_dict->size()); |
| 49 const base::DictionaryValue* share_target_info_dict = nullptr; | 56 const base::DictionaryValue* share_target_info_dict = nullptr; |
| 50 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 57 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 51 manifest_url, &share_target_info_dict)); | 58 manifest_url.spec(), &share_target_info_dict)); |
| 52 EXPECT_EQ(1UL, share_target_info_dict->size()); | 59 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 53 std::string url_template_in_dict; | 60 std::string url_template_in_dict; |
| 54 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 61 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 55 &url_template_in_dict)); | 62 &url_template_in_dict)); |
| 56 EXPECT_EQ(url_template_in_dict, url_template); | 63 EXPECT_EQ(url_template, url_template_in_dict); |
|
Matt Giuca
2017/02/07 05:19:36
Get kNameKey and verify that it is... I guess EXPE
constantina
2017/02/07 05:28:12
I already expect that the dictionary has a size of
Matt Giuca
2017/02/07 05:29:24
OK.
| |
| 57 | 64 |
| 58 // Add second share target to prefs that wasn't previously stored. | 65 // Add second share target to prefs that wasn't previously stored. |
| 59 manifest_url = "https://www.sharetarget2.com/manifest.json"; | 66 manifest_url = GURL("https://www.sharetarget2.com/manifest.json"); |
| 60 url_template = base::Optional<std::string>("share/?title={title}"); | 67 std::string name = "Share Target Name"; |
| 68 manifest.name = base::NullableString16(base::ASCIIToUTF16(name), false); | |
| 61 | 69 |
| 62 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 70 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 63 | 71 |
| 64 share_target_dict = | 72 share_target_dict = |
| 65 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 73 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 66 EXPECT_EQ(2UL, share_target_dict->size()); | 74 EXPECT_EQ(2UL, share_target_dict->size()); |
| 67 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 75 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 68 manifest_url, &share_target_info_dict)); | 76 manifest_url.spec(), &share_target_info_dict)); |
| 69 EXPECT_EQ(1UL, share_target_info_dict->size()); | 77 EXPECT_EQ(2UL, share_target_info_dict->size()); |
| 70 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 78 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 71 &url_template_in_dict)); | 79 &url_template_in_dict)); |
| 72 EXPECT_EQ(url_template_in_dict, url_template); | 80 EXPECT_EQ(url_template, url_template_in_dict); |
| 81 std::string name_in_dict; | |
| 82 EXPECT_TRUE(share_target_info_dict->GetString(kNameKey, &name_in_dict)); | |
| 83 EXPECT_EQ(name, name_in_dict); | |
| 73 } | 84 } |
| 74 | 85 |
| 75 TEST_F(ShareTargetPrefHelperUnittest, AddShareTargetTwice) { | 86 TEST_F(ShareTargetPrefHelperUnittest, AddShareTargetTwice) { |
| 76 const char kManifestUrl[] = "https://www.sharetarget.com/manifest.json"; | 87 const char kManifestUrl[] = "https://www.sharetarget.com/manifest.json"; |
| 77 const base::Optional<std::string> kUrlTemplate = | 88 const char kUrlTemplate[] = "share/?title={title}"; |
| 78 base::Optional<std::string>("share/?title={title}"); | |
| 79 | 89 |
| 80 // Add a share target to prefs that wasn't previously stored. | 90 // Add a share target to prefs that wasn't previously stored. |
| 81 UpdateShareTargetInPrefs(kManifestUrl, kUrlTemplate, pref_service()); | 91 GURL manifest_url(kManifestUrl); |
| 92 content::Manifest::ShareTarget share_target; | |
| 93 share_target.url_template = | |
| 94 base::NullableString16(base::ASCIIToUTF16(kUrlTemplate), false); | |
| 95 content::Manifest manifest; | |
| 96 manifest.share_target = | |
| 97 base::Optional<content::Manifest::ShareTarget>(share_target); | |
| 98 | |
| 99 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); | |
| 82 | 100 |
| 83 const base::DictionaryValue* share_target_dict = | 101 const base::DictionaryValue* share_target_dict = |
| 84 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 102 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 85 EXPECT_EQ(1UL, share_target_dict->size()); | 103 EXPECT_EQ(1UL, share_target_dict->size()); |
| 86 const base::DictionaryValue* share_target_info_dict = nullptr; | 104 const base::DictionaryValue* share_target_info_dict = nullptr; |
| 87 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 105 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 88 kManifestUrl, &share_target_info_dict)); | 106 kManifestUrl, &share_target_info_dict)); |
| 89 EXPECT_EQ(1UL, share_target_info_dict->size()); | 107 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 90 std::string url_template_in_dict; | 108 std::string url_template_in_dict; |
| 91 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 109 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 92 &url_template_in_dict)); | 110 &url_template_in_dict)); |
| 93 EXPECT_EQ(url_template_in_dict, kUrlTemplate); | 111 EXPECT_EQ(kUrlTemplate, url_template_in_dict); |
| 94 | 112 |
| 95 // Add same share target to prefs that was previously stored; shouldn't | 113 // Add same share target to prefs that was previously stored; shouldn't |
| 96 // duplicate it. | 114 // duplicate it. |
| 97 UpdateShareTargetInPrefs(kManifestUrl, kUrlTemplate, pref_service()); | 115 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 98 | 116 |
| 99 share_target_dict = | 117 share_target_dict = |
| 100 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 118 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 101 EXPECT_EQ(1UL, share_target_dict->size()); | 119 EXPECT_EQ(1UL, share_target_dict->size()); |
| 102 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 120 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 103 kManifestUrl, &share_target_info_dict)); | 121 kManifestUrl, &share_target_info_dict)); |
| 104 EXPECT_EQ(1UL, share_target_info_dict->size()); | 122 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 105 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 123 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 106 &url_template_in_dict)); | 124 &url_template_in_dict)); |
| 107 EXPECT_EQ(url_template_in_dict, kUrlTemplate); | 125 EXPECT_EQ(kUrlTemplate, url_template_in_dict); |
| 108 } | 126 } |
| 109 | 127 |
| 110 TEST_F(ShareTargetPrefHelperUnittest, UpdateShareTarget) { | 128 TEST_F(ShareTargetPrefHelperUnittest, UpdateShareTarget) { |
| 111 // Add a share target to prefs that wasn't previously stored. | 129 // Add a share target to prefs that wasn't previously stored. |
| 112 std::string manifest_url = "https://www.sharetarget.com/manifest.json"; | 130 GURL manifest_url("https://www.sharetarget.com/manifest.json"); |
| 113 base::Optional<std::string> url_template = | 131 content::Manifest::ShareTarget share_target; |
| 114 base::Optional<std::string>("share/?title={title}"); | 132 std::string url_template = "share/?title={title}"; |
| 133 share_target.url_template = | |
| 134 base::NullableString16(base::ASCIIToUTF16(url_template), false); | |
| 135 content::Manifest manifest; | |
| 136 manifest.share_target = | |
| 137 base::Optional<content::Manifest::ShareTarget>(share_target); | |
| 115 | 138 |
| 116 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 139 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 117 | 140 |
| 118 const base::DictionaryValue* share_target_dict = | 141 const base::DictionaryValue* share_target_dict = |
| 119 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 142 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 120 EXPECT_EQ(1UL, share_target_dict->size()); | 143 EXPECT_EQ(1UL, share_target_dict->size()); |
| 121 const base::DictionaryValue* share_target_info_dict = nullptr; | 144 const base::DictionaryValue* share_target_info_dict = nullptr; |
| 122 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 145 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 123 manifest_url, &share_target_info_dict)); | 146 manifest_url.spec(), &share_target_info_dict)); |
| 124 EXPECT_EQ(1UL, share_target_info_dict->size()); | 147 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 125 std::string url_template_in_dict; | 148 std::string url_template_in_dict; |
| 126 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 149 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 127 &url_template_in_dict)); | 150 &url_template_in_dict)); |
| 128 EXPECT_EQ(url_template_in_dict, url_template); | 151 EXPECT_EQ(url_template, url_template_in_dict); |
| 129 | 152 |
| 130 // Add same share target to prefs that was previously stored, with new | 153 // Add same share target to prefs that was previously stored, with new |
| 131 // url_template_in_dict; should update the value. | 154 // url_template_in_dict; should update the value. |
| 132 manifest_url = "https://www.sharetarget.com/manifest.json"; | 155 url_template = "share/?title={title}&text={text}"; |
| 133 url_template = | 156 manifest.share_target.value().url_template = |
| 134 base::Optional<std::string>("share/?title={title}&text={text}"); | 157 base::NullableString16(base::ASCIIToUTF16(url_template), false); |
| 135 | 158 |
| 136 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 159 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 137 | 160 |
| 138 share_target_dict = | 161 share_target_dict = |
| 139 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 162 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 140 EXPECT_EQ(1UL, share_target_dict->size()); | 163 EXPECT_EQ(1UL, share_target_dict->size()); |
| 141 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 164 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 142 manifest_url, &share_target_info_dict)); | 165 manifest_url.spec(), &share_target_info_dict)); |
| 143 EXPECT_EQ(1UL, share_target_info_dict->size()); | 166 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 144 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 167 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 145 &url_template_in_dict)); | 168 &url_template_in_dict)); |
| 146 EXPECT_EQ(url_template_in_dict, url_template); | 169 EXPECT_EQ(url_template, url_template_in_dict); |
| 147 } | 170 } |
| 148 | 171 |
| 149 TEST_F(ShareTargetPrefHelperUnittest, DontAddNonShareTarget) { | 172 TEST_F(ShareTargetPrefHelperUnittest, DontAddNonShareTarget) { |
| 150 const char kManifestUrl[] = "https://www.dudsharetarget.com/manifest.json"; | 173 const char kManifestUrl[] = "https://www.dudsharetarget.com/manifest.json"; |
| 151 const base::Optional<std::string> kUrlTemplate; | 174 const base::Optional<std::string> kUrlTemplate; |
| 152 | 175 |
| 153 // Don't add a site that has a null template. | 176 // Don't add a site that has a null template. |
| 154 UpdateShareTargetInPrefs(kManifestUrl, kUrlTemplate, pref_service()); | 177 UpdateShareTargetInPrefs(GURL(kManifestUrl), content::Manifest(), |
| 178 pref_service()); | |
| 155 | 179 |
| 156 const base::DictionaryValue* share_target_dict = | 180 const base::DictionaryValue* share_target_dict = |
| 157 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 181 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 158 EXPECT_EQ(0UL, share_target_dict->size()); | 182 EXPECT_EQ(0UL, share_target_dict->size()); |
| 159 const base::DictionaryValue* share_target_info_dict = nullptr; | 183 const base::DictionaryValue* share_target_info_dict = nullptr; |
| 160 ASSERT_FALSE(share_target_dict->GetDictionaryWithoutPathExpansion( | 184 ASSERT_FALSE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 161 kManifestUrl, &share_target_info_dict)); | 185 kManifestUrl, &share_target_info_dict)); |
| 162 } | 186 } |
| 163 | 187 |
| 164 TEST_F(ShareTargetPrefHelperUnittest, RemoveShareTarget) { | 188 TEST_F(ShareTargetPrefHelperUnittest, RemoveShareTarget) { |
| 165 // Add a share target to prefs that wasn't previously stored. | 189 // Add a share target to prefs that wasn't previously stored. |
| 166 std::string manifest_url = "https://www.sharetarget.com/manifest.json"; | 190 GURL manifest_url("https://www.sharetarget.com/manifest.json"); |
| 167 base::Optional<std::string> url_template = | 191 content::Manifest::ShareTarget share_target; |
| 168 base::Optional<std::string>("share/?title={title}"); | 192 std::string url_template = "share/?title={title}"; |
| 193 share_target.url_template = | |
| 194 base::NullableString16(base::ASCIIToUTF16(url_template), false); | |
| 195 content::Manifest manifest; | |
| 196 manifest.share_target = | |
| 197 base::Optional<content::Manifest::ShareTarget>(share_target); | |
| 169 | 198 |
| 170 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 199 UpdateShareTargetInPrefs(manifest_url, manifest, pref_service()); |
| 171 | 200 |
| 172 const base::DictionaryValue* share_target_dict = | 201 const base::DictionaryValue* share_target_dict = |
| 173 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 202 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 174 EXPECT_EQ(1UL, share_target_dict->size()); | 203 EXPECT_EQ(1UL, share_target_dict->size()); |
| 175 const base::DictionaryValue* share_target_info_dict = nullptr; | 204 const base::DictionaryValue* share_target_info_dict = nullptr; |
| 176 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( | 205 ASSERT_TRUE(share_target_dict->GetDictionaryWithoutPathExpansion( |
| 177 manifest_url, &share_target_info_dict)); | 206 manifest_url.spec(), &share_target_info_dict)); |
| 178 EXPECT_EQ(1UL, share_target_info_dict->size()); | 207 EXPECT_EQ(1UL, share_target_info_dict->size()); |
| 179 std::string url_template_in_dict; | 208 std::string url_template_in_dict; |
| 180 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, | 209 EXPECT_TRUE(share_target_info_dict->GetString(kUrlTemplateKey, |
| 181 &url_template_in_dict)); | 210 &url_template_in_dict)); |
| 182 EXPECT_EQ(url_template_in_dict, url_template); | 211 EXPECT_EQ(url_template, url_template_in_dict); |
| 183 | 212 |
| 184 // Share target already added now has null template. Remove from prefs. | 213 // Share target already added now has null template. Remove from prefs. |
| 185 manifest_url = "https://www.sharetarget.com/manifest.json"; | 214 manifest_url = GURL("https://www.sharetarget.com/manifest.json"); |
| 186 url_template = base::nullopt; | |
| 187 | 215 |
| 188 UpdateShareTargetInPrefs(manifest_url, url_template, pref_service()); | 216 UpdateShareTargetInPrefs(manifest_url, content::Manifest(), pref_service()); |
| 189 | 217 |
| 190 share_target_dict = | 218 share_target_dict = |
| 191 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); | 219 pref_service()->GetDictionary(prefs::kWebShareVisitedTargets); |
| 192 EXPECT_EQ(0UL, share_target_dict->size()); | 220 EXPECT_EQ(0UL, share_target_dict->size()); |
| 193 } | 221 } |
| 194 | 222 |
| 195 } // namespace | 223 } // namespace |
| OLD | NEW |