This repository hosts the Synergetic Meta-Orchestrator consisting of a Flask REST API that is responsible for translating intent formulations, constructing and enforcing deployment plans for Hyper Distributed Application Graphs.
This is a fork of the original SMO repository, which can be found here.
- Changes from the Original Repository
- Current Status and Issues
- License
- Getting started
- Changelog from the Original Repository
- Contributing
- Deployment
This repository has undergone a few changes to enhance its functionality, maintainability and compatibility.
-
Introduction of
pyproject.toml
: This repository has been updated to reflect a post-hypermodern Python development approach. The adoption of apyproject.toml
file provides a standardized and centralized configuration for dependency management and tooling. This simplifies project setup, ensures compatibility with modern Python packaging standards, and consolidates configuration for tools such as linters, formatters, and test runners. -
Project Refactoring: The codebase has been reorganized to improve readability, remove unnecessary dependencies, and simplify the overall structure. This ensures a cleaner and more maintainable implementation.
-
Database Support: Added support for SQLite, enabling more flexibility in deployment environments and simplifying testing and development setups.
-
Namespace Introduction: A dedicated namespace for the SMO has been introduced to better organize the project and facilitate integration with other components in the open-source cloud ecosystem (including Hop3).
-
Continuous Integration Enhancements: We've created a CI pipeline to ensure smoother automated testing, formatting enforcement, and build processes.
-
Code Quality Improvements: Static analysis (ruff, flake8, mypy, pyright...) and formatting (ruff, black, isort...) tools have been implemented to ensure consistent coding standards, and some minor issues and warnings have been resolved.
-
Testing Additions: We have added basic unit tests to validate functionality and as such start to improve the reliability of the codebase and the confidence in the future refactorings and enhancements.
-
Documentation Updates: Additional documentation (this README) has been included to clarify the usage and contribution guidelines for the project.
-
Added a CLI: We have added a CLI to interact with the SMO API. The CLI provides a simplified interface for deploying, managing, and monitoring Hyper Distributed Application Graphs. (WIP - not fully implemented yet).
usage: smo [-h] {deploy,get-graph,list-graphs,placement,remove,start,stop,plugins} ...
SMO CLI - Simplified Modular Operations
options:
-h, --help show this help message and exit
commands:
{deploy,get-graph,list-graphs,placement,remove,start,stop,plugins}
Available commands
deploy Deploy a graph descriptor
get-graph Fetch a specific graph
list-graphs Fetch all graphs under a project
placement Trigger the placement algorithm for a graph
remove Remove a running graph
start Start a stopped graph
stop Stop a running graph
plugins List currently installed plugins
The current version of this fork is a work in progress, with several planned enhancements and improvements. The following are some of the key areas that we are actively working on:
- Dependency Issue: The current deployment mechanism relies on
hdarctl
, which is not universally compatible. We are exploring alternative solutions to address this dependency issue and ensure broader compatibility. - Test Coverage: While we have added a few basic unit tests, current coverage rate is only 48%, which is quite low. We are working to expand test coverage to include integration tests and end-to-end tests to validate the functionality of the application more comprehensively.
- Configuration Management: Currently the configuraion is hardwired. We are enhancing the configuration management system to provide more flexibility and customization options for deployment environments.
- Error Handling and Logging: We are enhancing error handling and logging mechanisms to improve the robustness and reliability of the application.
- Refactoring and Modernization: We are refactoring the codebase to use modern Python features and best practices, including the adoption of a layered architecture, improved configuration management, and dependency injection mechanisms.
- Migrations: We have introduced Alembic for database migrations. We need to ensure that the migrations are properly managed and versioned to avoid data loss or corruption during updates.
- Type Annotations: We are adding type hints to all functions and methods to improve code readability and maintainability.
- Linting and Formatting: We are addressing all linting and type-checking issues to ensure consistent code quality and adherence to coding standards.
- Documentation Improvements: We are updating the documentation to include a changelog, improve readability, and provide more comprehensive information on the project.
- Changelog: We need to introduce a changelog to track changes and updates to the project more effectively.
- CI/CD Pipeline: We are enhancing the CI/CD pipeline to automate testing, linting, and formatting processes more efficiently.
- Deployment Options: We are exploring deployment options on various platforms, including Hop3, Heroku, and Docker Swarm, to provide more flexibility and scalability.
- Contributions: We welcome contributions from the community to help us address these issues and improve the SMO project further.
- License: The original SMO repository is licensed under the MIT License. We are maintaining the same license for this fork to ensure compliance with the original project's licensing terms.
- Licensing Issues: The project uses the Gurobi Optimizer which is a mathematical optimization software library for solving mixed-integer linear and quadratic optimization problems. This package comes with a trial license that allows to solve problems of limited size. We need to replace it with an open-source alternative to avoid licensing issues.
The original SMO repository is licensed under the MIT License. We are maintaining the same license for this fork to ensure compliance with the original project's licensing terms.
Here is the license compliance report (reuse lint
) for this repository:
* Bad licenses: 0
* Deprecated licenses: 0
* Licenses without file extension: 0
* Missing licenses: 0
* Unused licenses: 0
* Used licenses: BSD-3-Clause, CC-BY-4.0, MIT
* Read errors: 0
* Files with copyright information: 48 / 48
* Files with license information: 48 / 48
Congratulations! Your project is compliant with version 3.3 of the REUSE Specification :-)
Note that third party libraries used in this project may have different licenses. Please refer to the respective libraries' documentation for details. We will provide a more detailed assessment of third-party licenses in the future.
This is especially relevant for the Gurobi Optimizer, which is a mathematical optimization software library for solving mixed-integer linear and quadratic optimization problems. This package comes with a trial license that allows to solve problems of limited size. As stated elsewhere, we need to replace it with an open-source alternative to avoid licensing issues.
Note
We currently rely on [hdarctl](https://gitlab.eclipse.org/eclipse-research-labs/nephele-project/nephele-hdar.git)
for the deployment of applications. A binary is currently provided in this repository, but it will only work on Linux/x86_64 (for other architecture, you will have to build another binary). We need to find a more robust solution.
Assuming you have a working Python environment, you can install the dependencies and run the application as follows:
# Install for development
pip install -e .
# ... or for production
pip install .
# Run the application
flask run
docker build -t smo .
docker run -p 5000:5000 smo
Warning
This will run the application in debug mode. DO NOT use this in production.
docker-compose up
Warning
This will run the application in debug mode. DO NOT use this in production.
vagrant up
vagrant ssh
# etc.
- Refactor codebase for readability and maintainability.
- Remove unnecessary dependencies.
- Add SQLite support for database flexibility.
- Introduce SMO-specific namespace for better organization.
- Add basic unit tests for functionality validation.
- Implement static analysis and enforce consistent formatting.
- Create a CI pipeline on SourceHut.
- Update documentation for usage and contribution guidelines (README)
- Extend test capabilities to include runtime type-checking with tools like Typeguard and Beartype.
- Introduce a
Makefile
to streamline hypermodern Python development workflows (e.g., testing, linting, formatting). - Add support for local development with Vagrant.
- Enable easy integration and deployment with Heroku.
- Implement a basic CLI for interacting with the SMO API.
- Generate a SBOM for the project.
- refact: Refactor using a layered architecture.
- type: Add type hints to all functions and methods.
- fix: Work around the
hdarctl
dependency issue. - test: Add more unit tests in order to reach close to 100% coverage.
- test: Add integration tests.
- test: Add e2e tests.
- test: test Swagger API using Schemathesis (and/or Bravado). (But not Dredd - Dredd is dead, killed by Oracle)
- feature: Improve error handling and logging.
- refact: use the modern (2.0) SQLAlchemy ORM API.
- feature: Implement a proper configuration management.
- feature: Implement a dependency injection mechanism.
- feature: Implement an extension mechanism (e.g.
pluggy
or similar). - refact: Replace the Gurobi Optimizer with an open-source alternative
- lint: Fix / suppress all linting issues (ruff, flake8).
- lint: Resolve all type-checking issues (mypy, pyright, typeguard, beartype).
- doc: Introduce a Changelog (and tools to manage it, like
towncryer
or similar). - doc: Create a proper documentation site using Portray or MkDocs (cf. https://lab.abilian.com/Tech/Python/Tooling/Documentation/)
- doc: Describe python API using a formalized format (cf. https://lab.abilian.com/Tech/Python/Tooling/Documenting%20a%20Python%20API/)
- chore: Add a license compliance report (and double-check REUSE config).
- refact: make the optimizer pluggable.
- feat: make the orchestration backend-end (current, Kubernetes) pluggable.
- refact: make the orchestrator pluggable.
- feat: create plugins for other orchestrators: Nomad, Docker Swarm, OpenNebula, Hop3 (when it's ready), etc.
- feat: Make a Web UI.
- refact: Make the optimisation algorithm pluggable.
- feat: Create and benchmark alternative optimisation algorithms.
- ...
We welcome contributions to the SMO project! Below is a guide to help you get started.
We recommend to use uv
, which is a rapidly evolving Python project that aims to provide a modern, flexible, and efficient way to manage Python environments. It is designed to be a drop-in replacement for virtualenv
, pyenv
, pipenv
, poetry
, rye
.
If uv
is not supported by your OS (with Homebrew or Linuxbrew, you can install it with brew install uv
, and you can similarly leverage Nix or Guix to get a recent version of uv
), you can use pipx
to install it (assuming you have pipx
installed, of course):
pipx install uv
Or simply:
curl -LsSf https://astral.sh/uv/install.sh | sh
# Or on Windows:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
uv venv
. .venv/bin/activate
uv sync
Besides the uv
tool, we use the following tools to maintain the codebase:
- ruff: A modern, flexible, and efficient way to manage Python environments.
- black: The uncompromising Python code formatter.
- isort: A Python utility / library to sort imports.
- flake8: A Python tool that glues together pep8, pyflakes, mccabe, and third-party plugins to check the style and quality of some Python code.
- mypy: An optional static type checker for Python.
- pyright: Another optional static type checker for Python.
- pytest: A framework that makes it easy to write small tests, yet scales to support complex functional testing for applications and libraries.
- beartype: A runtime type-checker for Python functions.
- typeguard: Another runtime type checking for Python functions.
- nox: A flexible test automation tool that automates testing in multiple Python environments.
We orchestrate these tools using make
, the standard build tool on Unix-like systems, which provides shortcuts for common tasks based on these tools:
The provided Makefile
orchestrates various tasks to streamline development, testing, formatting, and maintenance workflows. Here’s a high-level overview of the key functionalities it provides:
develop
: Installs development dependencies, activates pre-commit hooks, and configures Git for rebase workflows by default.install-deps
: Ensures the project's dependencies are synced and up-to-date usinguv sync
.update-deps
: Updates the project's dependencies to the latest compatible versions usinguv sync -U
.activate-pre-commit
: Installs pre-commit hooks to automatically enforce coding standards during commits.configure-git
: Sets Git to use rebase workflows automatically when pulling branches.test
: Runs Python unit tests usingpytest
.test-randomly
: Executes tests in a randomized order to uncover order-dependent issues.test-e2e
: Placeholder for running end-to-end tests (not yet implemented).test-with-coverage
: Runs tests and generates a coverage report for the specified package.test-with-typeguard
: Verifies runtime type checking for the package usingTypeguard
.lint
: Performs linting and type-checking usingadt check
to ensure code quality.format
: Formats code to meet the style guide usingdocformatter
for documentation strings andadt format
for general formatting.clean
: Cleans up temporary files, cache directories, and build artifacts, leaving the repository in a pristine state.help
: Displays availablemake
commands and their descriptions, leveragingadt help-make
.
The full list of available commands can be viewed by running make help
.
- Fork the Repository: Create a fork of the repository in your own GitHub/GitLab account.
- Create a Feature Branch: Make a new branch in your fork for the feature or bugfix you plan to work on.
- Follow the Code Style: Adhere to the project's code style guidelines (see below).
- Add Tests: Ensure your changes are covered by appropriate unit and integration tests.
- Document Changes: Update relevant sections in the documentation, including this README if necessary.
- Submit a Pull Request: Open a pull request against the
main
branch of this repository with a clear description of your changes.
We use PEP 8 as the basis for our code style. In practice, most of the code formatting is handled by the following tools:
- Black: Ensures consistent formatting.
- Ruff: Handles both formatting and static analysis.
- isort: Organizes imports.
To apply formatting and linting, simply run:
black .
isort .
ruff format
# Use this last one carefully, as it introduces refctorings that should be reviewed:
ruff . --fix
(ruff
last as it may conflict with some of the changes made by black
and isort
.)
Or, better yet, use the provided Makefile
shortcuts:
make format
: Apply formatting.
Tests are critical to maintaining the quality and reliability of the codebase. We encourage contributors to:
- Add unit tests for new or modified functionalities.
- Write integration tests for changes that affect multiple components.
Run all tests using:
pytest
For test coverage, use:
pytest --cov=smo
The Makefile
provides shortcuts for common testing tasks:
make test
: Run all tests.make test-randomly
: Run tests in random order.make test-with-coverage
: Run tests with coverage report.make test-with-typeguard
: Run tests with typeguard enabled.make test-with-beartype
: Run tests with beartype enabled.make lint
: Run linters and static analysis.
We use nox
to automate testing in multiple Python environments. To run tests with nox
, use:
nox
(Run nox -l
to list available session types.)
All new features or changes should be documented. The documentation should include:
- Code Comments: Explain non-trivial parts of the code.
- README Updates: Update this file for any major changes in functionality or usage.
- Changelog: Add a note in the upcoming changelog (to be implemented).
- API Documentation: Update the API documentation if necessary (swagger files).
To ensure a smooth review process:
- Make sure your branch is up to date with the
main
branch. - Ensure all tests pass and there are no linting or formatting issues.
- Provide a clear and concise description of the changes in your pull request, including any relevant issue numbers.
- Be responsive to reviewer feedback and address any requested changes promptly.
This project adheres to the PSF Code of Conduct. By participating, you agree to abide by its terms. Please be respectful and collaborative in all interactions.
For further details, see the [CODE_OF_CONDUCT.md](./CODE_OF_CONDUCT.md)
file in the main repository.
hop create smo
hop deploy smo
# TODO: env vars
heroku create
heroku addons:create heroku-postgresql:essential-0
heroku config:set FLASK_APP=smo
heroku config:set FLASK_ENV=production
# TODO: set SQLALCHEMY_DATABASE_URI properly
git push heroku main
heroku run flask db upgrade
TODO.
Use docker compose:
docker-compose up
The SMO API is available at port 8000.
The directory structure of the codebase is as follows:
src/
├── errors
├── models
├── routes
├── services
├── utils
├── app.py
└── config.py
errors
: custom errors and handlersmodels
: db modelsroutes
: app blueprintsservices
: business logic for the routesutils
: miscapp.py
: the Flask applicationconfig.py
: the Flask application configuration files