mediawiki-extensions-Popups/tests/node-qunit/reducers/settings.test.js
Ed Sanders 883c8c1aca build: Update eslint-config-wikimedia to 0.22.1
Change-Id: I055517998ed06fccdf50ec31251ea6aa9040abb5
2022-02-28 13:18:24 +00:00

191 lines
4.5 KiB
JavaScript

import settings from '../../../src/reducers/settings';
import actionTypes from '../../../src/actionTypes';
QUnit.module( 'reducers/settings' );
QUnit.test( '@@INIT', ( assert ) => {
const state = settings( undefined, { type: '@@INIT' } );
assert.deepEqual(
state,
{
shouldShow: false,
showHelp: false,
shouldShowFooterLink: false
},
'The initial state doesn\'t show, doesn\'t show help, and doesn\'t show a footer link.'
);
} );
QUnit.test( 'BOOT with a single disabled popup type', ( assert ) => {
const action = {
type: actionTypes.BOOT,
initiallyEnabled: { page: false },
user: { isAnon: true }
};
assert.deepEqual(
settings( {}, action ),
{ shouldShowFooterLink: true },
'The boot state shows a footer link.'
);
action.user.isAnon = false;
assert.deepEqual(
settings( {}, action ),
{ shouldShowFooterLink: false },
'If the user is logged in, then it doesn\'t signal that the footer link should be shown.'
);
} );
QUnit.test( 'BOOT with multiple popup types', ( assert ) => {
const action = {
type: actionTypes.BOOT,
initiallyEnabled: { page: true, reference: null },
user: { isAnon: true }
};
assert.deepEqual(
settings( {}, action ),
{ shouldShowFooterLink: false },
'Footer link ignores unavailable popup types.'
);
action.initiallyEnabled.reference = true;
assert.deepEqual(
settings( {}, action ),
{ shouldShowFooterLink: false },
'Footer link is pointless when there is nothing to enable.'
);
action.initiallyEnabled.reference = false;
assert.deepEqual(
settings( {}, action ),
{ shouldShowFooterLink: true },
'Footer link appears when at least one popup type is disabled.'
);
} );
QUnit.test( 'SETTINGS_SHOW', ( assert ) => {
assert.deepEqual(
settings( {}, { type: actionTypes.SETTINGS_SHOW } ),
{
shouldShow: true,
showHelp: false
},
'It should mark the settings dialog as ready to be shown, with no help.'
);
} );
QUnit.test( 'SETTINGS_HIDE', ( assert ) => {
assert.deepEqual(
settings( {}, { type: actionTypes.SETTINGS_HIDE } ),
{
shouldShow: false,
showHelp: false
},
'It should mark the settings dialog as ready to be closed, and hide help.'
);
} );
QUnit.test( 'SETTINGS_CHANGE with page previews only', ( assert ) => {
const action = ( oldValue, newValue ) => {
return {
type: actionTypes.SETTINGS_CHANGE,
oldValue: { page: oldValue },
newValue: { page: newValue }
};
};
assert.deepEqual(
settings( {}, action( false, false ) ),
{ shouldShow: false },
'It should just hide the settings dialog when enabled state stays the same.'
);
assert.deepEqual(
settings( {}, action( true, true ) ),
{ shouldShow: false },
'It should just hide the settings dialog when enabled state stays the same.'
);
assert.deepEqual(
settings( {}, action( false, true ) ),
{
shouldShow: false,
showHelp: false,
shouldShowFooterLink: false
},
'It should hide the settings dialog and help when we enable.'
);
assert.deepEqual(
settings( {}, action( true, false ) ),
{
shouldShow: true,
showHelp: true,
shouldShowFooterLink: true
},
'It should keep the settings showing and show the help when we disable.'
);
} );
QUnit.test( 'SETTINGS_CHANGE with two preview types', ( assert ) => {
[
[
'All are disabled but nothing changed',
false, false, false, false,
{ shouldShow: false }
],
[
'All are enabled but nothing changed',
true, true, true, true,
{ shouldShow: false }
],
[
'One is enabled but nothing changed',
false, false, true, true,
{ shouldShow: false }
],
[
'Only one got disabled',
true, true, true, false,
{ shouldShow: true, showHelp: true, shouldShowFooterLink: true }
],
[
'One got disabled, the other enabled',
false, true, true, false,
{ shouldShow: true, showHelp: true, shouldShowFooterLink: true }
],
[
'Both got disabled',
true, false, true, false,
{ shouldShow: true, showHelp: true, shouldShowFooterLink: true }
],
[
'Only one got enabled',
false, false, false, true,
{ shouldShow: false, showHelp: false, shouldShowFooterLink: true }
],
[
'Both got enabled',
false, true, false, true,
{ shouldShow: false, showHelp: false, shouldShowFooterLink: false }
]
].forEach( ( [
message,
pageBefore,
pageAfter,
referenceBefore,
referenceAfter,
expected
] ) => {
assert.deepEqual(
settings( {}, {
type: actionTypes.SETTINGS_CHANGE,
oldValue: { page: pageBefore, reference: referenceBefore },
newValue: { page: pageAfter, reference: referenceAfter }
} ),
expected,
message
);
} );
} );