Camunda external task Robot Framework execution scheduler
Project description
Camunda external task Robot Framework execution scheduler
Technology preview.
carrot-executor
is an opinionated decoupled Camunda external task executor concept for scheduling Robot Framework RPA tasks. The concept separates task locking from the execution scheduling.
In this concept, Carrot external task client, based on camunda-external-task-client-js fetches configured external tasks from Camunda, schedules their execution, and keeps the tasks locked at Camunda until their executor has been completed. The Carrot external task client only completes task (by creating incident) by itself when the scheduling fails with unexpected reason. Any other interaction with Camunda is done by the scheduled Robot Framework bot, mostly using a dedicated Robot Framework listener library.
This initial preview provides support for local parallel task execution, but the concept is designed to support also remote executors, like parameterized Nomad tasks, CI systems, Docker or even Robocloud API.
Requirements:
-
Docker with Docker Compose for Camunda
-
Python >= 3.8 for executing Robot Framework
$ python --version Python 3.8.8
-
NodeJS >= 12 for executing the external task client
$ node --version v12.21.0
Trying it out
While carrot-executor
itself can be installed from PyPI, trying out the concept requires setting up Camunda BPM Platform and having the example Robot Framework task suites.
The easiest way for all this is to clone or download the project repository and starting the preconfigured Camunda with Docker Compose:
$ git clone https://github.com/datakurre/carrot-executor
$ cd carrot-executor
$ docker-compose up
After everything is ready, there should be Camunda running at http://localhost:8080/camunda with username demo
and password demo
.
By default, our Camunda container has both theirs and ours demo processes deployed. Let's get rid of their demo processes:
- Open Camunda Tasklist: http://localhost:8080/camunda/app/tasklist/default/
- Choose Start process
- Choose Reset Camunda to clear state and
- Press Start
The started process could now be completed with the help of carrot-executor
. For that we need to create a new Python environment with our package:
$ python -m venv my-carrot-executor
$ source my-carrot-executor/bin/activate
$ pip install carrot-executor
The executor may now be started with parameterizing it to complete tasks from the process we started:
$ CAMUNDA_API_PATH=http://localhost:8080/engine-rest ROBOT_SUITE=$(pwd)/robot/reset.robot CAMUNDA_TOPIC="Delete all tasklist filters,Delete all deployments" carrot-executor
polling
✓ subscribed to topic Delete all tasklist filters
✓ subscribed to topic Delete all deployments
polling
✓ polled 2 tasks
polling
✓ polled 0 tasks
By default, the executor executes the task name matching with the subscribed topic name. This can be overridden with environment variable ROBOT_TASK
. Setting the variable empty, should execute full suite.
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
Hashes for carrot_executor-0.6.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6f8eb7060421a8e4382f8924a98a0d07f14adb0c166f370d4b10e4fbab3e4212 |
|
MD5 | 6da535d6d65bd7e009d69591bbfd5fa8 |
|
BLAKE2b-256 | 827e3d9697623ac881fdb8ba1d8df54280ceb1df7808c613821bfe51a4c18d4e |