Bird
Raised Fist0
Terraformcloud~5 mins

Null values handling in Terraform - Commands & Configuration

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
Introduction
Sometimes you want to leave a setting empty or optional in your infrastructure code. Terraform lets you use null values to skip or ignore those settings safely without errors.
When you want to create a resource but leave some optional fields empty.
When you want to conditionally include a value only if it exists.
When you want to avoid errors from missing or empty inputs in your configuration.
When you want to write reusable modules that accept optional parameters.
When you want to override a default value with no value at all.
Config File - main.tf
main.tf
variable "instance_name" {
  type    = string
  default = null
}

resource "aws_instance" "example" {
  ami           = "ami-0c55b159cbfafe1f0"
  instance_type = "t2.micro"

  tags = {
    Name = var.instance_name != null ? var.instance_name : "default-instance"
  }
}

This Terraform file defines a variable instance_name that can be null. The AWS instance resource uses this variable for its tag Name. If instance_name is null, it uses the default name default-instance. This shows how to handle null values safely.

Commands
This command initializes the Terraform working directory. It downloads necessary provider plugins and prepares the environment.
Terminal
terraform init
Expected OutputExpected
Initializing the backend... Initializing provider plugins... - Finding latest version of hashicorp/aws... - Installing hashicorp/aws v4.0.0... - Installed hashicorp/aws v4.0.0 (signed by HashiCorp) Terraform has been successfully initialized!
This command shows what Terraform will do before applying changes. It helps verify that null values are handled correctly and the resource will be created with the right tags.
Terminal
terraform plan
Expected OutputExpected
An execution plan has been generated and is shown below. Resource actions are indicated with the following symbols: + create Terraform will perform the following actions: # aws_instance.example will be created + resource "aws_instance" "example" { + ami = "ami-0c55b159cbfafe1f0" + arn = (known after apply) + id = (known after apply) + instance_type = "t2.micro" + tags = { + "Name" = "default-instance" } } Plan: 1 to add, 0 to change, 0 to destroy. ───────────────────────────────────────────────────────────────────────────── Note: You didn't specify an "-out" parameter to save this plan, so Terraform can't guarantee that exactly these actions will be performed if "terraform apply" is subsequently run.
This command applies the planned changes and creates the AWS instance. The -auto-approve flag skips manual confirmation for faster execution.
Terminal
terraform apply -auto-approve
Expected OutputExpected
aws_instance.example: Creating... aws_instance.example: Still creating... [10s elapsed] aws_instance.example: Creation complete after 15s [id=i-0abcd1234efgh5678] Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
-auto-approve - Automatically approve the apply step without prompting
This command shows any outputs defined in the Terraform configuration. Here it confirms the resource creation and values.
Terminal
terraform output
Expected OutputExpected
Key Concept

If you remember nothing else from this pattern, remember: use null to safely skip optional values and avoid errors in Terraform configurations.

Common Mistakes
Setting an empty string "" instead of null for optional variables.
Terraform treats empty strings as actual values, which may cause unexpected behavior or resource changes.
Use null to represent no value and handle it explicitly in your resource definitions.
Not checking for null before using a variable in resource attributes.
This can cause Terraform to fail or apply incorrect values if the variable is null.
Use conditional expressions like var.name != null ? var.name : "default" to handle null safely.
Summary
Define variables with default = null to make them optional.
Use conditional expressions to check for null before using variables.
Run terraform init, plan, and apply to create resources with optional values handled safely.

Practice

(1/5)
1. What does a null value represent in Terraform configuration?
easy
A. A zero number
B. An empty string
C. An absence of a value or an intentional skip
D. A syntax error

Solution

  1. Step 1: Understand the meaning of null in Terraform

    In Terraform, null means no value is set or the value is intentionally skipped.
  2. Step 2: Differentiate null from other values

    Zero and empty string are actual values, while null means absence of any value.
  3. Final Answer:

    An absence of a value or an intentional skip -> Option C
  4. Quick Check:

    Null means no value set = B [OK]
