Bird
Raised Fist0
Terraformcloud~10 mins

Plan and apply separation in pipelines in Terraform - Step-by-Step Execution

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Process Flow - Plan and apply separation in pipelines
Start Pipeline
Terraform Plan Stage
Review Plan Output
Approve
Terraform Apply
Deploy Infrastructure
End Pipeline
The pipeline first runs a plan to show changes, waits for approval, then applies changes to deploy infrastructure.
Execution Sample
Terraform
terraform plan -out=tfplan
# Review plan output
terraform apply tfplan
This code runs a plan to preview changes and then applies them if approved.
Process Table
StepActionInput/ConditionResultNext Step
1Run terraform planNo prior planPlan file 'tfplan' created showing changesReview plan output
2Review plan outputPlan file existsChanges understood, decision neededApprove or Reject
3Decision: Approve?User inputIf yes, proceed; if no, stopApply or Stop
4Run terraform applyApproved plan fileInfrastructure updated as plannedDeploy infrastructure
5Deploy infrastructureApply successfulInfrastructure live and configuredEnd pipeline
6Stop pipelineRejected planNo changes appliedEnd pipeline
💡 Pipeline ends after apply or stop based on approval decision
Status Tracker
VariableStartAfter PlanAfter ApprovalAfter ApplyFinal
plan_filenonetfplan createdtfplan approved or rejectedtfplan applied or discardednone or applied state
pipeline_statusstartedplanningwaiting approvalapplying or stoppedcompleted or stopped
Key Moments - 3 Insights
Why do we separate 'plan' and 'apply' stages in the pipeline?
Separating plan and apply lets us review changes before making them live, as shown in execution_table rows 2 and 3.
What happens if the plan is rejected during approval?
The pipeline stops without applying changes, as shown in execution_table row 6.
Why do we save the plan output to a file before applying?
Saving the plan ensures the exact reviewed changes are applied later, preventing unexpected updates (execution_table row 1 and 4).
Visual Quiz - 3 Questions
Test your understanding
Look at the execution table, what is the result of step 1?
AInfrastructure updated as planned
BPlan file 'tfplan' created showing changes
CNo changes applied
DUser input required
💡 Hint
Check the 'Result' column for step 1 in the execution_table
At which step does the pipeline wait for user approval?
AStep 3
BStep 2
CStep 4
DStep 6
💡 Hint
Look at the 'Action' and 'Next Step' columns around step 3 in the execution_table
If the plan is rejected, what is the pipeline status after step 6?
Aapplying
Bcompleted
Cstopped
Dplanning
💡 Hint
Refer to 'pipeline_status' in variable_tracker after step 6
Concept Snapshot
Terraform pipelines separate 'plan' and 'apply' stages.
Plan stage previews changes and saves to a file.
Approval is required before applying.
Apply stage uses the saved plan to update infrastructure.
This prevents unexpected changes and improves safety.
Full Transcript
In Terraform pipelines, we first run 'terraform plan' to see what changes will happen. This plan is saved to a file. Then, the pipeline waits for approval to make sure the changes are correct. If approved, 'terraform apply' uses the saved plan to update the infrastructure exactly as planned. If rejected, the pipeline stops and no changes are made. This separation helps avoid mistakes and keeps infrastructure safe.

Practice

(1/5)
1. What is the main benefit of separating terraform plan and terraform apply in pipelines?
easy
A. It speeds up the deployment by combining steps
B. It skips the need for state files
C. It automatically fixes errors during apply
D. It allows you to review changes before applying them

Solution

  1. Step 1: Understand the purpose of terraform plan

    This command shows what changes Terraform will make without applying them.
  2. Step 2: Understand the purpose of terraform apply

    This command applies the changes to the infrastructure based on the plan.
  3. Final Answer:

    It allows you to review changes before applying them -> Option D
  4. Quick Check:

    Plan shows changes first = B [OK]
Hint: Plan shows changes, apply makes them live [OK]
Common Mistakes:
  • Thinking plan applies changes
  • Believing apply skips state files
  • Assuming steps run faster combined
2. Which command correctly saves a Terraform plan to a file named myplan.tfplan?
easy
A. terraform apply -out=myplan.tfplan
B. terraform save myplan.tfplan
C. terraform plan -out=myplan.tfplan
D. terraform plan save myplan.tfplan

Solution

  1. Step 1: Identify the correct syntax for saving a plan

    The correct command uses terraform plan -out=filename to save the plan.
  2. Step 2: Check each option

    terraform plan -out=myplan.tfplan matches the correct syntax exactly.
  3. Final Answer:

    terraform plan -out=myplan.tfplan -> Option C
  4. Quick Check:

    Plan with -out saves file = C [OK]
Hint: Use 'plan -out=' to save plans, not apply [OK]
Common Mistakes:
  • Using apply instead of plan to save
  • Using incorrect command like 'save'
  • Missing the '-out=' flag
3. Given these commands run in order:
terraform plan -out=planfile
terraform apply planfile
What happens when you run terraform apply planfile?
medium
A. Terraform applies exactly the changes saved in planfile
B. Terraform ignores planfile and creates a new plan
C. Terraform applies changes but may differ from planfile
D. Terraform throws an error because planfile is not a valid command

Solution

  1. Step 1: Understand the role of the saved plan file

    The plan file contains the exact changes Terraform will apply.
  2. Step 2: Understand how terraform apply planfile works

    This command applies the saved plan exactly, without recalculating changes.
  3. Final Answer:

    Terraform applies exactly the changes saved in planfile -> Option A
  4. Quick Check:

    Apply saved plan = exact changes [OK]
Hint: Apply with plan file applies exact saved changes [OK]
Common Mistakes:
  • Thinking apply recalculates plan
  • Assuming apply ignores plan file
  • Believing apply with plan file causes errors
4. You run terraform apply myplan.tfplan but get an error saying the plan file is invalid. What is the most likely cause?
medium
A. You forgot to run terraform init before apply
B. The plan file was created with a different Terraform version
C. You used terraform plan without -out flag
D. The plan file is empty because no changes were detected

Solution

  1. Step 1: Identify compatibility issues with plan files

    Plan files are version-specific and may be invalid if Terraform versions differ.
  2. Step 2: Check other options

    Running init is required but usually causes different errors; missing -out means no plan file saved; empty plan files do not cause invalid file errors.
  3. Final Answer:

    The plan file was created with a different Terraform version -> Option B
  4. Quick Check:

    Version mismatch causes invalid plan file error [OK]
Hint: Check Terraform versions match when using saved plans [OK]
Common Mistakes:
  • Assuming missing init causes invalid plan file error
  • Thinking empty plan files cause invalid file errors
  • Confusing missing -out with invalid plan file
5. You want to implement a pipeline that separates planning and applying Terraform changes. Which sequence of commands ensures you can review the plan before applying exactly those changes?
hard
A. terraform plan -out=planfile && terraform apply planfile
B. terraform apply && terraform plan -out=planfile
C. terraform plan && terraform apply
D. terraform apply -out=planfile && terraform apply planfile

Solution

  1. Step 1: Identify correct order for plan and apply separation

    First, run terraform plan -out=planfile to save the plan and review it.
  2. Step 2: Apply the saved plan exactly

    Then, run terraform apply planfile to apply the reviewed changes exactly.
  3. Final Answer:

    terraform plan -out=planfile && terraform apply planfile -> Option A
  4. Quick Check:

    Plan with -out then apply saved plan = A [OK]
Hint: Plan with -out then apply saved plan file [OK]
Common Mistakes:
  • Applying before planning
  • Not saving plan with -out
  • Using apply -out which is invalid