Bird
Raised Fist0
Terraformcloud~5 mins

Object type definition in Terraform - Cheat Sheet & Quick Revision

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
Recall & Review
beginner
What is an object type in Terraform?
An object type in Terraform is a way to group multiple named values with specific types into a single complex value, like a small container with labeled slots.
Click to reveal answer
beginner
How do you define an object type with two attributes: name as string and age as number?
You define it like this:
object({ name = string, age = number })
Click to reveal answer
intermediate
Why use object types instead of maps in Terraform?
Object types have fixed attribute names and types, which helps catch errors early and makes your code clearer, unlike maps which allow any keys and values.
Click to reveal answer
intermediate
Can object types in Terraform have nested objects?
Yes, object types can contain other object types as attributes, allowing you to build complex structured data.
Click to reveal answer
beginner
What happens if you try to assign a wrong type to an object attribute in Terraform?
Terraform will show an error during plan or apply, telling you the type does not match, helping you fix mistakes before deployment.
Click to reveal answer
Which Terraform type defines a fixed set of named attributes with specific types?
Aobject
Blist
Cmap
Dstring
How do you define an object type with attributes 'id' as number and 'enabled' as bool?
Amap(string)
Blist(number, bool)
Ctuple(number, bool)
Dobject({ id = number, enabled = bool })
What is a benefit of using object types over maps in Terraform?
AThey allow any keys and values
BThey enforce fixed attribute names and types
CThey are faster to write
DThey do not support nested data
Can an object type attribute itself be another object type?
AOnly if declared as a map
BNo
CYes
DOnly in Terraform 0.11 or earlier
What happens if you assign a string to an object attribute defined as number?
ATerraform throws a type error
BTerraform converts it automatically
CTerraform ignores the attribute
DTerraform treats it as null
Explain what an object type is in Terraform and why it is useful.
Think of an object type as a labeled box with specific slots for values.
You got /4 concepts.
    Describe how you would define a nested object type in Terraform with an example.
    Use object({ ... }) inside another object({ ... })
    You got /3 concepts.

      Practice

      (1/5)
      1. What is the main purpose of defining an object type in Terraform?
      easy
      A. To group related values with specific names and types
      B. To create a list of strings
      C. To define a single integer value
      D. To write shell scripts inside Terraform

      Solution

      1. Step 1: Understand object type concept

        An object type groups multiple related values, each with a name and a type.
      2. Step 2: Compare with other types

        Unlike lists or single values, objects organize structured data clearly.
      3. Final Answer:

        To group related values with specific names and types -> Option A
      4. Quick Check:

        Object type = group related named values [OK]
      Hint: Objects group named values, not single or list values [OK]
      Common Mistakes:
      • Confusing object with list or map types
      • Thinking object holds only one value
      • Assuming object is for scripting
      2. Which of the following is the correct syntax to define an object type with a string field name and a number field age in Terraform?
      easy
      A. object({ name string, age number })
      B. object({ name: string, age: number })
      C. object({ "name" = string, "age" = number })
      D. object({ name = string, age = number })

      Solution

      1. Step 1: Recall object type syntax

        Terraform object types use curly braces with unquoted identifier keys and equal signs: object({ key = type, ... })
      2. Step 2: Check each option

        object({ name = string, age = number }) correctly uses unquoted keys and equal signs. Others use invalid syntax like colons, quoted keys for simple identifiers, or missing equals.
      3. Final Answer:

        object({ name = string, age = number }) -> Option D
      4. Quick Check:

        Object keys unquoted with = sign [OK]
      Hint: Object keys use unquoted identifiers with = type [OK]
      Common Mistakes:
      • Using colons instead of equal signs
      • Quoting keys in object type
      • Omitting commas or using wrong separators
      3. Given this variable definition in Terraform:
      variable "person" {
        type = object({
          name = string
          age  = number
        })
        default = {
          name = "Alice"
          age  = 30
        }
      }
      What will be the value of var.person.age?
      medium
      A. "30"
      B. 30
      C. null
      D. Error: type mismatch

      Solution

      1. Step 1: Analyze variable type and default

        The variable is an object with fields name (string) and age (number). Default sets age to 30 (number).
      2. Step 2: Determine var.person.age value

        Accessing var.person.age returns the number 30 as defined.
      3. Final Answer:

        30 -> Option B
      4. Quick Check:

        Object field age = 30 number [OK]
      Hint: Object fields keep their defined types and values [OK]
      Common Mistakes:
      • Thinking number becomes string automatically
      • Expecting null if not accessed
      • Confusing default with no value
      4. Identify the error in this Terraform object type definition:
      variable "config" {
        type = object({
          "enabled" = bool
          "count" = int
        })
        default = {
          enabled = true
          count = 3
        }
      }
      medium
      A. The type int is invalid; should be number
      B. Keys in object type should not be quoted
      C. Default values must be strings
      D. Boolean values cannot be used in objects

      Solution

      1. Step 1: Check type names in object

        Terraform uses number for numeric types, not int.
      2. Step 2: Validate other syntax

        Quoted keys are allowed, default values match types, booleans are valid.
      3. Final Answer:

        The type int is invalid; should be number -> Option A
      4. Quick Check:

        Use number, not int, for numeric types [OK]
      Hint: Use 'number' type, not 'int' in Terraform objects [OK]
      Common Mistakes:
      • Using 'int' instead of 'number'
      • Thinking keys cannot be quoted
      • Believing booleans are invalid in objects
      5. You want to define a Terraform variable that accepts an object with a name (string), tags (map of strings), and an optional count (number). Which is the correct way to define this object type?
      hard
      A. object({ name = string, tags = map(string), count = number })
      B. object({ "name" = string, "tags" = map(string), "count" = optional(number) })
      C. object({ name = string, tags = map(string), count = optional(number) })
      D. object({ name = string, tags = map(string), count = optional number })

      Solution

      1. Step 1: Recall optional attribute syntax

        Terraform uses optional(type) without quotes for optional fields inside object types.
      2. Step 2: Check key quoting rules

        Keys in object type definitions use unquoted identifiers for standard names; quoting simple keys is incorrect.
      3. Step 3: Evaluate options

        object({ name = string, tags = map(string), count = optional(number) }) correctly uses unquoted keys and optional(number) syntax. object({ "name" = string, "tags" = map(string), "count" = optional(number) }) quotes keys incorrectly. object({ name = string, tags = map(string), count = number }) misses optional. object({ name = string, tags = map(string), count = optional number }) has invalid syntax.
      4. Final Answer:

        object({ name = string, tags = map(string), count = optional(number) }) -> Option C
      5. Quick Check:

        Optional fields use optional(type) with unquoted keys [OK]
      Hint: Use optional(type) without quotes and unquoted keys [OK]
      Common Mistakes:
      • Quoting keys in object type
      • Missing optional() for optional fields
      • Using invalid syntax like 'optional number'