Agent-skills run-acceptance-tests
Guide for running acceptance tests for a Terraform provider. Use this when asked to run an acceptance test or to run a test with the prefix `TestAcc`.
install
source · Clone the upstream repo
git clone https://github.com/hashicorp/agent-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/hashicorp/agent-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/terraform/provider-development/skills/run-acceptance-tests" ~/.claude/skills/hashicorp-agent-skills-run-acceptance-tests && rm -rf "$T"
manifest:
terraform/provider-development/skills/run-acceptance-tests/SKILL.mdsource content
An acceptance test is a Go test function with the prefix
TestAcc.
To run a focussed acceptance test named
TestAccFeatureHappyPath:
-
Run
with the following environment variables:go test -run=TestAccFeatureHappyPathTF_ACC=1
Default to non-verbose test output.
-
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.
- Run the test again. Use the
option to ensure that-count=1
does not use a cached result.go test - Offer verbose
output. Use thego test
option.-v - Offer debug-level logging. Enable debug-level logging with the environment
variable
.TF_LOG=debug - 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 acceptance test named
TestAccFeatureHappyPath:
- Edit the value of one of the TestCheckFuncs in one of the TestSteps in the TestCase.
- Run the acceptance test. Expect the test to fail.
- If the test fails, then undo the edit and report a successful flip. Else, keep the edit and report an unsuccessful flip.