Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(368)

Unified Diff: chrome/test/data/webui/settings/settings_page_browsertest.js

Issue 1457543004: Add Mocha based tests for Settings pages (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/test/data/webui/settings/settings_page_browsertest.js
diff --git a/chrome/test/data/webui/settings/settings_page_browsertest.js b/chrome/test/data/webui/settings/settings_page_browsertest.js
new file mode 100644
index 0000000000000000000000000000000000000000..9313da26ac9b70b64485e321ef42f22f77d12368
--- /dev/null
+++ b/chrome/test/data/webui/settings/settings_page_browsertest.js
@@ -0,0 +1,59 @@
+// Copyright 2015 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.
+
+/** @fileoverview Prototype for Settings page tests. */
+
+/** @const {string} Path to root from chrome/test/data/webui/settings/. */
+var ROOT_PATH = '../../../../../';
+
+// Polymer BrowserTest fixture.
+GEN_INCLUDE(
+ [ROOT_PATH + 'chrome/test/data/webui/polymer_browser_test_base.js']);
+
+/**
+ * @constructor
+ * @extends {PolymerTest}
+*/
+function SettingsPageBrowserTest() {}
+
+SettingsPageBrowserTest.prototype = {
+ __proto__: PolymerTest.prototype,
+
+ /** @override */
+ browsePreload: 'chrome://md-settings/',
+
+ /** @override */
+ extraLibraries: PolymerTest.getLibraries(ROOT_PATH),
+
+ runAccessibilityChecks: false,
+
+ getPage: function(type) {
dpapad 2015/11/18 01:44:54 Can we add type annotations for all parameters and
stevenjb 2015/11/18 20:02:33 Done.
+ var settings = document.querySelector('cr-settings');
+ assertTrue(!!settings);
dpapad 2015/11/18 01:44:54 How about assertNotNull(settings);
stevenjb 2015/11/18 20:02:33 ReferenceError: assertNotNull is not defined I do
+ var settingsUi = settings.shadowRoot.querySelector('settings-ui');
+ assertTrue(!!settingsUi);
+ var settingsMain = settingsUi.shadowRoot.querySelector('settings-main');
+ assertTrue(!!settingsMain);
+ var pages = settingsMain.$.pageContainer;
+ assertTrue(!!pages);
+ var pageType = 'settings-' + type + '-page';
dpapad 2015/11/18 01:44:54 @dbeam Can we start using relatively new v8 featur
+ var page = pages.querySelector(pageType);
+ assertTrue(!!page);
+ return page;
+ },
+
+ getSection: function(page, section) {
+ var sections = page.shadowRoot.querySelectorAll('settings-section');
+ assertTrue(!!sections);
+ var len = sections.length;
+ assertGT(len, 0);
+ for (var i = 0; i < len; ++i) {
+ var s = sections[i];
+ if (s.section == section)
+ return s;
+ }
+ assertNotReached('Section not found: ' + section + ' in ' + page);
+ return undefined;
+ },
+};

Powered by Google App Engine
This is Rietveld 408576698