Test Observer (TO) is a dashboard for viewing the results of tests run on different environments for a particular artefact. A user interested in testing an artefact (a deb, snap, charm or image) under different environments (particular machines or cloud setups) can use TO as means for storing, viewing and comparing results with previous runs or versions of an artefact. The last use case is particularly useful for catching regressions. Additionally, TO provides a mechanism to assign reviewers that can look at results and mark artefacts as approved or failed to gate updates. It is important to note that TO does not run the tests itself, but provides an API with which users can report the results to.
Certification currently deploys an instance of TO that they used for reviewing Stable Release Updates (SRUs). Other teams also use this instance for their tests. You can visit the frontend and view the API docs, although this currently requires Canonical VPN access. There's also a staging deployment of frontend and API that teams can use to test their integration.
The easiest way to run the full Test Observer stack locally is using Docker Compose (installed preferably via the docker.io provided APT source):
# Start the complete stack (backend, frontend, database)
# Migrations and test data seeding happen automatically
docker compose up
# Start without test data seeding
SEED_DATA=false docker compose up
# Run in detached mode
docker compose up -d
# Stop the stack
docker compose down
# Rebuild containers after code changes
docker compose up --build
# Run tests
docker compose exec test-observer-api pytestThis will start:
- Backend API at http://localhost:30000(with automatic migrations and seeding)
- Frontend at http://localhost:30001
- PostgreSQL database with persistent storage on port 5432
- SimpleSAMLPHP at http://localhost:8080a local Identity Provider (IdP) for testing
Test Observer (TO) supports authentication through SAML SSO. On staging and production Ubuntu One acts as the Identity Provider (IdP). On development however, SimpleSAMLPHP is deployed alongside TO to act as an IdP. The setup is configures one user account with the username "certbot" and password "password". This configuration resides in backend/saml/simplesamlphp/authsources.php.
For component-specific development, see the backend and frontend documentation.
To run the whole system via Terraform, juju and charms simulating production and staging environments, use terraform
A charmed Test Observer deployment can be integration tested using charmcraft test (which itself internally uses a classically confined copy of spread bundled with charmcraft).
The integration tests are runnable either locally (using lxd at the time of writing) or using GitHub. Alternative test execution backends are configurable by adding new adhoc backends next to lxd and github in the spread.yaml.
Tests can be run locally with either charmcraft test lxd or charmcraft.spread lxd (the latter gives a bit more verbose log output).
charmcraft.spread -v lxdTo debug the charm integration tests, you can jump into a spread provided environment for the test execution either before, instead of the test task, or after a test task has been executed (you could also combine this choosing to run only a specific test scenario).
# open a shell to the execution environment _before_ executing each test task 
charmcraft.spread -v -shell lxd 
# open a shell to the execution environment _instead of_ executing each test task 
charmcraft.spread -v -shell lxd
# open a shell to the execution environment _after_ of executing each test task 
charmcraft.spread -v -shell-after lxd