2019-03-27 18:09:56 +00:00
|
|
|
const Page = require( 'wdio-mediawiki/Page' ),
|
|
|
|
Api = require( 'wdio-mediawiki/Api' ),
|
|
|
|
BlankPage = require( 'wdio-mediawiki/BlankPage' ),
|
|
|
|
Util = require( 'wdio-mediawiki/Util' ),
|
2019-03-29 18:00:27 +00:00
|
|
|
MWBot = require( 'mwbot' ),
|
|
|
|
USER_BUBBLE_SELECTOR = '.mw-revslider-username-row .mw-revslider-bubble',
|
|
|
|
TAG_BUBBLE_SELECTOR = '.mw-revslider-tag-row:last-of-type .mw-revslider-bubble';
|
2019-03-27 18:09:56 +00:00
|
|
|
|
|
|
|
class DiffPage extends Page {
|
|
|
|
get rsMain() { return browser.element( '.mw-revslider-revision-slider' ); }
|
|
|
|
get rsToggleButton() { return browser.element( '.mw-revslider-toggle-button' ); }
|
|
|
|
|
2019-03-29 18:00:27 +00:00
|
|
|
get rsUserFilterBubble() { return browser.element( USER_BUBBLE_SELECTOR ); }
|
|
|
|
get rsTagFilterBubble() { return browser.element( TAG_BUBBLE_SELECTOR ); }
|
2019-03-27 18:09:56 +00:00
|
|
|
|
|
|
|
getRevision( num ) { return browser.element( '.mw-revslider-revision[data-pos="' + num + '"]' ); }
|
|
|
|
|
|
|
|
resourceLoaderModuleStatus( moduleName, moduleStatus, errMsg ) {
|
|
|
|
// Word of caution: browser.waitUntil returns a Timer class NOT a Promise.
|
|
|
|
// Webdriver IO will run waitUntil synchronously so not returning it will
|
|
|
|
// block JavaScript execution while returning it will not.
|
|
|
|
// http://webdriver.io/api/utility/waitUntil.html
|
|
|
|
// https://github.com/webdriverio/webdriverio/blob/master/lib/utils/Timer.js
|
|
|
|
browser.waitUntil( () => {
|
|
|
|
const result = browser.execute( ( module ) => {
|
|
|
|
return typeof mw !== 'undefined' &&
|
|
|
|
mw.loader.getState( module.name ) === module.status;
|
|
|
|
}, { status: moduleStatus, name: moduleName } );
|
|
|
|
return result.value;
|
|
|
|
}, 10000, errMsg );
|
|
|
|
}
|
|
|
|
|
|
|
|
ready() {
|
|
|
|
this.resourceLoaderModuleStatus( 'ext.RevisionSlider.lazyJs', 'ready', 'RevisionSlider did not load' );
|
|
|
|
}
|
|
|
|
|
|
|
|
prepareFilterTests() {
|
|
|
|
let title = Util.getTestString( 'revisionslider-test-' );
|
|
|
|
BlankPage.open();
|
|
|
|
this.toggleHelpDialog( false );
|
|
|
|
this.hasPageWithDifferentEdits( title );
|
|
|
|
this.open( title );
|
|
|
|
}
|
|
|
|
|
|
|
|
openSlider() {
|
|
|
|
this.rsToggleButton.click();
|
|
|
|
this.rsMain.waitForVisible();
|
|
|
|
}
|
|
|
|
|
|
|
|
open( title ) {
|
|
|
|
super.openTitle( title, { type: 'revision', diff: '' } );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {boolean} [show] Defaults to true.
|
|
|
|
*/
|
|
|
|
toggleHelpDialog( show ) {
|
|
|
|
let hide = show === false;
|
|
|
|
browser.localStorage( 'POST', { key: 'mw-revslider-hide-help-dialogue', value: hide ? '1' : '0' } );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Will setup a test page with two user edits, one anonymous edit
|
|
|
|
* and a tagged.
|
|
|
|
*
|
|
|
|
* @param {string} title Article to edit.
|
|
|
|
*/
|
|
|
|
hasPageWithDifferentEdits( title ) {
|
|
|
|
this.addTwoUserEditsToPage( title );
|
|
|
|
this.addTaggedOtherUserEditToPage( title );
|
|
|
|
this.addTaggedEditToPage( title );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} title Article to edit.
|
|
|
|
*/
|
|
|
|
addTwoUserEditsToPage( title ) {
|
|
|
|
browser.call( function () {
|
|
|
|
return Api.edit(
|
|
|
|
title,
|
|
|
|
'RevisionSlider-Test-Text One'
|
|
|
|
);
|
|
|
|
} );
|
|
|
|
browser.call( function () {
|
|
|
|
return Api.edit(
|
|
|
|
title,
|
|
|
|
'RevisionSlider-Test-Text Two'
|
|
|
|
);
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} title Article to edit.
|
|
|
|
*/
|
|
|
|
addTaggedEditToPage( title ) {
|
|
|
|
let bot = new MWBot();
|
|
|
|
|
|
|
|
browser.call( function () {
|
|
|
|
return bot.loginGetEditToken( {
|
|
|
|
apiUrl: `${browser.options.baseUrl}/api.php`,
|
|
|
|
username: browser.options.username,
|
|
|
|
password: browser.options.password
|
|
|
|
} ).then( function () {
|
|
|
|
return bot.edit(
|
|
|
|
title,
|
|
|
|
'',
|
|
|
|
'RevisionSlider-Test-Tagged',
|
|
|
|
{ tags: 'mw-blank' }
|
|
|
|
);
|
|
|
|
} );
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} title Article to edit.
|
|
|
|
*/
|
|
|
|
addTaggedOtherUserEditToPage( title ) {
|
|
|
|
let bot = new MWBot();
|
|
|
|
let otherUser = Util.getTestString( 'User-' );
|
|
|
|
let otherUserPassword = Util.getTestString();
|
|
|
|
browser.call( function () {
|
|
|
|
return Api.createAccount( otherUser, otherUserPassword );
|
|
|
|
} );
|
|
|
|
|
|
|
|
browser.call( function () {
|
|
|
|
return bot.loginGetEditToken( {
|
|
|
|
apiUrl: `${browser.options.baseUrl}/api.php`,
|
|
|
|
username: otherUser,
|
|
|
|
password: otherUserPassword
|
|
|
|
} ).then( function () {
|
|
|
|
return bot.edit(
|
|
|
|
title,
|
|
|
|
'RevisionSlider-Test-Other-Text with tag',
|
|
|
|
'RevisionSlider-Test-Other-Tagged',
|
|
|
|
{ tags: 'mw-replace' }
|
|
|
|
);
|
|
|
|
} );
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
|
|
|
|
dwellRevision( num ) {
|
|
|
|
browser.moveToObject( '.mw-revslider-revision[data-pos="' + num + '"]' );
|
|
|
|
browser.waitForVisible( '.mw-revslider-revision-tooltip-' + num );
|
|
|
|
}
|
|
|
|
|
2019-03-29 18:00:27 +00:00
|
|
|
dwellTagFilterBubble() {
|
|
|
|
browser.moveToObject( TAG_BUBBLE_SELECTOR );
|
|
|
|
}
|
|
|
|
|
2019-03-27 18:09:56 +00:00
|
|
|
abondonBubbleDwell() {
|
|
|
|
// make sure we do not dwell the line/bubble after clicking
|
|
|
|
browser.moveToObject( '.mw-revslider-revision-tooltip p:first-of-type' );
|
|
|
|
}
|
|
|
|
|
|
|
|
clickUserFilterBubble() {
|
|
|
|
this.rsUserFilterBubble.click();
|
|
|
|
this.abondonBubbleDwell();
|
|
|
|
}
|
|
|
|
|
|
|
|
clickTagFilterBubble() {
|
|
|
|
this.rsTagFilterBubble.click();
|
|
|
|
this.abondonBubbleDwell();
|
|
|
|
}
|
|
|
|
|
|
|
|
highlightsRevision( num ) {
|
|
|
|
return this.getRevision( num ).$( '..' )
|
|
|
|
.getAttribute( 'class' ).indexOf( 'mw-revslider-revision-highlight' ) !== -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
highlightsBubble( el ) {
|
|
|
|
return el.getAttribute( 'class' ).indexOf( 'mw-revslider-highlite-bubble' ) !== -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = new DiffPage();
|