skills.vishalvoidskills/vishalvoid
Technical & DevelopmentIntermediate

run-acceptance-tests

Run acceptance tests for Terraform providers using Go's test runner

Developer Setup

Setup & Installation

bash
npx skills add https://github.com/hashicorp/agent-skills --skill run-acceptance-tests

Overview

What This Skill Does

Runs acceptance tests for Terraform providers using Go's test runner. Handles the `TestAcc` prefix convention, required environment variables like `TF_ACC`, and progressive debugging steps when tests fail. Also validates passing tests by flipping expected values to confirm they can actually catch regressions.

Application

When to use this Skill

Documentation

Show Skills.md file

An acceptance test is a Go test function with the prefix TestAcc.

To run a focussed acceptance test named TestAccFeatureHappyPath:

  1. Run go test -run=TestAccFeatureHappyPath with the following environment variables:

    • TF_ACC=1

    Default to non-verbose test output.

  2. The acceptance tests may require additional environment variables for specific providers. If the test output indicates missing environment variables, then suggest how to set up these environment variables securely.

To diagnose a failing acceptance test, use these options, in order. These options are cumulative: each option includes all the options above it.

  1. Run the test again. Use the -count=1 option to ensure that go test does not use a cached result.
  2. Offer verbose go test output. Use the -v option.
  3. Offer debug-level logging. Enable debug-level logging with the environment variable TF_LOG=debug.
  4. Offer to persist the acceptance test's Terraform workspace. Enable persistance with the environment variable TF_ACC_WORKING_DIR_PERSIST=1.

A passing acceptance test may be a false negative. To "flip" a passing

Lines 1 - 25 of 32

Recommendations

Explore other random skills

All skillsMy patterns