Build taskcluster taskgraphs
Project description
Taskgraph
Taskgraph is a Python library to generate graphs of tasks for the Taskcluster CI service. It is the recommended approach for configuring tasks once your project outgrows a single .taskcluster.yml file and is what powers the over 30,000 tasks and counting that make up Firefox’s CI.
For more information and usage instructions, see the docs.
How It Works
Taskgraph leverages the fact that Taskcluster is a generic task execution platform. This means that tasks can be scheduled via its comprehensive API, and aren’t limited to being triggered in response to supported events.
Taskgraph leverages this execution platform to allow CI systems to scale to any size or complexity.
A decision task is created via Taskcluster’s normal .taskcluster.yml file. This task invokes taskgraph.
Taskgraph evaluates a series of yaml based task definitions (similar to those other CI offerings provide).
Taskgraph applies transforms on top of these task definitions. Transforms are Python functions that can programmatically alter or even clone a task definition.
Taskgraph applies some optional optimization logic to remove unnecessary tasks.
Taskgraph submits the resulting task graph to Taskcluster via its API.
Taskgraph’s combination of declarative task configuration combined with programmatic alteration are what allow it to support CI systems of any scale. Taskgraph is the library that powers the 30,000+ tasks making up Firefox’s CI.
Installation
Taskgraph supports Python 3.8 and up, and can be installed from Pypi:
pip install taskcluster-taskgraph
Alternatively, the repo can be cloned and installed directly:
git clone https://github.com/taskcluster/taskgraph
cd taskgraph
python setup.py install
In both cases, it’s recommended to use a Python virtual environment.
Get Involved
If you’d like to get involved, please see our contributing docs!
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
File details
Details for the file taskcluster_taskgraph-12.0.0.tar.gz
.
File metadata
- Download URL: taskcluster_taskgraph-12.0.0.tar.gz
- Upload date:
- Size: 375.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 96a6b04bb349621664d15bbb5856018175ce85999d6e0293374603f804c7234b |
|
MD5 | c0f3984cc4e7f3a5f46608918108e6b2 |
|
BLAKE2b-256 | c47329a26874c065ed2f6e5142cedd6e258efd67729c6c15f7e6f180ae6b8db3 |
File details
Details for the file taskcluster_taskgraph-12.0.0-py3-none-any.whl
.
File metadata
- Download URL: taskcluster_taskgraph-12.0.0-py3-none-any.whl
- Upload date:
- Size: 193.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7554e8709552918a66f03029134aa99a5c9414a839962d84c00e84ee848ab97e |
|
MD5 | 10c4e8ef64c1cbeea047b5fcfa65ead3 |
|
BLAKE2b-256 | a45f02c48a4890f63def2b746b94a5f0f602478bb84994c3223f6be24357b18f |