Helper tool for qontract-reconcile development
Project description
Qontract Development CLI
Qontract Development CLI supports your daily qontract-reconcile development work.
[toc]
Recommended Installation Method
The recommended way to install qontract-development-cli is to use the uv tool:
uv tool install qontract-development-cli
and upgrade an existing installation with:
uv tool upgrade qontract-development-cli
Alternative Installation Methods
You can install this library from PyPI with pip:
python3 -m pip install qontract-development-cli
or install it with pipx:
pipx install qontract-development-cli
and upgrade an existing installation with:
pipx upgrade qontract-development-cli
Quickstart
-
Create initial configuration
qd config init
-
Create a profile
sql-queryto run thesql-queryintegrationqd profile create sql-query
-
Run
sql-queryprofileqd profile run dev sql-query
Features
Qontract Development CLI currently provides the following features (get help with -h or --help):
- Run
qontract-reconcileandqontract-serveras docker containers on your local machine - Support for different App-Interface environments (dev, prod, ...) via the
envcommand - Configure your qontract-reconcile integration with the
profilecommand - Support pull request reviews (see
profile create) - Bootstrap your initial configurations with the
configcommand - Shell auto-completion (see
qd --help) - Automatically restart
qontract-reconcilecontainer when files change - Automatically rebuild the App-Interface bundle and restart the
qontract-servercontainer when files change
Examples
Take a look at the examples directory for different profile examples.
Usage
The following sections describe all available commands and their options.
Config
Manage global qontract-development-cli configuration.
qd config [sub-cmd] --help
- edit: open the configuration file in your favorite editor
- init: create a default configuration
Global Settings
| Key | Description | Default |
|---|---|---|
| debug | Enable/disable debug mode | false |
| defaults_profile | Name of defaults profile | defaults |
| docker_compose_project_name | Docker compose project name | qontract-development |
| editor | Your favorite editor | $EDITOR or vim |
| environments_dir | Directory to store environment files | User config directory / environments |
| profiles_dir | Directory to store profile files | User config directory / profiles |
| worktrees_dir | Directory to store git repo worktrees | User cache directory / worktrees |
Environments
An environment specifies app-interface instance settings, e.g., dev vs. prod config and path to the actual app-interface instance.
qd env [sub-cmd] --help
- edit: Create/edit an environment file in your editor.
- ls: List all available environments.
- rm: Remove environment.
- show: Display environment.
Environment Settings
| Key | Description | Default |
|---|---|---|
| app_interface_path | Path to local app-interface instance | ~/workspace/app-interface |
| app_interface_state_bucket | S3 bucket | empty |
| app_interface_state_bucket_account | AWS S3 account | empty |
| config | app-interface config | ~/workspace/qontract-reconcile/config.dev.toml |
| container_platform | Default Docker container platform for all images | linux/amd64 |
| gitlab_pr_submitter_queue_url | Gitlab pr submitter queue url | |
| run_qontract_api | Run qontract-api container | false |
| run_qontract_api_subscriber | Run qontract-api-subscriber container | false |
| run_qontract_api_worker | Run qontract-api-worker container | false |
| run_cache | Run cache (Redis) container | false |
| run_qontract_reconcile | Run qontract-reconcile container | true |
| run_qontract_server | Run qontract-server container | true |
| run_vault | Run vault container | false |
:point_right: Bold keys are mandatory or should be customized.
Profiles
A profile specifies all settings to run a qontract-reconcile integration (e.g., sql-query).
qd profile [sub-cmd] --help
-
create: Create a new profile to run an integration.
Supports the creation of a new profile from an open PR/MR. See
$ qd profile create --helpfor all available options. -
edit: Edit a profile in your editor.
-
ls: List all available profiles.
-
rm: Remove profile.
-
run: Run a profile.
-
show: Display profile.
--no-dry-run
By default, qd runs integrations in dry-run mode if not explicitly specified differently in the profile config.
There is also a --no-dry-run flag which lets you disable dry-run mode from the command line.
qd profile run dev my-integration --no-dry-run
The command line flag takes precedence over any configuration you might have in the profile settings.
Profile Settings
| Key | Description | Default |
|---|---|---|
| additional_environment | Dictionary of additional environment variables to pass to the qontract-reconcile container | {} |
| container_uid | Change ownership of /recconcile files in container to this user id | current UID |
| command | Command to run in the qontract-reconcile container. | run-integration |
| command_extra_args | Additional arguments to pass to the command. | |
| debugger | Python debugger | debugpy |
| dry_run | Run --dry-run mode | true |
| extra_hosts | List of 'HOSTNAME:IP' mapping entries for qontract-reconcile /etc/hosts. See extra_hosts docker compose file. |
[] |
| integration_name | Intergration name | |
| integration_extra_args | Intergration extra arguments | |
| internal_redhat_ca | Inject Red Hat internal CAs and REQUESTS_CA_BUNDLE environment variable |
false |
| internal_redhat_ca_image | The Red Hat internal CA image | Internal one |
| internal_redhat_ca_container_platform | The Red Hat internal CA container platform | Default from environment |
| log_level | Log level | info |
| app_interface_path | App-interface instance path. (Overrides env.app_interface_path) | |
| app_interface_pr | App-interface PR/MR number | |
| app_interface_upstream | Upstream remote name | upstream |
| cache_image | Cache (Redis) image | redis:7-alpine |
| cache_container_platform | Cache (Redis) container platform | Default from environment |
| cache_compose_file | Cache docker-compose file template | cache.yml.j2 |
| qontract_api_build_image | Build qontract-api image | true |
| qontract_api_image | Qontract-api image | quay.io/redhat-services-prod/.../qontract-api-master:latest |
| qontract_api_container_platform | Qontract-api container platform | Default from environment |
| qontract_api_compose_file | Qontract-api docker-compose file template | api.yml.j2 |
| qontract_api_debugger_port | Debugger port for qontract-api | 5679 |
| qontract_api_subscriber_build_image | Build qontract-api-subscriber image | true |
| qontract_api_subscriber_image | Qontract-api-subscriber image | quay.io/redhat-services-prod/.../qontract-api-master:latest |
| qontract_api_subscriber_container_platform | Qontract-api-subscriber container platform | Default from environment |
| qontract_api_subscriber_compose_file | Qontract-api-subscriber docker-compose file template | subscriber.yml.j2 |
| qontract_api_subscriber_debugger_port | Debugger port for qontract-api-subscriber | 5681 |
| qontract_api_worker_build_image | Build qontract-api-worker image | true |
| qontract_api_worker_image | Qontract-api-worker image | quay.io/redhat-services-prod/.../qontract-api-worker-master:latest |
| qontract_api_worker_container_platform | Qontract-api-worker container platform | Default from environment |
| qontract_api_worker_compose_file | Qontract-api-worker docker-compose file template | worker.yml.j2 |
| qontract_api_worker_debugger_port | Debugger port for qontract-api-worker | 5680 |
| qontract_reconcile_build_image | Build qontract-reconcile image | true |
| qontract_reconcile_image | Qontract-reconcile image | quay.io/redhat-services-prod/.../qontract-reconcile-master:latest |
| qontract_reconcile_container_platform | Qontract-reconcile container platform | Default from environment |
| qontract_reconcile_path | Qontract-reconcile path | ~/workspace/qontract-reconcile |
| qontract_reconcile_pr | Qontract-reconcile PR/MR number | |
| qontract_reconcile_upstream | Upstream remote name | upstream |
| qontract_reconcile_compose_file | Qontract-reconcile docker-compose file template | reconcile.yml.j2 |
| qontract_reconcile_debugger_port | Debugger port for qontract-reconcile | 5678 |
| qontract_server_build_image | Build qontract-server image | true |
| qontract_server_image | Qontract-server image | quay.io/redhat-services-prod/.../qontract-server-master:latest |
| qontract_server_container_platform | Qontract-server container platform | Default from environment |
| qontract_server_path | Qontract-server path | ~/workspace/qontract-server |
| qontract_server_compose_file | Qontract-server docker-compose file template | server.yml.j2 |
| qontract_server_debugger_port | Debugger port for qontract-server | 6789 |
| qontract_schemas_path | Qontract-schemas path | ~/workspace/qontract-schemas |
| qontract_schemas_pr | Qontract-schemas PR/MR number | |
| qontract_schemas_upstream | Upstream remote name | upstream |
| run_once | If 'true', execute the integration once and exit | true |
| sleep_duration_secs | If not run_once, sleep duration until integration runs again | 10 |
| localstack | Run localstack container and set AWS related environment variables | false |
| localstack_compose_file | Path to your Localstack docker-compose file | qontract_reconcile_path / dev/localstack/docker-compose.yml |
| skip_initial_make_bundle | Skip initial make bundle step | false |
| vault_image | Vault image | vault:1.5.4 |
| vault_container_platform | Vault container platform | Default from environment |
| vault_compose_file | Vault docker-compose file template | vault.yml.j2 |
:point_right: Bold keys are mandatory or should be customized.
Connecting your IDE to QR
Note that the Qontract Reconcile container will not start running until it is connected to by a debugger. You can use a config like this for VSCode:
{
"version": "0.2.0",
"configurations": [
{
"name": "Python Debugger: Reconcile",
"type": "debugpy",
"request": "attach",
"connect": { "host": "localhost", "port": 5678 },
"pathMappings": [
{ "localRoot": "${workspaceFolder}", "remoteRoot": "/work" }
],
"justMyCode": false,
"autoReload": {
"enable": true
}
},
{
"name": "Python Debugger: Api",
"type": "debugpy",
"request": "attach",
"connect": { "host": "localhost", "port": 5679 },
"pathMappings": [
{ "localRoot": "${workspaceFolder}", "remoteRoot": "/opt/app-root/src" }
],
"justMyCode": false,
"autoReload": {
"enable": true
}
},
{
"name": "Python Debugger: Subscriber",
"type": "debugpy",
"request": "attach",
"connect": { "host": "localhost", "port": 5681 },
"pathMappings": [
{ "localRoot": "${workspaceFolder}", "remoteRoot": "/opt/app-root/src" }
],
"justMyCode": true,
"autoReload": {
"enable": true
}
},
{
"name": "Python Debugger: Worker",
"type": "debugpy",
"request": "attach",
"connect": { "host": "localhost", "port": 5680 },
"pathMappings": [
{ "localRoot": "${workspaceFolder}", "remoteRoot": "/opt/app-root/src" }
],
"justMyCode": true,
"autoReload": {
"enable": true
}
}
],
"compounds": [
{
"name": "Debug: Reconcile + qontract-api",
"configurations": [
"Python Debugger: Reconcile",
"Python Debugger: Api",
"Python Debugger: Subscriber",
"Python Debugger: Worker"
],
"stopAll": true,
"presentation": {
"hidden": false,
"group": "Full Stack",
"order": 0
}
}
]
}
Please note that development does not currently work with PyCharm as debugpy is not yet supported. This issue is being tracked here
PR/MR support
It's a pretty handy feature to create a profile from a pull request (merge request). E.g.:
qd profile create --app-interface PATH_TO_YOUR_LOCAL/app-interface-dev-data --app-interface-pr NUMBER --qontract-schemas-pr NUMBER --qontract-reconcile-pr NUMBER --integration-name glitchtip --integration-extra-args '' glitchtip-pr-check
Which results in this profile:
$ qd profile show glitchtip-pr-check
---
app_interface_path: PATH_TO_YOUR_LOCAL/app-interface-dev-data
app_interface_pr: NUMBER
integration_name: glitchtip
qontract_reconcile_pr: NUMBER
qontract_schemas_pr: NUMBER
Running this profile will:
- Create new git worktrees (see
config.worktrees_dir) for app-interface-dev-data, qontract-schema, and qontract-reconcile PRs - Start the containers with the adapted path to these worktrees
- Restarting the profile will fetch PR updates
:point_right: A git worktree cleanup isn't implemented yet
Development
Release
- Bump the version in
pyproject.toml - Update the
CHANGELOG.md - Commit the changes
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qontract_development_cli-0.17.1.tar.gz.
File metadata
- Download URL: qontract_development_cli-0.17.1.tar.gz
- Upload date:
- Size: 20.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Red Hat Enterprise Linux","version":"9.7","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc9e7b5335ae51494884588197479a0e105d838aebb7fff64f1d4b9497152dcd
|
|
| MD5 |
9a584b6f00327a2c72cbc29c0b5059dd
|
|
| BLAKE2b-256 |
5ab0faaee4f2c56a41e5bef46890b62025819c26f8f3e201b0b8d073f0f6b5d8
|
File details
Details for the file qontract_development_cli-0.17.1-py3-none-any.whl.
File metadata
- Download URL: qontract_development_cli-0.17.1-py3-none-any.whl
- Upload date:
- Size: 26.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Red Hat Enterprise Linux","version":"9.7","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc0cdd95df5d544d813bccae8ebef7b001a9c4a96fd8133cc21184a7c769609c
|
|
| MD5 |
08304081c32b180c7df775ac7ce520dc
|
|
| BLAKE2b-256 |
fb435fea10fe372195abdd59ae83e5c6b0d038cd6ec81976ae8c2d52e410eb3a
|