This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
dagger/docs/faq/1232-chain-actions.md
m0un10 071d882d08 docs: fixed misleading example code
Signed-off-by: m0un10 <7553951+m0un10@users.noreply.github.com>
2022-04-19 21:29:38 +10:00

1.4 KiB

slug displayed_sidebar
/1232/chain-actions 0.2

How can I chain actions together ?

Dependencies are materialized at runtime, when your Cue files are parsed and the corresponding DAG gets generated:

// Prerequisite action that runs when `test` is being called
_dockerCLI: alpine.#Build & {
    packages: bash: _
}

// Main action
foo: bash.#Run & {
    input: _dockerCLI.output // <== CHAINING of action happening here
    script: contents: #"""
        echo "hello"
        """#
}

On above example, _dockerCLI gets executed first, as the corresponding DAG shows that it is required for the action foo to be processed.

This is the input-output model: foo's input is _dockerCLI's output.

We currently do not support explicit dependencies at the moment (one of our top priority). But, if you need one, here is how you can hack your way around it:

foo: bash.#Run & {
    input: _dockerCLI.output
    script: contents: #"""
        echo "hello"
        """#
}

// Main action
bar: bash.#Run & {
    input: _dockerCLI.output
    script: contents: #"""
        echo "hello"
        """#
    env: HACK: "\(foo.success)" // <== HACK: CHAINING of action happening here
}

foo and bar are similar actions. If you do not want to rely on the input-output model but still want to force a dependency between them. The easiest way is to create an environment variable that relies on the other action's success