🌴Branching

How to asset conditionality and contingent Tasks in Orchestra

When building your data pipelines, you may want to run a different set of tasks depending on what the result of an upstream task is.

For example, if a specific task in a pipeline fails, you may want to run a set of tasks that is different to the set of tasks you'd want to run if the task succeeded.

This is called Branching, and is similar to the idea of the BranchPythonOperator in Airflow.

Branching in Orchestra

By default, a node in Orchestra will run if the Tasks it depends on all end in one of a succeeded or warning state.

You can change this setting by selecting the branching icon here:

In this example, the green tick in a circle shows that the top Fivetran node will only run if all Tasks in the preceeding Task Group end in a succeeded state.

The node below it will only run if all Tasks in the preceding Task Group end in a failed state. This is signified by the red cross.

In the .yml, this is signified by the below condition:

Editing the .yml configuration directly will allow for more granular control over the branching condition.

Differences with the Airflow BranchPythonOperator

The BranchPythonOperator in Airflow is essentially a separate task that takes any callable. The Callable returns the name of the path or DAG to follow, so is extremely flexible.

In Orchestra, we do not allow you to construct a custom callable as a standalone task. Rather, any conditionality should be determined by the status of the previous Task or Tasks. Where custom logic is required, the Task itself should be forced to fail so Orchestra's branching capability can make use of the outputted status.

Last updated