Automate Common Workflows
Atmos Workflows combine multiple commands into executable units of work, ideal for automating common tasks and orchestrating “cold starts,” where you bring an environment up from scratch.
Workflows can call other workflows and be combined with Custom Commands. Usually, we use workflows to provision some combinations of Terraform components.
Defining workflows is entirely optional; use them if they are helpful for your project.
Step 0: Configure Your Project to Support Workflows
To define workflows, update your atmos.yaml to tell it where to find your workflows.
Add the following workflows section and configure the base path to the workflows:
workflows:
  # Can also be set using 'ATMOS_WORKFLOWS_BASE_PATH' ENV var, or '--workflows-dir' command-line arguments
  # Supports both absolute and relative paths
  base_path: "stacks/workflows"
Step 0: Create an Atmos Workflow
Now, let's create a workflow in the stacks/workflows directory.
   │   # Centralized stacks configuration
   └── stacks/
       └── workflows/
           └── weather.yaml
Add the following Atmos workflows to the stacks/workflows/weather.yaml file:
name: Workflows for Weather Station
description: Atmos workflows for managing Weather Station
workflows:
  plan-all:
    description: |
      Run 'terraform plan' on all 'station' components in all stacks
    steps:
      - command: terraform plan station -s dev
      - command: terraform plan station -s staging
      - command: terraform plan station -s prod
  apply-all:
    description: |
      Run 'terraform apply' on all 'station' components in all stacks
    steps:
      - command: terraform apply station -auto-approve -s dev
      - command: terraform apply station -auto-approve -s staging
      - command: terraform apply station -auto-approve -s prod
Step 0: Run the Atmos Workflow
Run the following Atmos commands to execute the workflows:
# Execute the workflow `plan-all-vpc-flow-logs` from the workflow manifest `weather.yaml`
atmos workflow plan-all -f weather
# Execute the workflow `apply-all-components` from the workflow manifest `weather.yaml`
atmos workflow apply-all -f weather
The atmos workflow CLI command supports the --dry-run flag. If passed, the command will just print information about
the executed workflow steps without executing them. For example:
Refer to atmos workflow for more information on the atmos workflow CLI command
Want to go deeper on this topic?
Workflows can do a lot more than we're showing here. Workflows support templates, and can call other workflows. Learn More