const Page = require( 'wdio-mediawiki/Page' ), Api = require( 'wdio-mediawiki/Api' ), BlankPage = require( 'wdio-mediawiki/BlankPage' ), Util = require( 'wdio-mediawiki/Util' ), 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'; class DiffPage extends Page { get rsMain() { return browser.element( '.mw-revslider-revision-slider' ); } get rsToggleButton() { return browser.element( '.mw-revslider-toggle-button' ); } get rsUserFilterBubble() { return browser.element( USER_BUBBLE_SELECTOR ); } get rsTagFilterBubble() { return browser.element( TAG_BUBBLE_SELECTOR ); } 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 ); } dwellTagFilterBubble() { browser.moveToObject( TAG_BUBBLE_SELECTOR ); } 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();