mediawiki-extensions-Popups/tests/node-qunit/ui/settingsDialog.test.js
joakin e6081106f1 Use EcmaScript modules instead of common.js modules
Why: Because they are the approved standard by TC39 and Ecma for
JavaScript modules.

Changes:
  * Wrap mw-node-qunit in run.js to register babel to transpile modules
    for node v6
  * Change all sources in src/ to use ES modules
    * Change constants.js to be able to run without
      jQuery.bracketedDevicePixelRatio given ES modules are hoisted to
      the top by spec so we can't patch globals before importing it
  * Change all tests in tests/node-qunit/ to use ES modules
  * Drop usage of mock-require given ES modules are easy to stub with
    sinon

Additional changes:
  * Rename tests/node-qunit/renderer.js to renderer.test.js to follow
    the convention of all the other files
  * Make npm run test:node run only .test.js test files so that it
    doesn't run the stubs.js or run.js file.

Bug: T171951
Change-Id: I17a0b76041d5e2fd18e2d54950d9d7c0db99a941
2017-07-31 23:05:44 +00:00

43 lines
1.1 KiB
JavaScript

import createSettingsDialogRenderer from '../../../src/ui/settingsDialog';
QUnit.module( 'ext.popups/settingsDialog', {
beforeEach: function () {
function render() { return $( '<div>' ); }
function getTemplate() { return { render: render }; }
mediaWiki.template = { get: getTemplate };
mediaWiki.config = { get: function () {} };
mediaWiki.msg = function () {};
},
afterEach: function () {
mediaWiki.config = null;
mediaWiki.template = null;
mediaWiki.msg = null;
}
} );
QUnit.test( '#render', function ( assert ) {
var boundActions = {
saveSettings: function () {},
hideSettings: function () {}
},
expected = {
appendTo: function () {},
show: function () {},
hide: function () {},
toggleHelp: function () {},
setEnabled: function () {}
},
result = createSettingsDialogRenderer()( boundActions );
// Specifically NOT a deep equal. Only structure.
assert.propEqual(
result,
expected,
'Interface exposed has the expected methods'
);
} );
// FIXME: Add Qunit integration tests about the rendering and the behavior of
// the settings dialog.