YAML syntax

This article will explain some rules that YAML has in place, and because YAML is pretty strict with formatting this will help to quickly overcome some common pitfalls with using YAML.


First off, spaces are used instead of tabs, as tabs are not universally supported. Wrongly indenting a line is a small mistake that is hard to spot and can lead to a failing build. For that reason, we recommend you to use 4 spaces while indenting lines.

YAML does not allow the use of tabs.

Example of two script steps with correct indentation.

- script:
    name: echo python information
    code: |
        echo "python version $(python --version) running"
        echo "pip version $(pip --version) running"
- script:
  name: deploy
  code: |
     ./scripts/deploy --target $ENVIRONMENT \
        --run-migrations \
        --api-key $API_KEY \
        --api-secret $API_SECRET


Mappings use a colon followed by a space : to mark each key/value pair.

box: google/golang

Example of a nested mapping: to setup the use of a private container.

    id: quay.io/knuth/golang
    username: $USERNAME
    password: $PASSWORD
    tag: beta
    registry: quay.io


Example of how we use a list to create a pipeline.

        - step
        - step
        - step


Strings can be unquoted, single and double-quoted. If you wrap text or numbers with quotes it will be forced as a string.


Comments can be added in YAML by prefixing them with a hash mark #:

box: nodesource/trusty
# Build definition

Further Reading