4901d45bbf
This patch adds UI templates directory and utils, which serve and unify HTML generation. Also, there are some fixes and improvements for HTML task report. In this patch: * Base mako templates (package rally.ui) * Rework tests/ci/rally-gate templates in order to use base template with generic header and styles * Show scenario errors (if any) in task report tab * Show scenario output (if any) in task report tab * Show SLA data in Overview tab * Show total scenario duration value (after the scenario name, above tabs) * If got some iteration error, save exception class name in the database instead of its repr() * Prevent layout from breaking and show proper message if JS libs can not be loaded for some reason * Fix bug 1387661 - the cause of the bug is wrong input json data, generated by plot.py. This happens when some atomic actions data missed (which is a result of scenario errors) - and we have different atomic actions sets between iterations. The fix saves atomic actions integrity by adding missed atomic actions (with 0 value). * Fix: if unexistend task uuid is specified in `task report' command, then proper exception is raised Closes-Bug: 1387661 Change-Id: I4bcbf86e6fad844e6752306eb6c1ccfefa6c6909 |
||
---|---|---|
.. | ||
ci | ||
functional | ||
hacking | ||
unit | ||
__init__.py | ||
README.rst |
Testing
Please, don't hesitate to write tests ;)
Unit tests
Files: /tests/unit/*
The goal of unit tests is to ensure that internal parts of the code work properly. All internal methods should be fully covered by unit tests with a reasonable mocks usage.
About Rally unit tests:
- All unit tests are located inside /tests/unit/*
- Tests are written on top of: testtools, fixtures and mock libs
- Tox is used to run unit tests
To run unit tests locally:
$ pip install tox
$ tox
To run py26, py27 or pep8 only:
$ tox -e <name>
#NOTE: <name> is one of py26, py27 or pep8
To get test coverage:
$ tox -e cover
#NOTE: Results will be in /cover/index.html
To generate docs:
$ tox -e docs
#NOTE: Documentation will be in doc/source/_build/html/index.html
Functional tests
Files: /tests/functional/*
The goal of functional tests is to check that everything works well together. Fuctional tests use Rally API only and check responses without touching internal parts.
To run functional tests locally:
$ source openrc
$ rally deployment create --from-env --name testing
$ tox -e cli
#NOTE: openrc file with OpenStack admin credentials
Rally CI scripts
Files: /tests/ci/*
This directory contains scripts and files related to the Rally CI system.
Rally Style Commandments
File: /tests/hacking/checks.py
This module contains Rally specific hacking rules for checking commandments.