v1.15.0-beta2
📦 terraformView on GitHub →
✨ 6 features🐛 13 fixes🔧 22 symbols
Summary
This beta release introduces Windows ARM64 builds, support for deprecation attributes on variables/outputs, and the new `convert` function. It also enhances configuration validation and fixes numerous bugs across CLI, backend operations, and testing.
Migration Steps
- If using `AWS_USE_FIPS_ENDPOINT` or `AWS_USE_DUALSTACK_ENDPOINT` environment variables for S3 backend, ensure they are set strictly to `"true"` or `"false"` instead of relying on any non-empty value being treated as true.
✨ New Features
- Produces builds for Windows ARM64.
- Introduced the ability to set a `deprecated` attribute on variable and output blocks to produce warnings.
- backend/s3 now supports authentication via `aws login`.
- The `validate` command now checks the `backend` block for type existence, required attributes, and backend validation logic.
- Introduced the `convert` function for precise inline type conversions.
- Terraform now supports variables and locals in module source and version attributes.
🐛 Bug Fixes
- File-level error diagnostics are now included in JUnit XML skipped test elements during testing.
- Fixed an issue where a refresh-only plan could result in a non-zero exit code with no changes.
- Fixed crash in `terraform show -json` when plan contains ephemeral resources with preconditions or postconditions.
- Fixed `terraform init -json` to properly format all backend configuration messages as JSON instead of plain text.
- The `state show` command will now explicitly fail and return code 1 when it fails to render the named resources state.
- Terraform raises an explicit error if a plan file intended for one workspace is applied against another workspace.
- Fixed `replace_triggered_by` to report an error when given an invalid attribute reference that does not exist in the target resource.
- Fixed nil pointer dereference crash during `terraform init` when the destination backend returns an error.
- Stacks now send progress events if the plan fails for better UI integration.
- Stacks component instances now correctly report no-op plan/apply, resolving a UI inconsistency with convergence destroy plans.
- backend/http now returns conflicting lock info from HTTP backend instead of the lock that failed to be taken.
- Fixed a bug that caused Terraform to be unable to identify when two states had different output values (affecting backend migrations).
- Terraform Cloud and registry discovery network requests are now more resilient to temporary network or service related errors.
Affected Symbols
backend/s3validate commandconvert functionmodule source attributemodule version attributeoutput blocksssh-based provisioner (file + remote-exec)terraform init loginit commanddevelopment overridemock blocksresource attributes/blockslist_start JSON logsinput variable validation for Stackscontainer value comparison to nullterraform show -jsonterraform init -jsonstate show commandapply commandreplace_triggered_bybackend/httpterraform cloud network requests