Handling .tfvarsΒ»
For some of our Terraform users, the most convenient solution to configure a stack is to specify its input values in a variable definitions file that is then passed to Terraform executions in plan and apply phases.
Spacelift supports this approach but does not provide a separate mechanism, depending instead on a combination of Terraform's built-in mechanisms and Spacelift-provided primitives like:
Using environment variablesΒ»
In Terraform, special environment variables can be used to pass extra flags to executed commands like plan or apply. These are the more generic TF_CLI_ARGS
and TF_CLI_ARGS_name
that only affect a specific command. In Spacelift, environment variables can be defined directly on stacks and modules, as well as on contexts attached to those. As an example, let's declare the following environment variable:
In our particular case we don't have this file checked in, so the run will fail:
But we can supply this file dynamically using mounted files functionality.
Using mounted filesΒ»
If the variable definitions file is not part of the repo, we can inject it dynamically. The above example can be fixed by supplying the variables file at the requested path:
Note that there are "magical" names you can give to your variable definitions files that always get autoloaded, without the need to supply extra CLI arguments. According to the documentation, Terraform automatically loads a number of variable definitions files if they are present:
- Files named exactly
terraform.tfvars
orterraform.tfvars.json
. - Any files with names ending in
.auto.tfvars
or.auto.tfvars.json
.
The above can be used in conjunction with another Spacelift building block, before_init
hooks.
Using before_init
hooksΒ»
If you need to use different variable definitions files for different projects, would like to have them checked into the repo, but would also want to avoid supplying extra CLI arguments, you could just dynamically move files - whether as a move, copy or a symlink to one of the autoloaded locations. This should happen in one of the before_init
steps. Example: