| Web Home: | http://testutils.org/sst |
|---|---|
| Project Home: | https://launchpad.net/selenium-simple-test |
| PyPI: | http://pypi.python.org/pypi/sst |
| License: | Apache License, Version 2.0 |
| Author: | Copyright (c) 2011-2012 Canonical Ltd. |
SST (selenium-simple-test) is a web test framework that uses Python to generate functional browser-based tests.
Tests are made up of scripts, created by composing actions that drive a browser and assert conditions. You have the flexibilty of the full Python language, along with a convenient set of functions to simplify web testing.
SST consists of:
- user actions and assertions (API) in Python
- test case loader (generates/compiles scripts to unittest cases)
- console test runner
- data parameterization/injection
- selectable output reports
- selectable browsers
- headless (xvfb) mode
- screenshots on errors
Test output can be displayed to the console, saved as an HTML report, or JUnit-compatible XML for compatibility with CI systems.
SST can be installed from PyPI using pip:
pip install -U sst
For example, on an Ubuntu/Debian system, you could Install SST (system-wide) like this:
$ sudo apt-get install python-pip xvfb
$ sudo pip install -U sst
a sample test case in SST:
from sst.actions import *
go_to('http://www.ubuntu.com/')
assert_title_contains('Ubuntu homepage')
Create a Python script (.py) file, and add your test code.
Then call your test script from the command line, using sst-run:
$ sst-run mytest
Test scripts perform actions in the browser as if they were a user. SST provides a set of “actions” (functions) for use in your tests. These actions are defined in the following API:
Usage: sst-run <options> [testname]
Options:
-h, --help show this help message and exit
-d DIR_NAME directory of test case files
-r REPORT_FORMAT results report format (html, xml, console)
-b BROWSER_TYPE select webdriver (Firefox, Chrome, InternetExplorer, etc)
-j disable javascript in browser
-m SHARED_MODULES directory for shared modules
-q output less debugging info during test run
-V print version info and exit
-s save screenshots on failures
--failfast stop test execution after first failure
--debug drop into debugger on test fail or error
--test run selftests
-x run tests in headless xserver
For logical organization of tests, you can use directories in your filesystem. SST will recursively walk your directory tree and gather all tests for execution.
For example, a simple test setup might look like:
/selenium-simple-test
/mytests
foo.py
and you would call this from the command line:
$ sst-run -d mytests
A more complex setup might look like:
/selenium-simple-test
/mytests
/project_foo
/feature_foo
foo.py
/project_bar
feature_bar.py
feature_baz.py
/shared
module.py
utils.py
and you would still call this from the command like:
$ sst-run -d mytests
SST will find all of the tests in subdirectories (including symlinks) and execute them. SST won’t look in directories starting with an underscore. This allows you to put Python packages/modules directly in your test directories if you want. A better option is to use the shared directory.
Inside tests you can import the sst.config module to know various things about the current test environment. The sst.config module has the following information:
from sst import config
# is javascript disabled?
config.javascript_disabled
# which browser is being used?
config.browser_type
# full path to the shared directory
config.shared_directory
# full path to the results directory
config.results_directory
If you need to disable Javascript for an individual test you can do it by putting the following at the start of the test:
JAVASCRIPT_DISABLED = True
SST is primarily being developed on Linux, specifically Ubuntu. It should work fine on other platforms, but any issues (or even better - patches) should be reported on the Launchpad project.
Get a copy of SST Trunk, install requirements, and run self-tests/examples from the branch:
$ sudo apt-get install bzr python-pip xvfb
$ bzr branch lp:selenium-simple-test
$ cd selenium-simple-test
$ sudo pip install -U -r requirements.txt
$ ./sst-run --test -x
$ ./sst-run -d examples
To manually setup dependencies, SST uses the following non-stdlib packages:
- selenium
- unittest2
- junitxml
- pyvirtualdisplay
- django (optional - needed for internal self-tests only)
SST source code repository and package download contain some trivial example scripts.
You can run them from your local sst directory like this:
$ ./sst-run -d examples
SST source code repository and package download contain a set of self-tests based on an included test Django project.
You can run the suite of self-tests (and the test Django server) from your local branch like this:
$ ./sst-run --test