Index: chrome/test/data/webui/settings/appearance_browsertest.js |
diff --git a/chrome/test/data/webui/settings/appearance_browsertest.js b/chrome/test/data/webui/settings/appearance_browsertest.js |
index 3c3e17a34fee8d5c3ba76a202f894fc4d3b529f9..f7941ab090e7e58d26975c53551ee8e7661746bb 100644 |
--- a/chrome/test/data/webui/settings/appearance_browsertest.js |
+++ b/chrome/test/data/webui/settings/appearance_browsertest.js |
@@ -2,73 +2,73 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-/** @fileoverview Runs Polymer Appearance Settings elements. */ |
+/** @fileoverview Runs polymer appearance font settings elements. */ |
-GEN_INCLUDE(['settings_page_browsertest.js']); |
+cr.define('settings_appearance', function() { |
+ /** |
+ * A test version of FontsBrowserProxy. |
+ * |
+ * @constructor |
+ * @implements {settings.FontsBrowserProxy} |
+ * @extends {settings.TestBrowserProxy} |
+ */ |
+ var TestFontsBrowserProxy = function() { |
+ settings.TestBrowserProxy.call(this, [ |
+ 'fetchFontsData', |
+ ]); |
+ }; |
-/** |
- * Test Polymer Appearance Settings elements. |
- * @constructor |
- * @extends {SettingsPageBrowserTest} |
-*/ |
-function AppearanceSettingsBrowserTest() {} |
+ TestFontsBrowserProxy.prototype = { |
+ __proto__: settings.TestBrowserProxy.prototype, |
-AppearanceSettingsBrowserTest.prototype = { |
- __proto__: SettingsPageBrowserTest.prototype, |
+ fontsData: { |
dpapad
2016/04/06 17:14:55
Since fontsData is not a function, it makes more s
dschuyler
2016/04/07 20:47:42
Done.
|
+ 'fontList': [['font name', 'alternate', 'ltr']], |
+ 'encodingList': [['encoding name', 'alternate', 'ltr']], |
+ }, |
- /** @return {string} */ |
- appearancePage: function(selector) { |
- var section = this.getSection(this.getPage('basic'), 'appearance'); |
- assertTrue(!!section); |
- var appearance = section.querySelector('settings-appearance-page'); |
- assertTrue(!!appearance); |
- var result = appearance.$$(selector); |
- assertTrue(!!result); |
- return result; |
- }, |
-}; |
+ /** |
dpapad
2016/04/06 17:14:55
/** @override */
dschuyler
2016/04/07 20:47:42
Done.
|
+ */ |
+ fetchFontsData: function() { |
+ this.methodCalled('fetchFontsData'); |
+ return Promise.resolve(this.fontsData); |
+ }, |
+ }; |
-TEST_F('AppearanceSettingsBrowserTest', 'uiTests', function() { |
- /** |
- * The prefs API that will get a fake implementation. |
- * @type {!SettingsPrivate} |
- */ |
- var settingsPrefs; |
- var self = this; |
+ function registerAppearanceFontSettingsBrowserTest() { |
+ var fontsEntry = null; |
dpapad
2016/04/06 17:14:55
Nit: s/fontsEntry/fontsPage or simply page?
dschuyler
2016/04/07 20:47:42
Done.
|
- var fontSize = function() { |
- return self.appearancePage( |
- '#defaultFontSize').$$('[class=iron-selected]').textContent.trim(); |
- }; |
+ /** @type {?TestFontsBrowserProxy} */ |
+ var fontsBrowserProxy = null; |
- suite('AppearanceHandler', function() { |
- suiteSetup(function() { |
- settingsPrefs = document.querySelector( |
- 'cr-settings').$$('settings-prefs'); |
- assertTrue(!!settingsPrefs); |
- return CrSettingsPrefs.initialized; |
- }); |
+ suite('AppearanceFontHandler', function() { |
+ setup(function() { |
+ fontsBrowserProxy = new TestFontsBrowserProxy(); |
+ settings.FontsBrowserProxyImpl.instance_ = fontsBrowserProxy; |
- test('very small font', function() { |
- settingsPrefs.set('prefs.webkit.webprefs.default_font_size.value', 9); |
- assertEquals('Very small', fontSize()); |
- }); |
+ PolymerTest.clearBody(); |
- test('large font', function() { |
- settingsPrefs.set('prefs.webkit.webprefs.default_font_size.value', 20); |
- assertEquals('Large', fontSize()); |
- }); |
+ fontsEntry = document.createElement('settings-appearance-fonts-page'); |
+ document.body.appendChild(fontsEntry); |
+ }); |
- /** |
- * If the font size is not one of the preset options (e.g. 16, 20, etc.) |
- * then the menu label will be 'Custom' (rather than 'Medium', 'Large', |
- * etc.). |
- */ |
- test('custom font size', function() { |
- settingsPrefs.set( |
- 'prefs.webkit.webprefs.default_font_size.value', 19); |
- assertEquals('Custom', fontSize()); |
+ teardown(function() { fontsEntry.remove(); }); |
+ |
+ test('fetchFontsData', function() { |
+ var fetchPromise = fontsBrowserProxy.whenCalled('fetchFontsData'); |
+ var responsePromise = fontsBrowserProxy.fetchFontsData().then( |
dpapad
2016/04/06 17:14:55
|fetchPromise| tests that the actual production co
dschuyler
2016/04/07 20:47:42
Done.
|
+ function(response) { |
+ assertGT(response.fontList.length, 0); |
+ assertGT(response.encodingList.length, 0); |
+ return true; |
+ }); |
+ return Promise.all([fetchPromise, responsePromise]); |
+ }); |
}); |
- }); |
- mocha.run(); |
+ } |
+ |
+ return { |
+ registerTests: function() { |
+ registerAppearanceFontSettingsBrowserTest(); |
+ }, |
+ }; |
}); |