( function ( M ) { var pageIssues = M.require( 'skins.minerva.scripts/pageIssues' ), mobile = M.require( 'mobile.startup' ), util = mobile.util, insertBannersOrNotice = pageIssues.test.insertBannersOrNotice, icon = {}, MEDIUM_ISSUE = { issue: { severity: 'MEDIUM', icon: icon }, iconString: 'i', text: 't' }, LOW_ISSUE = { issue: { severity: 'LOW', icon: icon }, iconString: 'i', text: 't' }, HIGH_ISSUE = { issue: { severity: 'HIGH', icon: icon }, iconString: 'i', text: 't' }, getAllIssuesSections = pageIssues.test.getAllIssuesSections, OverlayManager = mobile.OverlayManager, Page = mobile.Page, overlayManager = new OverlayManager( require( 'mediawiki.router' ) ), $mockContainer = $( '
' + '' + '' + '' + '' + '
ambox text span
' + '
' ), labelText = 'label text', inline = true, SECTION = '0', processedAmbox = insertBannersOrNotice( new Page( { el: $mockContainer } ), labelText, SECTION, inline, overlayManager ); QUnit.module( 'Minerva cleanuptemplates' ); QUnit.test( 'insertBannersOrNotice() should add a "learn more" message', function ( assert ) { assert.strictEqual( /⧼skin-minerva-issue-learn-more⧽/.test( processedAmbox.html() ), true ); } ); QUnit.test( 'insertBannersOrNotice() should add an icon', function ( assert ) { assert.strictEqual( /mw-ui-icon/.test( processedAmbox.html() ), true ); } ); QUnit.test( 'clicking on the product of insertBannersOrNotice() should trigger a URL change', function ( assert ) { processedAmbox.click(); assert.strictEqual( window.location.hash, '#/issues/' + SECTION ); } ); QUnit.test( 'getAllIssuesSections', function ( assert ) { var multipleIssuesWithDeletion, multipleIssues, allIssuesOldTreatment, allIssuesNewTreatment; allIssuesOldTreatment = { 0: [ MEDIUM_ISSUE, LOW_ISSUE, MEDIUM_ISSUE ] }; multipleIssues = { 0: [ util.extend( {}, MEDIUM_ISSUE, { grouped: true } ), util.extend( {}, LOW_ISSUE, { grouped: true } ), util.extend( {}, MEDIUM_ISSUE, { grouped: true } ) ] }; multipleIssuesWithDeletion = { 0: [ HIGH_ISSUE, util.extend( {}, MEDIUM_ISSUE, { grouped: true } ), util.extend( {}, LOW_ISSUE, { grouped: true } ), util.extend( {}, MEDIUM_ISSUE, { grouped: true } ) ] }; allIssuesNewTreatment = { 0: [ HIGH_ISSUE, LOW_ISSUE, MEDIUM_ISSUE ], 1: [ MEDIUM_ISSUE ] }; assert.propEqual( getAllIssuesSections( allIssuesOldTreatment ), [ '0', '0', '0' ], 'section numbers correctly extracted from old treatment' ); assert.propEqual( getAllIssuesSections( allIssuesNewTreatment ), [ '0', '0', '0', '1' ], 'section numbers correctly extracted from new treatment' ); assert.propEqual( getAllIssuesSections( multipleIssues ), [ '0' ], 'multiple issues are packed into one entry since there is one box' ); assert.propEqual( getAllIssuesSections( multipleIssuesWithDeletion ), [ '0', '0' ], 'while multiple issues are grouped, non-multiple issues are still reported' ); } ); }( mw.mobileFrontend ) );