Skip to content

Latest commit

 

History

History
388 lines (250 loc) · 8.28 KB

task.md

File metadata and controls

388 lines (250 loc) · 8.28 KB

Task Schema

Current Version

v1.0.0

Task

Property Type Required Default Value
steps step[] Required N/A
stepTimeout int Optional 600
secrets secret[] Optional N/A
networks network[] Optional N/A
env string[] Optional N/A
workingDirectory string Optional $HOME
version string Optional Yes

steps

An array of step objects.

  • Required
  • Type: step[]

stepTimeout

A step's maximum execution time in seconds. This property defaults all steps' timeout properties. A step can override this property via timeout.

  • Optional
  • Type: int

secrets

An array of secret objects.

  • Optional
  • Type: secret[]

networks

An array of network objects.

  • Optional
  • Type: network[]

env

If specified on a task, these environment variables are applied to every step in the format of VARIABLE=value. If specified on a step, it will override any environment variables inherited from the task. In other words, env is always scoped to a step.

  • Optional
  • Type: string[]

workingDirectory

Specifies the working directory of the container during runtime. If specified on a task, it defaults all of the steps' workingDirectory properties. If specified on a step, it will override the property provided by the task.

  • Optional
  • Type: string

version

The version of the task. If unspecified, defaults to the latest version.

  • Optional
  • Type: string

step

An object with the following properties:

Property Type Required Default Value
id string Optional acb_step_%d, where %d is the 0-based index of the step top-down in the yaml
cmd string Optional N/A
build string Optional N/A
workingDirectory string Optional $HOME
entryPoint string Optional N/A
user string Optional N/A
network string Optional N/A
isolation string Optional default
push string[] Optional N/A
env string[] Optional N/A
expose string[] Optional N/A
ports string[] Optional N/A
when string[] Optional N/A
timeout int Optional 600
startDelay int Optional 0
retryDelay int Optional 0
retries int Optional 0
repeat int Optional 0
keep bool Optional false
detach bool Optional false
privileged bool Optional false
ignoreErrors bool Optional false
disableWorkingDirectoryOverride bool Optional false
pull bool Optional false
  • A step must define either a cmd, build, or a push property. It may not define more than one of the aforementioned properties.

id

The unique identifier for the step. Used as the name of the running container. Can be referenced across containers using this identifier as the tcp host and used in when.

  • Optional
  • Type: string
  • Cannot contain spaces.

cmd

Defines which container to run along with any additional command line arguments.

Example:

cmd: bash echo "hello world"

This runs a container called bash and tells it to run the echo command with "Hello World" as a parameter.

  • Optional
  • Type: string

build

Allows building containers.

Example:

build: -f Dockerfile -t acr-builder:v1 https://github.com/Azure/acr-builder.git
  • Optional
  • Type: string

entryPoint

Sets the entry point of a container.

  • Optional
  • Type: string

user

Sets the username or UID of a container.

  • Optional
  • Type: string

isolation

Sets the isolation level of a container.

  • Optional
  • Type: string

push

Pushes the specified images to a container registry.

Example:

push: ["example.azurecr.io/acb:v1"]
  • Optional
  • Type: string[]

env

Sets environment variables for the container during execution.

Example:

env: ["K1=V1", "K2=V2"]
  • Optional
  • Type: string[]

expose

Exposes port(s) from the container.

  • Optional
  • Type: string[]

ports

Publishes port(s) from the container to the host.

  • Optional
  • Type: string[]

when

Describes when the step should get executed relative to other steps. If unspecified, steps will be ran sequentially.

If when: ["-"] is specified, the container will immediately begin execution without any dependency on parent steps' execution.

Examples:

# build is ran, followed by cmd sequentially.
steps:
  - build: -f Dockerfile . -t example
  - cmd: example
# step 1 and 2 are both executed simultaneously.
steps:
  - id: step_1
    cmd: bash echo "1"

  - id: step_2
    cmd: bash echo "2"
    when: ["-"]
# step 1 and 2 are both executed simultaneously. Step 3 is executed after step 1 is completed.
steps:
  - id: step_1
    cmd: bash echo "1"

  - id: step_2
    cmd: bash echo "2"
    when: ["-"]

  - id: step_3
    cmd: bash echo "3"
    when: ["step_1"]
  • Optional
  • Type: string[]

timeout

The maximum execution time of a step in seconds.

  • Optional
  • Type: int

startDelay

Defines the number of seconds to wait before executing the container.

  • Optional
  • Type: int

retries

The number of retries to attempt if a container fails its execution. A retry is only attempted if a container's exit code is non-zero.

  • Optional
  • Type: int

retryDelay

The delay in seconds between retries.

  • Optional
  • Type: int

repeat

The number of times to repeat the execution of a container.

  • Optional
  • Type: int

keep

Determines whether or not the container should be kept (all containers are removed by default) after it has been executed.

  • Optional
  • Type: bool

detach

Runs the container as a background process to avoid blocking.

  • Optional
  • Type: bool

privileged

Runs the container in privileged mode.

  • Optional
  • Type: bool

ignoreErrors

Ignores any errors during container execution and always marks the step as successful.

  • Optional
  • Type: bool

disableWorkingDirectoryOverride

Disables all workingDirectory override functionality. Use this in combination with workingDirectory to have complete control over the container's working directory.

pull

Forces a pull of the container before executing it to prevent any caching behavior.

  • Optional
  • Type: bool

secret

An object with the following properties:

Property Type Required Default Value
id string Required N/A
keyvault string Optional N/A
clientID string Optional N/A

keyvault

The key vault URL.

  • Optional
  • Type: string

clientID

The MSI user assigned identity client ID.

  • Optional
  • Type: string

network

An object with the following properties:

Property Type Required Default Value
name string Required N/A
driver string Optional N/A
ipv6 bool Optional false
skipCreation bool Optional false
isDefault bool Optional false

name

The name of the network.

  • Required
  • Type: string

driver

The driver to manage the network.

  • Default: bridge
  • Optional
  • Type: string

ipv6

Enables ipv6 networking.

  • Optional
  • Type: bool

skipCreation

Skips creation of the network.

  • Optional
  • Type: bool

isDefault

Specifies whether or not the network is a default one provided by Azure Container Registry.

  • Optional
  • Type: bool