Web application for checking tmt tests, plans and stories.
To run the service locally for development purposes, use the following command:
podman-compose up --build
Add -d
for the service to run in the background.
In order to quickly experiment without using Celery use this:
USE_CELERY=false CLONE_DIR_PATH=/var/tmp/test uvicorn tmt_web.api:app --reload --host 0.0.0.0 --port 8000
To run the tests, use the pytest
command (assuming the service is running).
Alternatively, if you have hatch
installed, hatch run dev:test
command will
rebuild, start the service and run the tests.
Run hatch env show
to see the list of available environments and their scripts.
REDIS_URL
- optional, passed to Celery on initialization as abroker
andbackend
argument, default value is:redis://localhost:6379
CLONE_DIR_PATH
- optional, specifies the path where the repositories will be cloned, default value is:./.repos/
USE_CELERY
- optional, specifies if the app should use Celery, set tofalse
for running without CeleryAPI_HOSTNAME
- required, specifies the hostname of the API, used for creating the callback URL to the service
The API version is defined by prefix in url, e.g. /v0.1/status
.
If we want to display metadata for both tests and plans, we can combine
the test-*
and plan-*
options together, they are not mutually
exclusive.
test-url
and test-name
, or plan-url
and plan-name
are required.
Returns ID of the created Celery task with additional metadata in JSON
and callback url for /status
endpoint, returns the same in HTML format
if format
is set to html
.
-
test-url
- URL of the repo test is located in - accepts astring
-
test-ref
- Ref of the repository the test is located in - accepts astring
, defaults to default branch of the repo -
test-path
- Points to directory wherefmf
tree is stored -
test-name
- Name of the test - accepts astring
-
plan-url
- URL of the repo plan is located in - accepts astring
-
plan-ref
- Ref of the repository the plan is located in - accepts astring
, defaults to default branch of the repo -
plan-path
- Points to directory wherefmf
tree is stored -
plan-name
- Name of the plan - accepts astring
-
format
- Format of the output - accepts astring
, default isjson
, other options areyaml
,html
(serves as a basic human-readable output format)
Returns a status of the tmt object being processed by the backend.
task_id
- ID of the task - accepts astring
Returns a status of the tmt object being processed by the backend in a simple HTML formatting.
task_id
- ID of the task - accepts astring
Returns a health status of the service.
The web interface design is based on the work of Fedora Design team, licensed under CC-BY-SA 4.0. The design elements include typography, color scheme, and visual components adapted from the Fedora design guidelines.