mediawiki-extensions-Revisi.../tests/qunit/RevisionSlider.SliderView.test.js
libraryupgrader f5de8ee108 build: Updating npm dependencies
* eslint-config-wikimedia: 0.27.0 → 0.28.0
  The following rules are failing and were disabled:
  * modules:
    * no-mixed-spaces-and-tabs
    * no-jquery/no-extend
    * implicit-arrow-linebreak
  * tests/qunit:
    * no-jquery/no-extend

* grunt-stylelint: 0.19.0 → 0.20.0
* stylelint-config-wikimedia: 0.16.1 → 0.17.1

Change-Id: I3fd3c4a2cbb03d3aa4c8efb658e33d14d24cd518
2024-06-08 12:04:26 +00:00

62 lines
2.1 KiB
JavaScript

( function () {
const SliderModule = require( 'ext.RevisionSlider.Slider' ),
Slider = SliderModule.Slider,
SliderView = SliderModule.SliderView,
Revision = SliderModule.Revision,
RevisionList = SliderModule.RevisionList;
let startHistoryState, startHref;
QUnit.module( 'ext.RevisionSlider.SliderView' );
QUnit.testStart( () => {
startHistoryState = history.state;
startHref = window.location.href;
} );
QUnit.testDone( () => {
history.replaceState( startHistoryState, 'QUnit', startHref );
} );
QUnit.test( 'render adds the slider view with defined revisions selected', ( assert ) => {
const $container = $( '<div>' ),
view = new SliderView( new Slider( new RevisionList( [
new Revision( { revid: 1, size: 5, comment: 'Comment1', user: 'User1' } ),
new Revision( { revid: 3, size: 21, comment: 'Comment2', user: 'User2' } ),
new Revision( { revid: 37, size: 13, comment: 'Comment3', user: 'User3' } )
] ) ) );
mw.config.set( {
wgDiffOldId: 1,
wgDiffNewId: 37
} );
view.render( $container );
assert.strictEqual( $container.find( '.mw-revslider-revision-slider' ).length, 1 );
const $revisionOld = $container.find( '.mw-revslider-revision-old' );
const $revisionNew = $container.find( '.mw-revslider-revision-new' );
assert.strictEqual( $revisionOld.length, 1 );
assert.strictEqual( $revisionOld.attr( 'data-revid' ), '1' );
assert.strictEqual( $revisionNew.length, 1 );
assert.strictEqual( $revisionNew.attr( 'data-revid' ), '37' );
} );
QUnit.test( 'render throws an exception when no selected revisions provided', ( assert ) => {
const $container = $( '<div>' ),
view = new SliderView( new Slider( new RevisionList( [
new Revision( { revid: 1, size: 5, comment: 'Comment1', user: 'User1' } ),
new Revision( { revid: 3, size: 21, comment: 'Comment2', user: 'User2' } ),
new Revision( { revid: 37, size: 13, comment: 'Comment3', user: 'User3' } )
] ) ) );
mw.config.set( 'wgDiffOldId', null );
mw.config.set( 'wgDiffNewId', null );
assert.throws(
() => {
view.render( $container );
}
);
} );
}() );