Skip to content

Latest commit

 

History

History
122 lines (95 loc) · 5.61 KB

README.md

File metadata and controls

122 lines (95 loc) · 5.61 KB

OMOTES orchestrator

This repository is part of the 'Nieuwe Warmte Nu Design Toolkit' project.

Orchestrator component of OMOTES project which monitors workflows and starts the various steps of each workflow.

Directory structure

The following directory structure is used:

  • ci/: Contains all CI & other development scripts to help standardize the development workflow for both Linux and Windows.
  • omotes-system-at-orchestrator/: Submodule link to the latest omotes-system release. Necessary for infrastructure that is necessary during the integration test.
  • config/: Contains orchestrator workflow definitions configuration. The workflow_config.json file will be overwritten by a volume mount when deploying via docker.
  • integration_test/: Contains a large integration test which is run to check for robustness and stability.
  • src/: Source code for the orchestrator as well as the necessary database models.
  • unit_test/: All unit tests for the orchestrator.
  • .dockerignore: Contains all files and directories which should not be available while building the docker image.
  • .env-template: Template .env file to run the orchestrator locally outside of docker.
  • .gitignore: Contains all files and directories which are not kept in Git source control.
  • dev-requirements.txt: Pinned versions of all development and non-development dependencies.
  • Dockerfile: The build instructions for building the docker image.
  • dev.Dockerfile: Used when running or testing with local code from the omotes-system repository.
  • pyproject.toml: The Python project (meta) information.
  • requirements.txt: Pinned versions of all dependencies needed to run the orchestrator.
  • run.sh: Script to start the orchestrator locally outside of docker on Linux.
  • run_windows.sh: Script to start the orchestrator locally outside of docker on Windows.

Development workflow

The scripts under ci/ are used to standardize the development proces. The following scripts are available for Windows (under ci/win32/ with extension .cmd) and Linux (under ci/linux/ with extension `.sh).

  • create_venv: Creates a local virtual environment (.venv/) in which all dependencies may be installed.
  • db_models_generate_new_revision: Can be used to generate a new revision of the SQL db schema. Expects 1 argument e.g. ci/linux/db_models_generate_new_revision.sh "this is the revision message.
  • install_dependencies: Installs all development and non-development dependencies in the local virtual environment.
  • lint: Run the flake8 to check for linting issues.
  • test_unit: Run all unit tests under unit_test/ using pytest.
  • typecheck: Run mypy to check the type annotations and look for typing issues.
  • update_dependencies: Update dev-requirements.txt and requirements.txt based on the dependencies specified in pyproject.toml

A typical development workflow would be:

  1. create and configure .env from .env-template
  2. run create_venv
  3. run install_dependencies.
  4. develop or update the codebase according to the requirements...
  5. run lint, test_unit, and typecheck to check for code quality issues.

One of the example development workflows can be that you need to run and develop the orchestrator locally (without docker) while having other omotes-system infrastructure (e.g. postgres, rabbitmq, workers, etc.) started by dockers. The steps could be:

  1. comment out the orchestrator parts in the docker-compose.yml file in the omotes-system repository.
  2. start omotes-system infrastructure via running setup and start scripts in the omotes-system repository.
  3. run run.sh or run_windows.sh in the orchestrator repository to develop and interact with omotes-system infrastructure.

All these scripts are expected to run from the root of the repository

Working with omotes-system submodule

The omotes-system is available as a submodule at omotes-system-at-orchestrator. The name of this path is chosen to make sure starting the omotes-system with docker compose uses the omotes-system-at-orchestrator project name instead of omotes-system. If a developer is both developing the orchestrator and non-submodule omotes-system otherwise the environments may conflict in docker.

To make the submodule available after cloning this repository:

git submodule update --init

Also, checking out a different branch on orchestrator may reference a different commit than the branch you are moving from. So, whenever you checkout a new branch, make sure you run the command:

git submodule update --init

This will update the reference to point to the correct submodule commit.

How to work with alembic to make database revisions

First set up the development environment with create_venv and install_dependencies. Then you can make the necessary changes to omotes_orchestrator/db_models/. Finally, a new SQL schema revision may be generated using alembic by running:

./ci/linux/db_models_generate_new_revision.sh "revision message"

All database revisions will be automatically applied when the orchestrator is started.

Direct Alembic control

In case more control is necessary, you can run the necessary alembic commands directly after activating the virtual environment (Linux: . ./.venv/bin/activate, Windows: call venv\Scripts\activate.bat).

First, change directory: cd src/

  • Make a revision: alembic revision --autogenerate -m "<some message>"
  • Perform all revisions: alembic upgrade head
  • Downgrade to a revision: alembic downgrade <revision> (revision 'base' to undo everything.)