Hint: Null means no value, not zero or empty string [OK]
Common Mistakes:
  • Confusing null with zero
  • Thinking null is an empty string
  • Assuming null causes syntax error
2. Which of the following is the correct way to assign a null value to a variable in Terraform?
easy
A. variable "example" { default = null }
B. variable "example" { default = "null" }
C. variable "example" { default = '' }
D. variable "example" { default = 0 }

Solution

  1. Step 1: Review Terraform syntax for null assignment

    In Terraform, null is a keyword without quotes to represent no value.
  2. Step 2: Identify incorrect options

    variable "example" { default = "null" } uses quotes making it a string, C is empty string, D is zero number.
  3. Final Answer:

    variable "example" { default = null } -> Option A
  4. Quick Check:

    Null keyword without quotes = A [OK]
Hint: Use null without quotes to assign null value [OK]
Common Mistakes:
  • Using "null" as a string instead of null keyword
  • Confusing empty string with null
  • Assigning zero instead of null
3. Given this Terraform expression:
var.input != null ? var.input : "default_value"

What will be the result if var.input is null?
medium
A. null
B. "default_value"
C. var.input
D. Error: invalid expression

Solution

  1. Step 1: Understand the conditional expression

    The expression checks if var.input is not null; if true, returns var.input, else returns "default_value".
  2. Step 2: Apply the condition when var.input is null

    Since var.input is null, the condition is false, so the expression returns "default_value".
  3. Final Answer:

    "default_value" -> Option B
  4. Quick Check:

    Null input returns default = A [OK]
Hint: If input is null, conditional returns default value [OK]
Common Mistakes:
  • Assuming null is returned instead of default
  • Thinking expression causes error
  • Confusing var.input with string "var.input"
4. Identify the error in this Terraform snippet handling null values:
output "example" {
  value = var.optional_value != null ? var.optional_value : null
}
medium
A. The output block must not use variables
B. The conditional operator syntax is incorrect
C. Using null as fallback causes output to be invalid
D. No error; this is valid Terraform code

Solution

  1. Step 1: Analyze the conditional expression

    The expression returns var.optional_value if not null, else returns null.
  2. Step 2: Understand output block behavior with null

    Terraform outputs can have null values; it is valid and will display as null when using terraform output.
  3. Final Answer:

    No error; this is valid Terraform code -> Option D
  4. Quick Check:

    Outputs can accept null = D [OK]
Hint: Outputs can safely return null values [OK]
Common Mistakes:
  • Believing outputs cannot accept null values
  • Misreading the conditional syntax as incorrect
  • Thinking variables cannot be used in output blocks
5. You want to create a resource only if a variable enable_feature is not null and true. Which Terraform expression correctly handles null values to achieve this?
hard
A. count = var.enable_feature != null && var.enable_feature == true ? 1 : 0
B. count = var.enable_feature != false ? 1 : 0
C. count = var.enable_feature ? 1 : 0
D. count = var.enable_feature != null ? 1 : 0

Solution

  1. Step 1: Understand the requirement

    The resource should be created only if enable_feature is not null and true.
  2. Step 2: Evaluate each option

    count = var.enable_feature != null ? 1 : 0: count = var.enable_feature != null ? 1 : 0 creates the resource if not null, regardless of true or false.
    count = var.enable_feature != false ? 1 : 0: count = var.enable_feature != false ? 1 : 0 creates for true and null (null != false).
    count = var.enable_feature ? 1 : 0: count = var.enable_feature ? 1 : 0 errors if null (invalid boolean condition).
    count = var.enable_feature != null && var.enable_feature == true ? 1 : 0: count = var.enable_feature != null && var.enable_feature == true ? 1 : 0 checks both conditions explicitly.
  3. Final Answer:

    count = var.enable_feature != null && var.enable_feature == true ? 1 : 0 -> Option A
  4. Quick Check:

    Check null and true explicitly = D [OK]
Hint: Check both not null and true explicitly for safe resource creation [OK]
Common Mistakes:
  • Ignoring null check causing errors
  • Assuming null is false automatically
  • Using only one condition without null check