mirror of
https://gerrit.wikimedia.org/r/mediawiki/skins/MinervaNeue
synced 2025-01-09 03:04:32 +00:00
a32999e641
Change-Id: Icabf6e065ed5685207731262db72faf848a0a04d
30 lines
914 B
JavaScript
30 lines
914 B
JavaScript
/**
|
|
* World
|
|
*
|
|
* World is a function that is bound as `this` to each step of a scenario.
|
|
* It is reset for each scenario.
|
|
* https://github.com/cucumber/cucumber-js/blob/master/docs/support_files/world.md
|
|
*
|
|
* Contrary to Cucumber.js best practices, this `MinervaWorld` is not being
|
|
* bound to scenarios with the `setWorldConstructor` like this:
|
|
*
|
|
* setWorldConstructor(MinervaWorld);
|
|
*
|
|
* Instead, it acts as a simple function that encapsulates all dependencies,
|
|
* and is exported so that it can be imported into each step definition file,
|
|
* allowing us to use the dependencies across scenarios.
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const mwCorePages = require( '../support/pages/mw_core_pages' ),
|
|
minervaPages = require( '../support/pages/minerva_pages' );
|
|
|
|
function MinervaWorld() {
|
|
/* pageObjects */
|
|
Object.assign( this, mwCorePages );
|
|
Object.assign( this, minervaPages );
|
|
}
|
|
|
|
module.exports = new MinervaWorld();
|