OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/bind.h" | 5 #include "base/bind.h" |
6 #include "base/memory/ref_counted.h" | 6 #include "base/memory/ref_counted.h" |
7 #include "base/run_loop.h" | 7 #include "base/run_loop.h" |
8 #include "chrome/browser/extensions/extension_install_prompt.h" | 8 #include "chrome/browser/extensions/extension_install_prompt.h" |
9 #include "content/public/test/test_browser_thread_bundle.h" | 9 #include "content/public/test/test_browser_thread_bundle.h" |
10 #include "extensions/common/extension.h" | 10 #include "extensions/common/extension.h" |
11 #include "extensions/common/extension_builder.h" | 11 #include "extensions/common/extension_builder.h" |
12 #include "extensions/common/feature_switch.h" | |
12 #include "extensions/common/permissions/api_permission.h" | 13 #include "extensions/common/permissions/api_permission.h" |
13 #include "extensions/common/permissions/api_permission_set.h" | 14 #include "extensions/common/permissions/api_permission_set.h" |
14 #include "extensions/common/permissions/manifest_permission_set.h" | 15 #include "extensions/common/permissions/manifest_permission_set.h" |
15 #include "extensions/common/permissions/permission_set.h" | 16 #include "extensions/common/permissions/permission_set.h" |
16 #include "extensions/common/url_pattern_set.h" | 17 #include "extensions/common/url_pattern_set.h" |
17 #include "extensions/common/value_builder.h" | 18 #include "extensions/common/value_builder.h" |
18 #include "testing/gtest/include/gtest/gtest.h" | 19 #include "testing/gtest/include/gtest/gtest.h" |
19 | 20 |
20 namespace extensions { | 21 namespace extensions { |
21 | 22 |
22 void VerifyPromptPermissionsCallback( | 23 void VerifyPromptPermissionsCallback( |
23 const base::Closure& quit_closure, | 24 const base::Closure& quit_closure, |
25 size_t regular_permissions_count, | |
26 size_t withheld_permissions_count, | |
24 const ExtensionInstallPrompt::ShowParams& params, | 27 const ExtensionInstallPrompt::ShowParams& params, |
25 ExtensionInstallPrompt::Delegate* delegate, | 28 ExtensionInstallPrompt::Delegate* delegate, |
26 scoped_refptr<ExtensionInstallPrompt::Prompt> install_prompt) { | 29 scoped_refptr<ExtensionInstallPrompt::Prompt> install_prompt) { |
27 ASSERT_TRUE(install_prompt.get()); | 30 ASSERT_TRUE(install_prompt.get()); |
28 EXPECT_EQ(1u, install_prompt->GetPermissionCount()); | 31 EXPECT_EQ(regular_permissions_count, |
32 install_prompt->GetPermissionCount( | |
33 ExtensionInstallPrompt::REGULAR_PERMISSIONS)); | |
34 EXPECT_EQ(withheld_permissions_count, | |
35 install_prompt->GetPermissionCount( | |
36 ExtensionInstallPrompt::WITHHELD_PERMISSIONS)); | |
29 quit_closure.Run(); | 37 quit_closure.Run(); |
30 } | 38 } |
31 | 39 |
32 TEST(ExtensionInstallPromptUnittest, PromptShowsPermissionWarnings) { | 40 TEST(ExtensionInstallPromptUnittest, PromptShowsPermissionWarnings) { |
33 content::TestBrowserThreadBundle thread_bundle; | 41 content::TestBrowserThreadBundle thread_bundle; |
34 APIPermissionSet api_permissions; | 42 APIPermissionSet api_permissions; |
35 api_permissions.insert(APIPermission::kTab); | 43 api_permissions.insert(APIPermission::kTab); |
36 scoped_refptr<PermissionSet> permission_set = | 44 scoped_refptr<PermissionSet> permission_set = |
37 new PermissionSet(api_permissions, | 45 new PermissionSet(api_permissions, |
38 ManifestPermissionSet(), | 46 ManifestPermissionSet(), |
39 URLPatternSet(), | 47 URLPatternSet(), |
40 URLPatternSet()); | 48 URLPatternSet()); |
41 scoped_refptr<const Extension> extension = | 49 scoped_refptr<const Extension> extension = |
42 ExtensionBuilder().SetManifest( | 50 ExtensionBuilder().SetManifest( |
43 DictionaryBuilder().Set("name", "foo") | 51 DictionaryBuilder().Set("name", "foo") |
44 .Set("version", "1.0") | 52 .Set("version", "1.0") |
45 .Set("manifest_version", 2) | 53 .Set("manifest_version", 2) |
46 .Set("description", "Random Ext")).Build(); | 54 .Set("description", "Random Ext")).Build(); |
47 ExtensionInstallPrompt prompt(NULL /* no web contents in this test */); | 55 ExtensionInstallPrompt prompt(NULL /* no web contents in this test */); |
48 base::RunLoop run_loop; | 56 base::RunLoop run_loop; |
49 prompt.set_callback_for_test(base::Bind(&VerifyPromptPermissionsCallback, | 57 prompt.set_callback_for_test(base::Bind(&VerifyPromptPermissionsCallback, |
50 run_loop.QuitClosure())); | 58 run_loop.QuitClosure(), |
59 1u, // regular_permissions_count | |
Finnur
2014/09/15 11:45:28
nit: Think I'd prefer:
// |regular_permissions_cou
gpdavis
2014/09/15 20:04:07
Done.
Finnur
2014/09/16 10:18:11
... with the period at the end. :)
gpdavis
2014/09/16 19:01:47
Oops! Wasn't sure if that period was meant to be
| |
60 0u)); // withheld_permissions_count | |
51 prompt.ConfirmPermissions(NULL, // no delegate | 61 prompt.ConfirmPermissions(NULL, // no delegate |
52 extension.get(), | 62 extension.get(), |
53 permission_set.get()); | 63 permission_set.get()); |
54 run_loop.Run(); | 64 run_loop.Run(); |
55 } | 65 } |
56 | 66 |
67 TEST(ExtensionInstallPromptUnittest, PromptShowsWithheldPermissions) { | |
68 content::TestBrowserThreadBundle thread_bundle; | |
69 | |
70 // Enable consent flag so that <all_hosts> permissions get withheld. | |
71 FeatureSwitch::ScopedOverride enable_scripts_switch( | |
72 FeatureSwitch::scripts_require_action(), true); | |
73 | |
74 ListBuilder permissions; | |
75 permissions.Append("http://*/*"); | |
76 permissions.Append("http://www.google.com/"); | |
77 permissions.Append("tabs"); | |
78 scoped_refptr<const Extension> extension = | |
79 ExtensionBuilder().SetManifest( | |
80 DictionaryBuilder().Set("name", "foo") | |
81 .Set("version", "1.0") | |
82 .Set("manifest_version", 2) | |
83 .Set("description", "Random Ext") | |
84 .Set("permissions", permissions)).Build(); | |
85 ExtensionInstallPrompt prompt(NULL /* no web contents in this test */); | |
86 base::RunLoop run_loop; | |
87 | |
88 // We expect <all_hosts> to be withheld, but http://www.google.com/ and tabs | |
89 // permissions should be granted as regular permissions. | |
90 prompt.ConfirmInstall( | |
91 NULL, | |
92 extension.get(), | |
93 base::Bind(&VerifyPromptPermissionsCallback, | |
94 run_loop.QuitClosure(), | |
95 2u, // regular_permissions_count | |
96 1u)); // withheld_permissions_count | |
97 run_loop.Run(); | |
98 } | |
99 | |
57 } // namespace extensions | 100 } // namespace extensions |
OLD | NEW |