/lifelines

Primary LanguageRubyOtherNOASSERTION

Lifelines

These are the Watir Tests to be run on the a test project designed by Thoughtworks. They are an strip-down example of a complex test suite for a web application.

Here you find the entire testsuite. It is using the Watir Webdriver and the Unit Test Framework.

Getting started with Ruby

The tests are written in Ruby. After installing Ruby you need to install the bundler gem (once):

gem install bundler

and let the bundler check for (new) ruby packages in this Lifelines repository with

bundle install

The tests are running in real browsers and "experience" the page like a real user. They cannot interact with hidden elements or not fully loaded content. One can run the tests in different browsers:

Browsers

Firefox works out of the box. Besides Firefox you can run the tests in a headless environment. You need to install xvfb though.

They can also run in Chrome, when the Chrome Driver is installed on the system.

Start the tests

You can start the tests by runing test_nd_retry <browser>, where <browser> is the name of the browser` you want to run the tests in.

  • Possible options for browser are either firefox, chrome or headless

Example:

bundle exec bin/test_and_retry firefox

The following will happen

  • You will be running a script (test_and_retry) which itself at first starts the bin/test script. bin/test runs all written tests in alphabetical order. You see a success or fail console output for every single test. All errors are printed in the console and logged in a seperate file.
  • Second, the test_and_retry script will start bin/retry. Here all tests that failed before are started once more. Sometimes tests just fail, eg. because of timeouts in the connection. Thus, to be sure that the found error is reproduceable, the tests are executed a second time.
  • The script will evaluate which errors were reproduceable and in the end give you a summary of all the failed tests (or tell you that one-time errors were resolved)

Debuging

When the tests fail you need to find out what exactly went wrong. The following will guide you

  • In any case the error output in the console gives you the first clues where to find the error :-)
  • Furthermore the backtrace is saved in log/backtrace.log for every single fail. Its stripped down to show only the information you really need but not the entire ruby stacktrace.
  • Additionally, the failed test cases are stored in the log files. You find the failing testcase (incl. browser) in log/errors.log
  • For all these tests that failed reproduceable you will find screenshots in the folder /screenshots. They have the same name as the test, so you can actually look at the page, and see what went wrong.

Probably you will use the combination of console output and screenshots most often, as they are most handy.

When you fixed the code and you want to rerun a specific test suite that failed before (maybe to check if it really works before running all tests), you can pass the name of the specific test suite with an additional argument -n and run the bin/test script only:

bundle exec bin/test firefox -n test_search_flow_frontpage_elements

Happy debugging!

File Structure

The whole repository is structured like a ruby gem: You can find the scripts, that start the tests in the /bin folder. What the scripts are doing is explained in the section above. You will find everything around the / addition to the tests in the /lib files:

  • lib/tests contains the actual tests. Each file in there reflects one of the stories (and is named accordingly). If there is a critical bug related to a specific story in the product, it is covered by a test within the file, too, eg. in the promotion code tests.
  • lib/classes contains all code, that is not written directly in the test files to keep the test suite clean and dry.
  • lib/lifelines contains the setup and error logging

Install xvfb

If you want run the tests headless on your local machine:

  • Linux:
sudo apt-get install -y xfonts-100dpi xfonts-75dpi xfonts-scalable xfonts-cyrillic xvfb x11-apps  imagemagick
  • Mac:

You may want to set up a virtual box with Linux or set up and use XQuarz (not yet tested by me though)

Contribute

Please fork and share and work on it. Any feedback is highly appreciated!