| 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/memory/scoped_ptr.h" | 5 #include "base/memory/scoped_ptr.h" |
| 6 #include "base/values.h" | 6 #include "base/values.h" |
| 7 #include "chrome/browser/extensions/api/permissions/permissions_api_helpers.h" | 7 #include "chrome/browser/extensions/api/permissions/permissions_api_helpers.h" |
| 8 #include "chrome/common/extensions/api/permissions.h" | 8 #include "chrome/common/extensions/api/permissions.h" |
| 9 #include "extensions/common/permissions/permission_set.h" | 9 #include "extensions/common/permissions/permission_set.h" |
| 10 #include "extensions/common/url_pattern_set.h" | 10 #include "extensions/common/url_pattern_set.h" |
| (...skipping 18 matching lines...) Expand all Loading... |
| 29 // Tests that we can convert PermissionSets to and from values. | 29 // Tests that we can convert PermissionSets to and from values. |
| 30 TEST(ExtensionPermissionsAPIHelpers, Pack) { | 30 TEST(ExtensionPermissionsAPIHelpers, Pack) { |
| 31 APIPermissionSet apis; | 31 APIPermissionSet apis; |
| 32 apis.insert(APIPermission::kTab); | 32 apis.insert(APIPermission::kTab); |
| 33 apis.insert(APIPermission::kFileBrowserHandler); | 33 apis.insert(APIPermission::kFileBrowserHandler); |
| 34 // Note: kFileBrowserHandler implies kFileBrowserHandlerInternal. | 34 // Note: kFileBrowserHandler implies kFileBrowserHandlerInternal. |
| 35 URLPatternSet hosts; | 35 URLPatternSet hosts; |
| 36 AddPattern(&hosts, "http://a.com/*"); | 36 AddPattern(&hosts, "http://a.com/*"); |
| 37 AddPattern(&hosts, "http://b.com/*"); | 37 AddPattern(&hosts, "http://b.com/*"); |
| 38 | 38 |
| 39 scoped_refptr<const PermissionSet> permission_set = | 39 PermissionSet permission_set(apis, ManifestPermissionSet(), hosts, |
| 40 new PermissionSet(apis, ManifestPermissionSet(), hosts, URLPatternSet()); | 40 URLPatternSet()); |
| 41 | 41 |
| 42 // Pack the permission set to value and verify its contents. | 42 // Pack the permission set to value and verify its contents. |
| 43 scoped_ptr<Permissions> permissions(PackPermissionSet(permission_set.get())); | 43 scoped_ptr<Permissions> permissions(PackPermissionSet(&permission_set)); |
| 44 scoped_ptr<base::DictionaryValue> value(permissions->ToValue()); | 44 scoped_ptr<base::DictionaryValue> value(permissions->ToValue()); |
| 45 base::ListValue* api_list = NULL; | 45 base::ListValue* api_list = NULL; |
| 46 base::ListValue* origin_list = NULL; | 46 base::ListValue* origin_list = NULL; |
| 47 EXPECT_TRUE(value->GetList("permissions", &api_list)); | 47 EXPECT_TRUE(value->GetList("permissions", &api_list)); |
| 48 EXPECT_TRUE(value->GetList("origins", &origin_list)); | 48 EXPECT_TRUE(value->GetList("origins", &origin_list)); |
| 49 | 49 |
| 50 EXPECT_EQ(3u, api_list->GetSize()); | 50 EXPECT_EQ(3u, api_list->GetSize()); |
| 51 EXPECT_EQ(2u, origin_list->GetSize()); | 51 EXPECT_EQ(2u, origin_list->GetSize()); |
| 52 | 52 |
| 53 std::string expected_apis[] = {"tabs", "fileBrowserHandler", | 53 std::string expected_apis[] = {"tabs", "fileBrowserHandler", |
| 54 "fileBrowserHandlerInternal"}; | 54 "fileBrowserHandlerInternal"}; |
| 55 for (size_t i = 0; i < arraysize(expected_apis); ++i) { | 55 for (size_t i = 0; i < arraysize(expected_apis); ++i) { |
| 56 scoped_ptr<base::Value> value(new base::StringValue(expected_apis[i])); | 56 scoped_ptr<base::Value> value(new base::StringValue(expected_apis[i])); |
| 57 EXPECT_NE(api_list->end(), api_list->Find(*value)); | 57 EXPECT_NE(api_list->end(), api_list->Find(*value)); |
| 58 } | 58 } |
| 59 | 59 |
| 60 std::string expected_origins[] = { "http://a.com/*", "http://b.com/*" }; | 60 std::string expected_origins[] = { "http://a.com/*", "http://b.com/*" }; |
| 61 for (size_t i = 0; i < arraysize(expected_origins); ++i) { | 61 for (size_t i = 0; i < arraysize(expected_origins); ++i) { |
| 62 scoped_ptr<base::Value> value(new base::StringValue(expected_origins[i])); | 62 scoped_ptr<base::Value> value(new base::StringValue(expected_origins[i])); |
| 63 EXPECT_NE(origin_list->end(), origin_list->Find(*value)); | 63 EXPECT_NE(origin_list->end(), origin_list->Find(*value)); |
| 64 } | 64 } |
| 65 | 65 |
| 66 // Unpack the value back to a permission set and make sure its equal to the | 66 // Unpack the value back to a permission set and make sure its equal to the |
| 67 // original one. | 67 // original one. |
| 68 scoped_refptr<const PermissionSet> from_value; | |
| 69 std::string error; | 68 std::string error; |
| 70 Permissions permissions_object; | 69 Permissions permissions_object; |
| 71 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); | 70 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); |
| 72 from_value = UnpackPermissionSet(permissions_object, true, &error); | 71 scoped_ptr<const PermissionSet> from_value = |
| 72 UnpackPermissionSet(permissions_object, true, &error); |
| 73 EXPECT_TRUE(error.empty()); | 73 EXPECT_TRUE(error.empty()); |
| 74 | 74 |
| 75 EXPECT_EQ(*permission_set.get(), *from_value.get()); | 75 EXPECT_EQ(permission_set, *from_value); |
| 76 } | 76 } |
| 77 | 77 |
| 78 // Tests various error conditions and edge cases when unpacking values | 78 // Tests various error conditions and edge cases when unpacking values |
| 79 // into PermissionSets. | 79 // into PermissionSets. |
| 80 TEST(ExtensionPermissionsAPIHelpers, Unpack) { | 80 TEST(ExtensionPermissionsAPIHelpers, Unpack) { |
| 81 scoped_ptr<base::ListValue> apis(new base::ListValue()); | 81 scoped_ptr<base::ListValue> apis(new base::ListValue()); |
| 82 apis->Append(new base::StringValue("tabs")); | 82 apis->Append(new base::StringValue("tabs")); |
| 83 scoped_ptr<base::ListValue> origins(new base::ListValue()); | 83 scoped_ptr<base::ListValue> origins(new base::ListValue()); |
| 84 origins->Append(new base::StringValue("http://a.com/*")); | 84 origins->Append(new base::StringValue("http://a.com/*")); |
| 85 | 85 |
| 86 scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); | 86 scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); |
| 87 scoped_refptr<const PermissionSet> permissions; | 87 scoped_ptr<const PermissionSet> permissions; |
| 88 std::string error; | 88 std::string error; |
| 89 | 89 |
| 90 // Origins shouldn't have to be present. | 90 // Origins shouldn't have to be present. |
| 91 { | 91 { |
| 92 Permissions permissions_object; | 92 Permissions permissions_object; |
| 93 value->Set("permissions", apis->DeepCopy()); | 93 value->Set("permissions", apis->DeepCopy()); |
| 94 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); | 94 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); |
| 95 permissions = UnpackPermissionSet(permissions_object, true, &error); | 95 permissions = UnpackPermissionSet(permissions_object, true, &error); |
| 96 EXPECT_TRUE(permissions->HasAPIPermission(APIPermission::kTab)); | 96 EXPECT_TRUE(permissions->HasAPIPermission(APIPermission::kTab)); |
| 97 EXPECT_TRUE(permissions.get()); | 97 EXPECT_TRUE(permissions.get()); |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 167 value->Set("permissions", invalid_apis->DeepCopy()); | 167 value->Set("permissions", invalid_apis->DeepCopy()); |
| 168 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); | 168 EXPECT_TRUE(Permissions::Populate(*value, &permissions_object)); |
| 169 permissions = UnpackPermissionSet(permissions_object, true, &error); | 169 permissions = UnpackPermissionSet(permissions_object, true, &error); |
| 170 EXPECT_FALSE(permissions.get()); | 170 EXPECT_FALSE(permissions.get()); |
| 171 EXPECT_FALSE(error.empty()); | 171 EXPECT_FALSE(error.empty()); |
| 172 EXPECT_EQ(error, "'unknown_permission' is not a recognized permission."); | 172 EXPECT_EQ(error, "'unknown_permission' is not a recognized permission."); |
| 173 } | 173 } |
| 174 } | 174 } |
| 175 | 175 |
| 176 } // namespace extensions | 176 } // namespace extensions |
| OLD | NEW |