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/strings/stringprintf.h" | 5 #include "base/strings/stringprintf.h" |
6 #include "chrome/common/extensions/manifest_tests/chrome_manifest_test.h" | 6 #include "chrome/common/extensions/manifest_tests/chrome_manifest_test.h" |
7 #include "extensions/common/error_utils.h" | 7 #include "extensions/common/error_utils.h" |
8 #include "extensions/common/feature_switch.h" | 8 #include "extensions/common/feature_switch.h" |
9 #include "extensions/common/manifest_constants.h" | 9 #include "extensions/common/manifest_constants.h" |
10 #include "extensions/common/manifest_handlers/options_page_info.h" | 10 #include "extensions/common/manifest_handlers/options_page_info.h" |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
58 extension = LoadAndExpectSuccess("options_ui_page_with_legacy_page.json"); | 58 extension = LoadAndExpectSuccess("options_ui_page_with_legacy_page.json"); |
59 EXPECT_EQ(base::StringPrintf("chrome-extension://%s/newoptions.html", | 59 EXPECT_EQ(base::StringPrintf("chrome-extension://%s/newoptions.html", |
60 extension.get()->id().c_str()), | 60 extension.get()->id().c_str()), |
61 OptionsPageInfo::GetOptionsPage(extension.get()).spec()); | 61 OptionsPageInfo::GetOptionsPage(extension.get()).spec()); |
62 | 62 |
63 Testcase testcases[] = {Testcase("options_ui_page_bad_url.json", | 63 Testcase testcases[] = {Testcase("options_ui_page_bad_url.json", |
64 "'page': expected page, got null")}; | 64 "'page': expected page, got null")}; |
65 RunTestcases(testcases, arraysize(testcases), EXPECT_TYPE_WARNING); | 65 RunTestcases(testcases, arraysize(testcases), EXPECT_TYPE_WARNING); |
66 } | 66 } |
67 | 67 |
68 // Tests for the options_ui.chrome_style and options_ui.open_in_tab fields. | 68 // Tests for the options_ui.chrome_style and options_ui.open_in_tab fields with |
| 69 // the flag enabled. This makes open_in_tab default to true if unspecified. |
69 TEST_F(OptionsPageManifestTest, OptionsUIChromeStyleAndOpenInTab) { | 70 TEST_F(OptionsPageManifestTest, OptionsUIChromeStyleAndOpenInTab) { |
70 FeatureSwitch::ScopedOverride enable_flag( | 71 FeatureSwitch::ScopedOverride enable_flag( |
71 FeatureSwitch::embedded_extension_options(), true); | 72 FeatureSwitch::embedded_extension_options(), true); |
72 | 73 |
| 74 // Explicitly specifying true in the manifest for options_ui.chrome_style and |
| 75 // options_ui.open_in_tab sets them both to true. |
| 76 scoped_refptr<Extension> extension = |
| 77 LoadAndExpectSuccess("options_ui_flags_true.json"); |
| 78 EXPECT_TRUE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
| 79 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
| 80 |
| 81 // Explicitly specifying false in the manifest for options_ui.chrome_style |
| 82 // and options_ui.open_in_tab sets them both to false. |
| 83 extension = LoadAndExpectSuccess("options_ui_flags_false.json"); |
| 84 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
| 85 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
| 86 |
| 87 // Specifying an options_ui key but neither options_ui.chrome_style nor |
| 88 // options_ui.open_in_tab uses the default values: false for open-in-tab, |
| 89 // false for use-chrome-style. |
| 90 extension = LoadAndExpectSuccess("options_ui_page_basic.json"); |
| 91 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
| 92 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
| 93 |
| 94 // Likewise specifying no options_ui key at all. |
| 95 extension = LoadAndExpectSuccess("init_valid_options.json"); |
| 96 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
| 97 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
| 98 } |
| 99 |
| 100 // Tests for the options_ui.chrome_style and options_ui.open_in_tab fields when |
| 101 // the flag for embedded extension options is turned off. This makes |
| 102 // open_in_tab default to false. |
| 103 TEST_F(OptionsPageManifestTest, OptionsUIChromeStyleAndOpenInTabNoFlag) { |
| 104 ASSERT_FALSE(FeatureSwitch::embedded_extension_options()->IsEnabled()); |
| 105 |
| 106 // These conditions are the same as OptionsUIChromeStyleAndOpenInTab, except |
| 107 // when the flag is off the default for open-in-tab is true. |
| 108 |
73 scoped_refptr<Extension> extension = | 109 scoped_refptr<Extension> extension = |
74 LoadAndExpectSuccess("options_ui_flags_true.json"); | 110 LoadAndExpectSuccess("options_ui_flags_true.json"); |
75 EXPECT_TRUE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | 111 EXPECT_TRUE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
76 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | 112 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
77 | 113 |
78 extension = LoadAndExpectSuccess("options_ui_flags_false.json"); | 114 extension = LoadAndExpectSuccess("options_ui_flags_false.json"); |
79 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | 115 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
80 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | 116 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
81 | 117 |
82 // If chrome_style and open_in_tab are not set, they should be false. | |
83 extension = LoadAndExpectSuccess("options_ui_page_basic.json"); | 118 extension = LoadAndExpectSuccess("options_ui_page_basic.json"); |
84 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | 119 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
85 EXPECT_FALSE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | |
86 } | |
87 | |
88 // Tests for the options_ui.chrome_style and options_ui.open_in_tab fields when | |
89 // the flag for embedded extension options is turned off. chrome_style should | |
90 // always be false, open_in_tab should always be true. | |
91 TEST_F(OptionsPageManifestTest, OptionsUIChromeStyleAndOpenInTabNoFlag) { | |
92 ASSERT_FALSE(FeatureSwitch::embedded_extension_options()->IsEnabled()); | |
93 | |
94 scoped_refptr<Extension> extension = | |
95 LoadAndExpectSuccess("options_ui_flags_true.json"); | |
96 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | |
97 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | 120 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
98 | 121 |
99 extension = LoadAndExpectSuccess("options_ui_flags_false.json"); | 122 extension = LoadAndExpectSuccess("init_valid_options.json"); |
100 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | |
101 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | |
102 | |
103 extension = LoadAndExpectSuccess("options_ui_page_basic.json"); | |
104 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); | 123 EXPECT_FALSE(OptionsPageInfo::ShouldUseChromeStyle(extension.get())); |
105 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); | 124 EXPECT_TRUE(OptionsPageInfo::ShouldOpenInTab(extension.get())); |
106 } | 125 } |
OLD | NEW |