2018-05-02 17:48:24 +00:00
|
|
|
const Page = require( 'wdio-mediawiki/Page' ),
|
|
|
|
|
Api = require( 'wdio-mediawiki/Api' );
|
2018-01-13 12:56:46 +00:00
|
|
|
|
|
|
|
|
class DeletePage extends Page {
|
|
|
|
|
get reason() { return browser.element( '#wpReason' ); }
|
|
|
|
|
get watch() { return browser.element( '#wpWatch' ); }
|
|
|
|
|
get submit() { return browser.element( '#wpConfirmB' ); }
|
|
|
|
|
get displayedContent() { return browser.element( '#mw-content-text' ); }
|
|
|
|
|
|
2018-05-02 17:48:24 +00:00
|
|
|
open( title ) {
|
|
|
|
|
super.openTitle( title, { action: 'delete' } );
|
2018-01-13 12:56:46 +00:00
|
|
|
}
|
|
|
|
|
|
2018-05-02 17:48:24 +00:00
|
|
|
delete( title, reason ) {
|
|
|
|
|
this.open( title );
|
2018-01-13 12:56:46 +00:00
|
|
|
this.reason.setValue( reason );
|
|
|
|
|
this.submit.click();
|
|
|
|
|
}
|
|
|
|
|
|
2018-05-02 17:48:24 +00:00
|
|
|
// @deprecated Use wdio-mediawiki/Api#delete() instead.
|
2018-01-13 13:52:35 +00:00
|
|
|
apiDelete( name, reason ) {
|
2018-05-02 17:48:24 +00:00
|
|
|
return Api.delete( name, reason );
|
2018-01-13 13:52:35 +00:00
|
|
|
}
|
2018-01-13 12:56:46 +00:00
|
|
|
}
|
selenium: Minor clean-up in preparation for packaging
This is functionally a no-op, purely refactoring (mostly style).
* Consistently require packages at the top of a file.
(e.g. MWBot in edit.page.js).
* Remove unused .call(this) from mwbot interaction closures,
which didn't use 'this'.
* Use Node.js regular Promise chaining with then(), instead of
complex bluebird.coroutine generator function yields, which
are intended to emulate async-await, but the syntax is quite
error-prone for inexperienced developers and hard to debug.
Once we require Node 7+ for the selenium tests, we can use
async-await here natively, but until then, might as well use
regular then() syntax, which we already use elsewhere in the
tests, and is also what MWBot documentation uses.
* Also applied some minor whitespace changes for consistency
among these files and other MediaWiki JS. E.g. no empty line
before the first statement of a function. Add a new line between
different methods, and between the end of a class and the
export statement.
* Remove 'use strict' from test files. The patterns that would expose
the bad non-strict behaviour are mostly already forbidden by ESLint,
and the run-time optimisation to disable non-strict can't be noticed
in tests (more useful in prod where e.g. the same process would run
a function 1 million times). Main reason here is to keep things
simple for new-comers and reduce boilerplate, given that these tests
will mainly be worked on by browser-JS developers, not Node.js devs,
and we don't currently use strict mode in our front-end code, either.
* Remove unused bluebird dependency.
Bug: T193088
Change-Id: I59f9211299e8e884c28c7733bcee3b7b28542610
2018-05-02 03:48:36 +00:00
|
|
|
|
2018-01-13 12:56:46 +00:00
|
|
|
module.exports = new DeletePage();
|