This repository is used to store the configuration of podman compose in order to provide an environment for development.
To run DCI in podman-compose
, first clone this repository:
git clone git@github.com:redhat-cip/dci-dev-env.git
Then, bootstrap dci-dev-env
:
./utils/bootstrap.sh
Once install, you can launch the environment:
podman-compose up -d
Then, you can attach containers in order to run parts of the applications:
podman-compose exec <container-name> bash
For instance
podman-compose exec api bash
To see logs of a specific container, use podman logs command
podman-compose logs -f api
Here is the list of containers for running the application:
db
: contains the postgresql database and serves it on localhost port5432
, started by default ;api
: contains the API of the application and serves it on localhost port5000
;tox
: container used to run test on dci-control-server, python-dciclient and dci-ansible ;
Other services are available in dci-<service>
.yml
ui
: contains the web app of DCI and serves it on localhost port8000
.doc
: helper to build the project's documentation ;keycloak
: keycloak server forSSO
.⚠️ Uselocalhost
askeycloak
's domain as it's set to this value and not;127.0.0.1
analytics
: analytics container running elatic service.feeder
: feeder container for synchronizing components.
You can initialize or re-initialize the database from the API container by running:
podman-compose exec api ./bin/dci-dbprovisioning
This container allows to run test on dci-control-server, python-dciclient and dci-ansible.
To run tox
on dci-control-server:
podman-compose exec -w /opt/dci-control-server tox tox
To run tox
on python-dciclient:
podman-compose exec -w /opt/python-dciclient tox tox
To run tox
on dci-ansible:
podman-compose exec -w /opt/dci-ansible tox tox
If you want to start the feeder, do not forget to start the createbuckets container
podman-compose -f dci.yml -f dci-feeder.yml up -d feeder createbuckets
This container allows to use SSO
based authentication.
See dci-keycloak/README.md
This container generates DCI documentation.
Use the following command to generate the doc:
podman-compose -f dci-doc.yml run doc
You will need to install podman-compose
and git-review
:
pip install -U -r requirements.txt