summaryrefslogtreecommitdiffstats
path: root/chrome/browser/ui/webui/options/options_browsertest.js
diff options
context:
space:
mode:
authorscr@chromium.org <scr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-10-22 01:46:03 +0000
committerscr@chromium.org <scr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-10-22 01:46:03 +0000
commit4ba1dbcc38a8843703a3494eef053644c00d813c (patch)
treeb411df17bd40c08df07653931356459dfa1d40f3 /chrome/browser/ui/webui/options/options_browsertest.js
parent3eb8314456f9c3aa5c791db67cb71718e4dd9c66 (diff)
downloadchromium_src-4ba1dbcc38a8843703a3494eef053644c00d813c.zip
chromium_src-4ba1dbcc38a8843703a3494eef053644c00d813c.tar.gz
chromium_src-4ba1dbcc38a8843703a3494eef053644c00d813c.tar.bz2
Allow generator javascript test files to go anywhere in the source tree
- Allow javascript files anywhere in the source tree - specifically in the same directory as the implementation files. - Copy the files to '<(PRODUCT_DIR)/test_data/...' so that cros can copy these where they need to go for cross-platform testing using 'ebuild' R=jhawkins@chromium.org BUG=90907,89337 TEST=browser_tests --gtest_filter=OptionsWebUITest.* Review URL: http://codereview.chromium.org/8333013 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@106833 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/ui/webui/options/options_browsertest.js')
-rw-r--r--chrome/browser/ui/webui/options/options_browsertest.js121
1 files changed, 121 insertions, 0 deletions
diff --git a/chrome/browser/ui/webui/options/options_browsertest.js b/chrome/browser/ui/webui/options/options_browsertest.js
new file mode 100644
index 0000000..e3ec6ab
--- /dev/null
+++ b/chrome/browser/ui/webui/options/options_browsertest.js
@@ -0,0 +1,121 @@
+// Copyright (c) 2011 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.
+
+/**
+ * TestFixture for OptionsPage WebUI testing.
+ * @extends {testing.Test}
+ * @constructor
+ */
+function OptionsWebUITest() {}
+
+OptionsWebUITest.prototype = {
+ __proto__: testing.Test.prototype,
+
+ /**
+ * Browse to the options page & call our preLoad().
+ */
+ browsePreload: 'chrome://settings',
+
+ /**
+ * Register a mock handler to ensure expectations are met and options pages
+ * behave correctly.
+ */
+ preLoad: function() {
+
+ /**
+ * Create handler class with empty methods to allow mocking to register
+ * expectations and for registration of handlers with chrome.send.
+ */
+ function MockOptionsHandler() {}
+
+ MockOptionsHandler.prototype = {
+ coreOptionsInitialize: function() {},
+ fetchPrefs: function() {},
+ observePrefs: function() {},
+ setBooleanPref: function() {},
+ setIntegerPref: function() {},
+ setDoublePref: function() {},
+ setStringPref: function() {},
+ setObjectPref: function() {},
+ clearPref: function() {},
+ coreOptionsUserMetricsAction: function() {},
+ // TODO(scr): Handle this new message:
+ // getInstantFieldTrialStatus: function() {},
+ };
+
+ // Create the actual mock and register stubs for methods expected to be
+ // called before our tests run. Specific expectations can be made in the
+ // tests themselves.
+ var mockHandler = this.mockHandler = mock(MockOptionsHandler);
+ mockHandler.stubs().fetchPrefs(ANYTHING);
+ mockHandler.stubs().observePrefs(ANYTHING);
+ mockHandler.stubs().coreOptionsInitialize();
+
+ // Register our mock as a handler of the chrome.send messages.
+ registerMockMessageCallbacks(mockHandler, MockOptionsHandler);
+ },
+};
+
+// Crashes on Mac only. See http://crbug.com/79181
+GEN('#if defined(OS_MACOSX)');
+GEN('#define MAYBE_testSetBooleanPrefTriggers ' +
+ 'DISABLED_testSetBooleanPrefTriggers');
+GEN('#else');
+GEN('#define MAYBE_testSetBooleanPrefTriggers testSetBooleanPrefTriggers');
+GEN('#endif // defined(OS_MACOSX)');
+
+TEST_F('OptionsWebUITest', 'MAYBE_testSetBooleanPrefTriggers', function() {
+ // TODO(dtseng): make generic to click all buttons.
+ var showHomeButton = $('toolbarShowHomeButton');
+ var trueListValue = [
+ 'browser.show_home_button',
+ true,
+ 'Options_Homepage_HomeButton',
+ ];
+ // Note: this expectation is checked in testing::Test::tearDown.
+ this.mockHandler.expects(once()).setBooleanPref(trueListValue);
+
+ // Cause the handler to be called.
+ showHomeButton.click();
+ showHomeButton.blur();
+});
+
+// Not meant to run on ChromeOS at this time.
+// Not finishing in windows. http://crbug.com/81723
+GEN('#if defined(OS_CHROMEOS) || defined(OS_MACOSX) || defined(OS_WIN) \\');
+GEN(' || defined(TOUCH_UI)');
+GEN('#define MAYBE_testRefreshStaysOnCurrentPage \\');
+GEN(' DISABLED_testRefreshStaysOnCurrentPage');
+GEN('#else');
+GEN('#define MAYBE_testRefreshStaysOnCurrentPage ' +
+ 'testRefreshStaysOnCurrentPage');
+GEN('#endif');
+
+TEST_F('OptionsWebUITest', 'MAYBE_testRefreshStaysOnCurrentPage', function() {
+ var item = $('advancedPageNav');
+ item.onclick();
+ window.location.reload();
+ var pageInstance = AdvancedOptions.getInstance();
+ var topPage = OptionsPage.getTopmostVisiblePage();
+ var expectedTitle = pageInstance.title;
+ var actualTitle = document.title;
+ assertEquals("chrome://settings/advanced", document.location.href);
+ assertEquals(expectedTitle, actualTitle);
+ assertEquals(pageInstance, topPage);
+});
+
+// Test that there are no console errors after opening all registered pages.
+// Crashes on chromium os, flaky on other platforms. See crbug.com/90420.
+// Disabling on Mac OS X since the failure rate is now >50%.
+GEN('#if defined(TOOLKIT_VIEWS) || defined(OS_MACOSX)');
+GEN('#define MAYBE_testOpenAllOptionsPages DISABLED_testOpenAllOptionsPages');
+GEN('#else');
+GEN('#define MAYBE_testOpenAllOptionsPages FLAKY_testOpenAllOptionsPages');
+GEN('#endif // defined(TOOLKIT_VIEWS)');
+TEST_F('OptionsWebUITest', 'MAYBE_testOpenAllOptionsPages', function() {
+ expectTrue(!!OptionsPage.registeredPages);
+ for (var name in OptionsPage.registeredPages) {
+ OptionsPage.showPageByName(name, false);
+ }
+});