Skip to main content

Build taskcluster taskgraphs

Project description

Task Status Code Coverage Pypi Version Documentation Status License

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.

  1. A decision task is created via Taskcluster’s normal .taskcluster.yml file. This task invokes taskgraph.

  2. Taskgraph evaluates a series of yaml based task definitions (similar to those other CI offerings provide).

  3. Taskgraph applies transforms on top of these task definitions. Transforms are Python functions that can programmatically alter or even clone a task definition.

  4. Taskgraph applies some optional optimization logic to remove unnecessary tasks.

  5. 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
pip 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

taskcluster_taskgraph-19.1.0.tar.gz (555.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

taskcluster_taskgraph-19.1.0-py3-none-any.whl (206.6 kB view details)

Uploaded Python 3

File details

Details for the file taskcluster_taskgraph-19.1.0.tar.gz.

File metadata

  • Download URL: taskcluster_taskgraph-19.1.0.tar.gz
  • Upload date:
  • Size: 555.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for taskcluster_taskgraph-19.1.0.tar.gz
Algorithm Hash digest
SHA256 a99d08021afb4e9d7006619a9bccbdbf70a84e93f8b62dce66f1b4e2032f1c6f
MD5 97b2d4627be3c8bcd595f83a361c5526
BLAKE2b-256 3ef2969fffd43c7c35c1160018bd5f90fb09e3e14be8b67ee78959fbfac531a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for taskcluster_taskgraph-19.1.0.tar.gz:

Publisher: pypi-publish.yml on taskcluster/taskgraph

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file taskcluster_taskgraph-19.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for taskcluster_taskgraph-19.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 832f1151402bc05b72da1fdd9cd37b294819bee140e36073262ffc897b68dac3
MD5 891e531049ad4c0005c9c93a2ed366cc
BLAKE2b-256 85f50ada15b6b972c3a23b9c47211e3a97d10615326e507f005e35f6f7dbd757

See more details on using hashes here.

Provenance

The following attestation bundles were made for taskcluster_taskgraph-19.1.0-py3-none-any.whl:

Publisher: pypi-publish.yml on taskcluster/taskgraph

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page