' ).appendTo( $qf ),
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is not shown' );
dialog.open();
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is shown' );
dialog.close();
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is not shown' );
} );
QUnit.test( 'setContent', function ( assert ) {
var $qf = $( '#qunit-fixture' ),
$anchor = $( '
' ).appendTo( $qf ),
titleText = 'This is a title',
bodyText = 'This is the
body',
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
dialog.setContent( titleText, bodyText );
dialog.open();
assert.notStrictEqual( $( '.mw-mmv-tipsy-dialog' ).text().match( titleText ), null, 'Title is included' );
assert.notStrictEqual( $( '.mw-mmv-tipsy-dialog' ).html().match( bodyText ), null, 'Body is included' );
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).find( '.typsyDialogTest-123' ).length, 1, 'Body is HTML' );
} );
QUnit.test( 'Close on click', function ( assert ) {
var $qf = $( '#qunit-fixture' ),
$anchor = $( '
' ).appendTo( $qf ),
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
dialog.open();
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is shown initially' );
dialog.getPopup().trigger( 'click' );
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is not hidden when clicked' );
dialog.getPopup().find( '.mw-mmv-tipsy-dialog-disable' ).trigger( 'click' );
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is hidden when close icon is clicked' );
dialog.open();
$qf.trigger( 'click' );
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is hidden when clicked outside' );
} );
}() );