Selenium/Ruby/Shared features

This is a list of features provided by the mediawiki_selenium RubyGem that are available to all browser tests in all repos. See Quality Assurance/Browser testing/Writing tests for an introduction to writing tests.


Login edit

Logs the user in on the wiki specified by the environment variable MEDIAWIKI_URL

Usage edit

In any Scenario in any Feature, just use

 Given I am logged in

and the shared login step will use the environment variables MEDIAWIKI_USER and MEDIAWIKI_PASSWORD to login at the target wiki.

Notes edit

Login is accomplished as thoroughly as possible:

  • in order to avoid missed clicks, the script fires an "onfocus" event on the login button before clicking
  • in order to confirm login, the script checks for the existence of a link to "Special:UserLogout" in order to proceed. This check works in all languages for all wikis

Random page edit

Sends the script to a random page in the target wiki

Usage edit

In any Scenario in any Feature, just use

 Given/When I am am at a random page

Notes edit

uses Special:Random in the target wiki

Reset preferences edit

Resets all of the test user's preferences to default settings.

Usage edit

In any Scenario in any Feature, just use

 Given/When I have reset my preferences

Notes edit

This feature has the potential to interfere with other tests that rely on particular preferences being set in a particular way. Make certain that this feature is used only for test users whose preference settings are irrelevant for other work.

ResourceLoader errors edit

After loading any page, this step will check for ResourceLoader errors and report any modules that have errors and any modules that are missing.

Usage edit

In any Scenario in any Feature, just use

 Given/When/Then page has no ResourceLoader errors

Notes edit

This is a pure javascript check and does not manipulate any aspect of browser function.

Upload file edit

Steps to upload valid or invalid media files via the shared interface in both Firefox and Chrome

Usage edit

In any Scenario in any Feature, just use

 When upload file <filename>

to upload a valid PNG image file

and

 When upload bogus file <filename>

to upload an invalid empty file

Notes edit

As of 2014 April this is valid only the MobileFrontend and UploadWizard repositories. The steps are shared, but each repo right now has it's own version of the UploadPage page object. This is Bug 63833


Create page at run time via API edit

Creates a page with particular title and text in the target wiki at runtime.

In the target wiki:

  • if no page with this title exists, the page will be created with the specified content
  • if a page with this title exists but the contents of the page differ from what is in the API call, the existing page will be updated with the contents of the API call by means of a normal revision, which will appear in the history of the page.
  • if a page with this title exists and the contents of the page are identical to what is in the API call, the existing page is not changed in any way, and no additional revisions are created. This is a no-op.

Usage edit

In the steps for any Scenario do

Given(/^I create some page with some content$/) do
  on(APIPage).create "page title", "page contents"
end

Note the creative possibilities:

  • to create a page in the target wiki with a quasi-unique title that the running Scenario will be able to find and use in the course of the test:
Given(/^I create a random page using the API$/) do
  on(APIPage).create @random_string, @random_string
end
  • to guarantee that a particular page in the target wiki will have particular content, and then navigate to that page:
Given(/^I go to a page that has references$/) do
  wikitext = "MobileFrontend is a 
MediaWiki extension.<ref>[http://mediawiki.org/wiki/Extension:MobileFrontend Extension:MobileFrontend]</ref>

==References==
<references />"

  on(APIPage).create "Selenium References test page", wikitext
  step 'I am on the "Selenium References test page" page'
end

Protect edit

sets the level of protection to

edit=sysop|move=sysop


Usage edit

on(APIPage).protect "Title of page to be protected", "Reason for protection"

Notes edit

APIPage features rely on an environment variable MEDIAWIKI_API_URL. Before the test runs, do for example:

 export MEDIAWIKI_API_URL=http://en.wikipedia.beta.wmflabs.org/w/api.php

The test will abort immediately if it calls (ApiPage).create and the MEDIAWIKI_API_URL env var is not in place.

Also note that the user identified by the environment variables MEDIAWIKI_USER and MEDIAWIKI_PASSWORD must have proper permissions to manipulate pages on the target wiki via the API in order to use this feature.