terraform-azurerm-set-diff-analyzer
Analyze Terraform plan JSON output for AzureRM Provider, distinguishing false positive differences (e.g., order changes in Set type attributes) to accurately identify configuration changes.
npx skills add github/awesome-copilot --skill terraform-azurerm-set-diff-analyzerBefore / After Comparison
1 组Terraform plan outputs often show false positive differences, such as changes in the order of Set-type attributes, making it difficult to accurately determine real configuration changes. This increases review burden and can lead to misjudgment of risks.
Analyze Terraform plan JSON output to intelligently distinguish false positive differences. Ensure accurate identification of AzureRM configuration changes, simplify the review process, and improve deployment security.
Terraform AzureRM Set Diff Analyzer
A skill to identify "false-positive diffs" in Terraform plans caused by AzureRM Provider's Set-type attributes and distinguish them from actual changes.
When to Use
terraform planshows many changes, but you only added/removed a single element- Application Gateway, Load Balancer, NSG, etc. show "all elements changed"
- You want to automatically filter false-positive diffs in CI/CD
Background
Terraform's Set type compares by position rather than by key, so when adding or removing elements, all elements appear as "changed". This is a general Terraform issue, but it's particularly noticeable with AzureRM resources that heavily use Set-type attributes like Application Gateway, Load Balancer, and NSG.
These "false-positive diffs" don't actually affect the resources, but they make reviewing terraform plan output difficult.
Prerequisites
- Python 3.8+
If Python is unavailable, install via your package manager (e.g., apt install python3, brew install python3) or from python.org.
Basic Usage
# 1. Generate plan JSON output
terraform plan -out=plan.tfplan
terraform show -json plan.tfplan > plan.json
# 2. Analyze
python scripts/analyze_plan.py plan.json
Troubleshooting
python: command not found: Usepython3instead, or install PythonModuleNotFoundError: Script uses only standard library; ensure Python 3.8+
Detailed Documentation
- scripts/README.md - All options, output formats, exit codes, CI/CD examples
- references/azurerm_set_attributes.md - Supported resources and attributes
User Reviews (0)
Write a Review
No reviews yet
Statistics
User Rating
Rate this Skill