Tooling for converting subunit streams into a SQL DB
Go to file
Christian Berendt 11111251b4 Stop using intersphinx
Remove intersphinx from the docs build as it triggers network calls that
occasionally fail, and we don't really use intersphinx (links other
sphinx documents out on the internet)

This also removes the requirement for internet access during docs build.

This can cause docs jobs to fail if the project errors out on
warnings.

Change-Id: I4253a3ebb1eb2cf0b8e4d3b9e35c75cd56bc915d
Related-Bug: #1368910
2014-09-25 10:25:45 +02:00
doc/source Stop using intersphinx 2014-09-25 10:25:45 +02:00
subunit2sql Add get_failing_from_run db api method 2014-09-12 19:38:15 +00:00
.gitignore Update project packaging 2014-06-24 15:50:36 -04:00
.gitreview Add a .gitreview file 2014-07-12 12:48:23 -04:00
.testr.conf Add basic unit tests 2014-06-24 20:14:18 -04:00
alembic.ini Switch sample sqlalchemy url to use mysql 2014-09-12 19:38:11 +00:00
LICENSE Initial commit 2014-06-12 23:59:00 -04:00
openstack-common.conf Initial commit 2014-06-12 23:59:00 -04:00
README.rst Add basic support for creating a subunit stream from db 2014-08-12 23:18:18 -04:00
requirements.txt Bump oslo.config version 2014-07-23 22:53:16 +00:00
setup.cfg Add basic support for creating a subunit stream from db 2014-08-12 23:18:18 -04:00
setup.py Initial commit 2014-06-12 23:59:00 -04:00
test-requirements.txt Update the documentation 2014-07-27 13:15:12 -04:00
TODO.rst Merge "Add new item to the TODO list" 2014-08-14 21:56:32 +00:00
tox.ini Update pep8 ignore list 2014-09-03 09:10:00 -04:00

subunit2SQL README

subunit2SQL like it's name implies is a tool used for converting subunit streams to data in a SQL database. The motivation is that for multiple distributed test runs that are generating subunit output it is useful to store the results in a unified repository. This is the motivation for the testrepository project which does a good job for centralizing the results from multiple test runs.

However, imagine something like the OpenStack CI system where the same basic test suite is normally run several hundreds of times a day. To provide useful introspection on the data from those runs and to build trends over time the test results need to be stored in a format that allows for easy querying. Using a SQL database makes a lot of sense for doing this.

subunit2SQL uses alembic migrations to setup a DB schema that can then be used by the subunit2sql binary to parse subunit streams and populate the DB. Additionally, it provides a DB API that can be used to query information from the results stored to build other tooling.

Usage

DB Setup

The usage of subunit2ql is split into 2 stages. First you need to prepare a database with the proper schema; alembic should be used to do this. The alembic.ini file in-tree includes the necessary options for alembic, however the database uri must be specificed with the option:

sqlalchemy.url = smysql:///user:pass@127.0.0.1/subunit

to be able to use alembic to setup the db schema. Obviously the sql connector type, user, password, address, and database name should be specific to your environment. After the alembic.ini file is updated you perform can run the db migrations with the command:

alembic upgrade head

from the root path for subunit2sql. This will bring the DB schema up to the latest version for subunit2sql. Also, it is worh noting that the schema migrations used in subunit2sql do not currently support sqlite. While it is possible to fix this, sqlite only supports a subset of the necessary sql calls used by the migration scripts. As such, maintaining support for sqlite will be a continual extra effort, so if support is added in the future, it is no guarantee that it will remain. In addition, the performance of running, even in a testing capacity, subunit2sql with MySQL or Postgres make it worth the effort of setting up one of them to use subunit2sql.

Running subunit2sql

Once you have a database setup with the proper database schema you can then use the subunit2sql command to populate the database with data from your test runs. subunit2sql takes in a subunit v2 either through stdin or by passing it file paths as positional arguments to the script. If only a subunit v1 stream is available, it can be converted to a subunit v2 stream using the subunit-1to2 utility.

There are several options for running subunit2sql, they can be listed with:

subunit2sql --help

The only required options are the state_path and the database-connections. These options and the other can either be used on the CLI, or put in a config file. If a config file is used you need to specify the location on the CLI.

Most of the optional arguments deal with how subunit2sql interacts with the SQL DB. However, it is worth pointing out that the artifacts option and the run_meta option are used to pass additional metadata into the database for the run(s) being added. The artifacts option should be used to pass in a url or path that points to any logs or other external test artifacts related to the run being added. The run_meta option takes in a dictionary which will be added to the database as key value pairs associated with the run being added.

Creating a v2 Subunit Stream from the DB

The sql2subunit utility is used for taking a run_id and creating a subunit v2 stream from the data in the DB about that run. To create a new subunit stream run:

sql2subunit $RUN_ID

along with any options that you would normally use to either specify a config file or the DB connection info. Running this command will print to stdout the subunit v2 stream for the run specified by $RUN_ID, unless the --out_path argument is specified to write it to a file instead.