A simple workflow engine for distributed applications 🎬 🌌
gambol enables you to write straightforward workflows that can be run on no-frills cloud environments. Rather than require you to be an expert in cloud infrastructure, gambol allows you focus on what matters: getting work done. You can write end-to-end tests for your distributed application, test packages in isolated environments, create comphrensive testing suites that can run both locally and in the cloud, and more. Say goodbye to spending half your day just setting up your testing infrastructure with shell script soup!
To get started with gambol, check out the getting started how-to below 👇
gambol is inspired by cleantest. cleantest originally started out with the goal of taking Python functions that perform some destructive action like modifying the underlying filesystem, and executing it within an isolated test environment. cleantest worked great at first, however, there were some challenges that emerged as the test framework matured.
First, it's really hard to support Python applications that must support
environments with wide interpreter version stratification. The Python API is a
moving target which made it difficult to work with cleantest's injectable
mechanism where it would copy over the body of a function and execute within an
isolated environment. Second, cleantest had a bit of an identity crisis where it
became both a testing framework and a workflow orchestrator. You could write tests
Python tests the traditional way like you can with unittest
or pytest
, but you
could also orchestrate things that had absolutely nothing to do with testing Python
modules like set up a mini-supercomputer or end-to-end tests for a separate
application. Difficult to sell people on your using your framework when you've
effectively railroaded two different paradigms together!
gambol is a breakout of that second half of cleantest. It's a workflow orchestrator for distributed applications. It can request isolated environment dynamically, test a wide variety of applications, and has straightforward syntax for creating workflows.
You first need to setup a cloud that will provide the instances that gambol will use to run workflows. For this how-to, we can use LXD as our backing cloud, and will use snap to install gambol.
Run the following commands to install LXD on your system:
snap install lxd
lxd init --minimal
And now use the following command to install gambol:
# [WIP]: Snap is not published yet
snap install gambol
Now you're ready to start using gambol.
Below are some key concepts in gambol that you should be familiar with to better understand how it works:
A playthrough is a YAML file that defines the workflow that gambol to will run.
A provider is a cloud that provides the containers and/or virtual machines that gambol will use run to run defined playthrough in. Currently, LXD is the only supported option.
An Act is a sequence of steps that you want to execute within an instance requested from the configured provider. Each Act corresponds to a single instance, or an Act can correspond an instance that has been requested for a previous Act.
A Scene is a step within an Act. Scenes wrap executable blocks, and will report whether or not the given block completes successfully within an Act instance.
Using your favorite text editor, create the file playthrough.yaml, and enter the
following document. This playthrough will create the Act instance act-1
, and will
run the scenes Install cowsay
and Say hello word
:
name: "my first playthrough"
provider:
lxd:
acts:
act-1:
name: "Say hello to the world with gambol!"
run-on: noble
scenes:
- name: "Install cowsay"
run: |
export DEBIAN_FRONTEND=noninteractive
apt-get -y install cowsay
- name: "Say hello world"
run: |
cowsay hello world
After you have created the file playthrough.yaml, use the following command to run the playthrough with gambol:
gambol run playthrough.yaml
Congratulations! You have run your first playthrough using gambol 🎉
gambol can do a lot more than just make an ASCII cow say hello within a system container. I'm still working on more comprehensive documentation for gambol, but in the meantime, you check out the e2e tests for more advanced use cases of gambol/
Right now, gambol is very much a hacking and wacking endevour, so there's no formal contribution process quite yet. However, if you are interested in contributing to gambol, please ensure the all e2e tests are passing before opening a pull request:
make e2e
All contributions must be licensed under the AGPLv3 license.
If you're interested in discussing development of gambol, reach out on Mastodon, or feel free to start a new Discussion thread on GitHub.
gambol is licensed under the GNU Affero General Public License, version 3. Please see the AGPLv3 LICENSE file for further details.