// Copyright (c) 2010 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "chrome/browser/extensions/extension_apitest.h" #include "chrome/common/chrome_switches.h" class ExperimentalApiTest : public ExtensionApiTest { public: void SetUpCommandLine(CommandLine* command_line) { ExtensionApiTest::SetUpCommandLine(command_line); command_line->AppendSwitch(switches::kEnableExperimentalExtensionApis); } }; IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PermissionsFail) { ASSERT_TRUE(RunExtensionTest("permissions/disabled")) << message_; // Since the experimental APIs require a flag, this will fail even though // It's enabled. // TODO(erikkay) This test is currently broken because LoadExtension in // ExtensionBrowserTest doesn't actually fail, it just times out. To fix this // I'll need to add an EXTENSION_LOAD_ERROR notification, which is probably // too much for the branch. I'll enable this on trunk later. //ASSERT_FALSE(RunExtensionTest("permissions/enabled"))) << message_; } IN_PROC_BROWSER_TEST_F(ExperimentalApiTest, PermissionsSucceed) { ASSERT_TRUE(RunExtensionTest("permissions/enabled")) << message_; } IN_PROC_BROWSER_TEST_F(ExtensionApiTest, ExperimentalPermissionsFail) { // At the time this test is being created, there is no experimental // function that will not be graduating soon, and does not require a // tab id as an argument. So, we need the tab permission to get // a tab id. ASSERT_TRUE(RunExtensionTest("permissions/experimental_disabled")) << message_; } IN_PROC_BROWSER_TEST_F(ExtensionApiTest, FavIconPermission) { ASSERT_TRUE(RunExtensionTest("permissions/favicon")) << message_; } // Test functions and APIs that are always allowed (even if you ask for no // permissions. IN_PROC_BROWSER_TEST_F(ExtensionApiTest, AlwaysAllowed) { ASSERT_TRUE(RunExtensionTest("permissions/always_allowed")) << message_; } // TODO(gregoryd): run the NaCl test on all systems once // http://code.google.com/p/chromium/issues/detail?id=51335 is fixed. // Meanwhile we run it on Mac OSX only, since we can be sure that an x86-32 NaCl // module will work there. // Mark as Flaky. http://crbug.com/51861 // // FLAKY --> DISABLED since it takes 10sec to timeout a dialog. Need // faster timeout. #if defined(OS_MACOSX) IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_NaClPermissionEnabled) { CommandLine::ForCurrentProcess()->AppendSwitch(switches::kInternalNaCl); ASSERT_TRUE(RunExtensionTest("permissions/nacl_enabled")) << message_; } #endif