wdio-mediawiki
v2.5.0
Published
WebdriverIO plugin for testing a MediaWiki site.
Downloads
11,466
Readme
wdio-mediawiki
A plugin for WebdriverIO providing utilities to simplify testing of MediaWiki features.
Getting Started
Page
The Page
class is a base class for following the Page Objects Pattern.
openTitle( title [, Object query [, string fragment ] ] )
The convention is for implementations to extend this class and provide an open()
method
that calls super.openTitle()
, as well as add various getters for elements on the page.
See BlankPage and specs/BlankPage for an example.
Api
Utilities to interact with the MediaWiki API. Uses the mwbot library.
Actions are performed logged-in using browser.config.mwUser
and browser.config.mwPwd
,
which typically come from MEDIAWIKI_USER
and MEDIAWIKI_PASSWORD
environment variables.
bot([string username [, string password [, string baseUrl ] ] ])
createAccount(MWBot bot, string username, string password)
blockUser(MWBot bot, [ string username [, string expiry ] ])
unblockUser(MWBot bot, [ string username ])
Example:
bot = await Api.bot();
await bot.edit( 'Some page', 'Some initial content' );
await bot.edit( 'Some page', 'Some other content', 'Optional edit reason here' );
await bot.delete( 'Some page', 'Some deletion reason here' );
RunJobs
Use the static RunJobs.run()
method to ensure that any queued jobs are executed before
making assertions that depend on its outcome.
Util
Util
is a collection of popular utility methods.
getTestString([ string prefix ])
waitForModuleState(string moduleName [, string moduleStatus [, number timeout ] ])
Versioning
This package follows Semantic Versioning guidelines for its releases. In particular, its major version must be bumped when compatibility is removed for a previous of MediaWiki.
It is the expectation that this module will only support a single version of MediaWiki at any given time, and that tests in older branches of MediaWiki-related projects naturally use the older release line of this package.
In order to allow for smooth and decentralised upgrades, it is recommended that the only type of breaking change made to this package is a change that removes something. Thus, in order to change something, it must either be backwards-compatible, or must be introduced as a new method that co-exists with its deprecated equivalent for at least one release.
Issue tracker
Please report issues to Phabricator.
Contributing
This module is maintained in the MediaWiki core repository and published from there as a package to npmjs.org. To simplify development and to ensure changes are verified automatically, MediaWiki core itself uses this module directly from the working copy using npm Local Paths.