diff options
author | scr@chromium.org <scr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-10-22 01:46:03 +0000 |
---|---|---|
committer | scr@chromium.org <scr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-10-22 01:46:03 +0000 |
commit | 4ba1dbcc38a8843703a3494eef053644c00d813c (patch) | |
tree | b411df17bd40c08df07653931356459dfa1d40f3 /chrome/browser/ui/webui/options/options_browsertest.js | |
parent | 3eb8314456f9c3aa5c791db67cb71718e4dd9c66 (diff) | |
download | chromium_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.js | 121 |
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); + } +}); |