General preparation
← Older revision
Revision as of 15:02, 10 May 2013
(One intermediate revision by one user not shown)
Line 1:
Line 1:
+
{{TOC}}
System testing of Semantic MediaWiki can be done using [[website::http://seleniumhq.org/|Selenium]] and the Selenium Framework provided by [[mws:Selenium/Deployment|MediaWiki]].
System testing of Semantic MediaWiki can be done using [[website::http://seleniumhq.org/|Selenium]] and the Selenium Framework provided by [[mws:Selenium/Deployment|MediaWiki]].
−
==DocuFramework==
+
== Creating Selenium Tests ==
+
Selenium IDE can be used well for quick recording of tests, debugging of tests, and learning how to write Selenium tests. Recorded Selenium tests can be exported as PHP to be included in the SMW code. In this HowTo we describe the usage of the IDE.
+
+
+
This section describes the general environment for Selenium Tests. The environment is valid for the whole system testing process, whether you are creating only one or several test cases.
+
+
===Prerequisites===
+
* Firefox (IDE/XPather not for firefox 4, yet!)
+
* Recording of tests: Selenium IDE [http://seleniumhq.org/download/] (this howto has been created using Selenium 1.x.)
+
* Finding targets (only one needed):
+
** Firefox Plugin XPather [http://xpath.alephzarro.com/]
+
** Firefox Plugin DOM Inspector [https://addons.mozilla.org/de/firefox/addon/dom-inspector-6622/]
+
+
===Selenium preparation===
+
After installing Selenium IDE you can open this tool via the Firefox menu: ''Tools'' --> ''Selenium IDE''. Selenium IDE opens in an own window.
+
+
*check options
+
**Default timeout value for recorded commands (Default is 30.000 ms, 10.000 ms should be adequate)
+
**Uncheck "Start recording immediately on open"
+
*define Base URL: Main Page of your wiki (AUT). Each test case shall start and end on the wikis Main Page.
+
+
===Wiki (Application under Test)===
+
The created tests shall be used automatically in other wikis afterwards. So, you need to avoid any dependencies to the wiki, in which the test were created. Make sure that:
+
*LocalSettings.php is on default
+
*Wiki is using standard skin (vektor)
+
*Wiki database is empty
+
+
==Test creation==
+
The aim of the Selenium Tests is to create several modular test cases, which all only check a single functionality or a single use case (for example: ''Define type of property'').
+
+
===Story===
+
Each test case has one story, containing:
+
*setUp
+
*one or more tests
+
*tearDown
+
+
In the '''setUp''' you achieve the prerequisites for the respective test case. Mostly you will create and edit pages in the setUp or make some annotations, but you will not make any tests in this section. The general rule is: If a test afterwards will fail in the setUp, then the source of this problem is not in the respective feature or use case which is checked by the whole test case.
+
+
The single '''tests''' in contrast should check exactly the feature or use case of the whole test case. If you divide them, you may create several tests. Choose significant names for the tests (for example: ''check semantic search'' and ''check displaying'').
+
+
With the '''tearDown''' you bring back the system to its original state before the tests. This means: delete all created pages and undo all of your editings. Finally you have to return to the Main page. The tearDown is very important to not leave any traces in the wiki. So, you can make sure, that your test be used several times in succession without any problems.
+
+
===Uniform nomination===
+
Please make sure, that you choose a clear nomination. With Selenium you will create a file for the setUp, for the several tests and the tearDown of each test case.
+
+
You should use the name of the test case for every file and add an prefix (for example, setUp, test01, etc.). If you have created more than one test for a test case, you need to illustrate the order of the several tests in their nomination.
+
+
Example files for one test case:
+
*setUp_DefineTypeOfProperty
+
*test01_checksemanticsearch_DefineTypeOfProperty
+
*test02_checkdisplaying_DefineTypeOfProperty
+
*tearDown_DefineTypeOfProperty
+
+
===Record test===
+
* Login manually (will later be done by the Selenium Framework)
+
* Set Base URL
+
* Create structure
+
** One TestSuite (which will become one Test Case later)
+
** Test Cases (which will become functions in the Selenium Framework). Example: setUp_Factboxtest, test01_Factboxtest_factboxpresent, test02_Factboxtest_factboxpropertypresent, ..., tearDown_Factboxtest
+
* Open Base URL in Browser
+
* Switch on recording
+
* Commands are recorded by Selenium automatically. To create and use commands manually, see Selenium Command Reference [http://release.seleniumhq.org/selenium-core/1.0.1/reference.html]
+
* record for setUp -> open, type, clickAndWait (done both together!), clickAndWait, type, clickAndWait (done both together!)
+
* record for tests -> (see: "How to find targets")
+
** Factbox -> e.g., use assertElementPresent
+
** Property -> e.g., use assertTextPresent
+
** See Selenium Command Reference [http://release.seleniumhq.org/selenium-core/1.0.1/reference.html]
+
* record for tearDown -> clickAndWait...
+
+
====How to find targets====
+
* Selenium provides commands that need a target, e.g., "assertElemantPresent", see [http://release.seleniumhq.org/selenium-core/1.0.1/reference.html]
+
* There are tools that allow you to find target by simply clicking on an element
+
* e.g., use XPather [http://xpath.alephzarro.com/]
+
* e.g., use DOM Inspector [https://addons.mozilla.org/de/firefox/addon/dom-inspector-6622/]
+
** "Einen Knoten zum Inspezieren durch Draufklicken suchen"
+
** Click on element -> Copy&Paste locator -> Put extra slash in front of locator to indicate "XPath" locator, e.g., "//html/body/div[@id='globalWrapper']/div[@id='column-content']/div[@id='content']/div[@id='bodyContent']/div[@id='mw-data-after-content']/div"
+
*** Note, that this is not a robust way of defining targets.
+
*** This way, it could easily be that a change to the underlying code leads to a break of the locator
+
* There are other (and especially more robust to code changes) ways to describe a locator, see [http://seleniumhq.org/docs/02_selenium_ide.html#locating-elements]
+
* You can also use the context menu in your browser to add commands. Just right-click the concerning element when Selenium is running (not recording).
+
+
===Final check and PHP export===
+
After you have finished recording the test, you need to check, if the whole test is running without problems.
+
+
* Run the whole test case (Selenium: "Play entire test suite") in the browser, for each Test Case there is indicated whether it run successfully or failed.
+
* Run the test a second time to verify, that the test is repeatable
+
* Save Test Suite (made of all Test Cases), save Test Cases (so, now, they can be opened again), use selenium internalt format (HTML). Use the same names as described before (Selenium files don't need a file extension)
+
* Export test to php: Unfortunately you can not export the whole Test Suite (Selenium terminology). So you need to export each Test Case (Selenium terminology):
+
** Select setUp and click ''File'' -> ''Export Test Case As...'' -> ''PHP''(There are 2 PHP options to choose as export format, when using the Selenium IDE version 1.2; PHP PHPUnit and PHP Selenium_TestCase. Which format do I use?)--[[Special:Contributions/24.21.198.189|24.21.198.189]] 02:59, 15 August 2011 (CEST)
+
** Do the same for the test files and the tearDown
+
** Use the same file names. Just add file extension ''.php''
+
+
The task of ''Creating SMW Selenium Tests'' ends with the creation of the php test files. The next task is '' [[Howto_-_Running_SMW_Selenium_Tests| Running SMW Selenium Tests]]''.
+
+
==Examples==
+
* See [http://svn.wikimedia.org/svnroot/mediawiki/trunk/extensions/SemanticMediaWiki/tests/selenium/suites/cases_SMWSeleniumTestSuite/] for examples.
+
+
==Lessons Learned==
+
This section should give some advices for creating tests in the future. Please add your experiences to reach a better workflow in the test creation process.
+
+
* please consider putting lessons learned into WMF efforts, see [http://www.mediawiki.org/wiki/SeleniumFramework#Test_style_guide]
+
+
===Experiences: Selenum IDE===
+
* Browser context menu will help you to quickly find commands
+
* You may copy and paste (shortcuts are working) commands and edit them manually (for example if its the same command, only using another value)
+
* Note, that you have to select a test on the left with a double click before editing. A single click is only highlighting a test but you will still edit the last one.
+
* If you create similar test cases, you may reuse them (load test case, rename and make changes).
+
* You may also just reuse the setUp and the tearDown and extend them.
+
+
===Experiences: Selenium with PHP===
+
* In order to have special characters shown correctly in the browser, the TestSuite and TestCase PHP files were saved in UTF-8 format.
+
* Screenshots can be taken by:
$this->captureScreenshot("C:\\Folder1\\Folder2\\..\\mySeleniumScreenshot.png");
+
* Bear in mind to read Selenium command documentation: e.g., getValue() and getText() are different.
+
+
== DocuFramework ==
We have created a wiki that shall support the creation of system tests. It is a Single-Source-Framework for describing functionality of SMW to be explained in the user/admin manual and tested with Selenium.
We have created a wiki that shall support the creation of system tests. It is a Single-Source-Framework for describing functionality of SMW to be explained in the user/admin manual and tested with Selenium.