 Chromium Code Reviews
 Chromium Code Reviews Issue 1864713003:
  [MD settings] appearance browser tests  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 1864713003:
  [MD settings] appearance browser tests  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| 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(); | 
| + }, | 
| + }; | 
| }); |