Skip to content

helmbold/sulfur

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

German Version

Sulfur

Sulfur is a tool to easily write human readable browser based GUI tests. It is a FitNesse adapter using Selenium under the hood. FitNesse is a wiki to write tests in a human readable way, and Selenium controls the browser.

You can write automated GUI tests with Sulfur like this:

!| script | Browser |
| get      | http://example.com/holidays |
| title is | My holiday planner |
| click on | id:datepicker|
| click on | xpath://a[@title='Next>'] |
| click on | link:8 |
| click on | id:submitButton|
| element  | id:missingNameMessage | is visible |
| element  | id:missingNameMessage | has text | Please enter your name |
| type     | John Miller | in | name:lastname |
| element  | id:missingNameMessage | is invisible |

Installation

You need Java 7 to run Sulfur and FitNesse. So please download and install Java 7 (JDK or JRE) if not already available on your machine.

  1. Create a directory for your first Sulfur project.

  2. Download FitNesse and put the fitnesse-standalone.jar file in the just created project directory.

  3. Download Sulfur and put the sulfur-1.x-complete.jar in the project directory.

  4. Open a terminal, change into your project directory, and enter:

     java -jar fitnesse-standalone.jar
    

This will create the basic wiki structure (when executed the first time) and start the wiki server.

  1. Open http://localhost/FrontPage?edit in your browser and replace the content visible on the page with

     !define TEST_SYSTEM {slim} 
     !path *.jar
     !contents -R -g -p -f -h
    

And click 'save'. The above configuration tells FitNesse to use the SLIM engine and where to look for libraries (like Sulfur).

That's it! You can now start to write automated GUI tests.

Create SetUp and TearDown

To avoid repetition on every page, you can create pages named 'SetUp' and 'TearDown', to execute something before and after the tests on a page. These pages will be included automatically in your test pages.

Open http://localhost/FrontPage in your browser and click on 'Add > Test page'. Type 'SetUp' in the 'page name' field and put the following text in the content area:

|Import|
|de.advitec.sulfur|

Click save, go back to http://localhost/FrontPage and add another page named 'TearDown' with the following content:

!|script|Browser|
|close|

If you want to write your tests in German, use de.advitec.sulfur.lang.de in the import statement, and replace close by schließen.

Writing Tests

Open http://localhost/FrontPage in your browser, and click on 'Add > Test page'. Give your page a meaningful name and write your test code into the content area. Please note that FitNesse requires at least one upper case letter in the middle of the page name (example: MyTest).

There are three kinds of adapters right now: Browser, List and Table. Example:

!| script | Browser |
| get      | http://example.com/holidays |
| title is | My holiday planner |
| click on | id:datepicker|

!| query:List | id:someElement |
| items      |
| 2013-08-08 |
| 2013-08-09 |

!| Subset query:Table | id:employees |
| Date       | Remaining | Name   | 
| 2013-08-13 | 9         | Meyer  |
| 2013-08-13 | 9         | Meyer2 |

Click save. Now you can run your test page by clicking on the 'Test' button.

You are selecting certain elements of the html page with selectors. In the example above the id selector is used to find elements by id.

You can find all adapter methods with examples in the API docs.

Selectors

To act on a certain html element, you need to express which element should be used. You do this with one of the following selectors.

selector description example selector matches example html
id id attribute id:loginButton <input type="submit" id="loginButton" />
name name attribute name:email<input type="text" name="email" />
tag name of tag tag:h1 <h1>Example</h1>
link link text link:log in <a href="...">log in</a>
linkPart part of the link text linkPart:log <a href="...">log in</a>
class css class attribute class:auth <a href="..." class="auth" >log in</a>
xpath expression to locate an xml element xpath://input[@alt='Search'] <input type="image" src="some.gif" alt="Search" title="Search">
css CSS 3 selector css:.category button <div class="category"><button class="confirmation">OK</button></div>

XPath and CSS 3 Selectors are explained in detail on the W3C website.

Browser Adapter Methods

You can control the browser with the following methods:

| browser | chrome |
| get             | http://example.com |
| click on        | id:someElement |
| type            | some value | in | id:someElement |
| select text     | some value | in | id:someElement |
| select value    | someValue | in | id:someElement |
| select position | 0 | in | id:someElement |
| pause           | 10 | seconds |
| title is        | some page title |
| element         | id:someElement | has text | some text |
| element         | id:someElement | is active |
| element         | id:someElement | is inactive |
| element         | id:someElement | is visible |
| element         | id:someElement | is invisible |
| url is          | http://example.com |
| element         | id:someElement | has attribute | someAttribute | with value | someValue |
| element         | id:someElement | has attribute | someAttribute | 
| element         | id:someElement | exists |
| element         | id:someElement | does not exist |
| close           |

Installing Additional Browser Drivers

To be able to use other browsers than Firefox, you need to download the respective driver. The driver binaries needs to be placed somewhere on your system’s path. And of course you need the required browsers themselves.

More information about web drivers.

Sulfur is brought to you by ADVITEC Informatik GmbH

contact form or [email protected]

About

Selenium adapter for FitNesse - browser based GUI tests

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages