2020-05-14 21:14:42 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
2019-09-29 01:59:56 +00:00
|
|
|
const Page = require( 'wdio-mediawiki/Page' );
|
2018-01-13 12:56:46 +00:00
|
|
|
|
|
|
|
|
class DeletePage extends Page {
|
2023-11-22 18:25:32 +00:00
|
|
|
get reason() {
|
2024-07-12 13:44:57 +00:00
|
|
|
return $( '#wpReason input' );
|
2023-11-22 18:25:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get watch() {
|
|
|
|
|
return $( '#wpWatch' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get submit() {
|
|
|
|
|
return $( '#wpConfirmB' );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get displayedContent() {
|
|
|
|
|
return $( '#mw-content-text' );
|
|
|
|
|
}
|
2018-01-13 12:56:46 +00:00
|
|
|
|
2024-02-21 11:26:01 +00:00
|
|
|
async open( title ) {
|
|
|
|
|
return super.openTitle( title, { action: 'delete' } );
|
2018-01-13 12:56:46 +00:00
|
|
|
}
|
|
|
|
|
|
2022-11-23 17:50:28 +00:00
|
|
|
async delete( title, reason ) {
|
|
|
|
|
await this.open( title );
|
|
|
|
|
await this.reason.setValue( reason );
|
|
|
|
|
await this.submit.click();
|
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();
|