Skip to content

Releases: hashicorp/terraform

v0.12.28

25 Jun 13:44

Choose a tag to compare

0.12.28 (June 25, 2020)

BUG FIXES:

  • build: build the 0.12 version of Terraform with Go 1.12.13, rather than 0.13 Terraform's 1.14.2 (#25386)

v0.12.27

24 Jun 20:22

Choose a tag to compare

0.12.27 (June 24, 2020)

BUG FIXES:

  • backend/remote: fix panic when there's a connection error to the remote backend (#25341)

v0.13.0-beta2

17 Jun 18:36

Choose a tag to compare

v0.13.0-beta2 Pre-release
Pre-release

0.13.0-beta2 (June 17, 2020)

NOTES:

  • backend/s3: Deprecated lock_table, skip_get_ec2_platforms, and skip_requesting_account_id arguments have been removed (#25134)
  • backend/s3: Credential ordering has changed from static, environment, shared credentials, EC2 metadata, default AWS Go SDK (shared configuration, web identity, ECS, EC2 Metadata) to static, environment, shared credentials, default AWS Go SDK (shared configuration, web identity, ECS, EC2 Metadata) (#25134)
  • backend/s3: The AWS_METADATA_TIMEOUT environment variable no longer has any effect as we now depend on the default AWS Go SDK EC2 Metadata client timeout of one second with two retries (#25134)
  • Removed unused targets from Makefile. If you were previously using make dev or make quickdev, replace that usage with go install (#25146)

ENHANCEMENTS:

  • backend/kubernetes: New kubernetes remote state storage backend (#19525)
  • backend/s3: Always enable shared configuration file support (no longer require AWS_SDK_LOAD_CONFIG environment variable) (#25134)
  • backend/s3: Automatically expand ~ prefix for home directories in shared_credentials_file argument (#25134)
  • backend/s3: Add assume_role_duration_seconds, assume_role_policy_arns, assume_role_tags, and assume_role_transitive_tag_keys arguments (#25134)
  • command/providers: Show providers in a tree of modules requiring them, along with a list of providers required by state (#25190)
  • provisioner/remote-exec: Return an error when the host field is empty (#24080)

BUG FIXES:

  • addrs: detect builtin "terraform" provider in legacy state (#25154)
  • backend/remote: do not panic if PrepareConfig or Configure receive null values (can occur when the user cancels the init command) (#25135)
  • backend/s3: Ensure configured profile is used (#25134)
  • backend/s3: Ensure configured STS endpoint is used during AssumeRole API calls (#25134)
  • backend/s3: Prefer AWS shared configuration over EC2 metadata credentials by default (#25134)
  • backend/s3: Prefer ECS credentials over EC2 metadata credentials by default (#25134)
  • backend/s3: Remove hardcoded AWS Provider messaging (#25134)
  • command/0.13upgrade: Fix 0.13upgrade usage help text to include options (#25127)
  • command/0.13upgrade: Do not add source for builtin provider (#25215)
  • command/apply: Fix bug which caused Terraform to silently exit on Windows when using absolute plan path (#25233)
  • command/init: Fix bug which caused the default local plugindir to be omitted as a provider source location (#25214)
  • command/format: Fix bug which caused some diagnostics to print empty source lines (#25156)
  • command/version: add -json flag for machine-parsable version output (#25252)
  • config: Function argument expansion with ... will no longer incorrectly return "Invalid expanding argument value" in situations where the expanding argument type isn't known yet. (#25216)
  • config: Fix crash in validation with non-ascii characters (#25144)
  • config: Don't panic if version constraint syntax isn't accepted by new version constraint parser (#25223)
  • config: Validate depends_on references in modules and outputs (#25261)
  • core: Fix crash with multiple nested modules (#25176)
  • core: Fix panic when importing with modules (#25208)
  • core: Allow targeting with expanded module addresses (#25206)
  • core: Allow referencing module instances (#25258)

v0.13.0-beta1

03 Jun 18:34

Choose a tag to compare

v0.13.0-beta1 Pre-release
Pre-release

0.13.0-beta1 (June 03, 2020)

NEW FEATURES:

  • count and for_each for modules: Similar to the arguments of the same name in resource and data blocks, these create multiple instances of a module from a single module block. (#24461)
  • depends_on for modules: Modules can now use the depends_on argument to ensure that all module resource changes will be applied after any changes to the depends_on targets have been applied. (#25005)
  • Automatic installation of third-party providers: Terraform now supports a decentralized namespace for providers, allowing for automatic installation of community providers from third-party namespaces in the public registry and from private registries. (More details will be added about this prior to release.)
  • Custom validation rules for input variables: A new validation block type inside variable blocks allows module authors to define validation rules at the public interface into a module, so that errors in the calling configuration can be reported in the caller's context rather than inside the implementation details of the module. (#25054)

BREAKING CHANGES:

  • As part of implementing a new decentralized namespace for providers, Terraform now requires an explicit source specification for any provider that is not in the "hashicorp" namespace in the main public registry. (More details will be added about this prior to release, including links to upgrade steps.) (#24477)
  • backend/oss: Changes to the TableStore schema now require a primary key named LockID of type String (#24149)
  • command/0.12upgrade: this command has been replaced with a deprecation notice directing users to install terraform v0.12 to run terraform 0.12upgrade. (#24403)
  • command/import: remove the deprecated -provider command line argument (#24090)
  • command/import: fixed a bug where the import command was not properly attaching the configured provider for a resource to be imported, making the -provider command line argument unnecessary. (#22862)
  • command/providers: the output of this command is now a flat list that does not display providers per module. (#24634)
  • config: Inside provisioner blocks that have when = destroy set, and inside any connection blocks that are used by such provisioner blocks, it is now an error to refer to any objects other than self, count, or each (#24083)
  • configs: At most one terraform.required_providers block is permitted per module (#24763)
  • The official MacOS builds of Terraform CLI are no longer compatible with Mac OS 10.10 Yosemite; Terraform now requires at least Mac OS 10.11 El Capitan. Terraform 0.13 is the last major release that will support 10.11 El Capitan, so if you are upgrading your OS we recommend upgrading to Mac OS 10.12 Sierra or later.
  • The official FreeBSD builds of Terraform CLI are no longer compatible with FreeBSD 10.x, which has reached end-of-life. Terraform now requires FreeBSD 11.2 or later.

NOTES:

  • The terraform plan and terraform apply command will now detect and report changes to root module outputs as able to be applied even if there are no resource changes in the plan. This will be an improvement in behavior for most users, since it will now be possible to change output blocks and use terraform apply to apply those changes, but it may require some changes to unusual situations where a root module output value was intentionally changing on every plan, which was not an intended usage pattern and is no longer supported.
  • Terraform CLI now supports TLS 1.3 and supports Ed25519 certificates when making outgoing connections to remote TLS servers. While both of these changes are backwards compatible in principle, certain legacy TLS server implementations can reportedly encounter problems when attempting to negotiate TLS 1.3. (These changes affects only requests made by Terraform CLI itself, such as to module registries or backends. Provider plugins have separate TLS implementations that will gain these features on a separate release schedule.)
  • On Unix systems where use-vc is set in resolv.conf, Terraform will now use TCP for DNS resolution. We don't expect this to cause any problem for most users, but if you find you are seeing DNS resolution failures after upgrading please verify that you can either reach your configured nameservers using TCP or that your resolver configuration does not include the use-vc directive.
  • backend/s3: Region validation now automatically supports the new af-south-1 (Africa (Cape Town)) region. For AWS operations to work in the new region, the region must be explicitly enabled as outlined in the AWS Documentation. When the region is not enabled, the Terraform S3 Backend will return errors during credential validation (e.g. error validating provider credentials: error calling sts:GetCallerIdentity: InvalidClientTokenId: The security token included in the request is invalid). (#24744)

ENHANCEMENTS:

  • config: templatefile function will now return a helpful error message if a given variable has an invalid name, rather than relying on a syntax error in the template parsing itself. (#24184)
  • config: The configuration language now uses Unicode 12.0 character tables for certain Unicode-version-sensitive operations on strings, such as the upper and lower functions. Those working with strings containing new characters introduced since Unicode 9.0 may see small differences in behavior as a result of these table updates.
  • cli: When installing providers from the Terraform Registry, Terraform will verify the trust signature for partner providers, and allow for self-signed community providers (#24617)
  • cli: Display detailed trust signature information when installing providers from the Terraform Registry, including a link to more documentation on different levels of signature (#24932)
  • cli: It is now possible to optionally specify explicitly which installation methods can be used for different providers, such as forcing a particular provider to be loaded from a particular directory on local disk instead of consulting its origin provider registry. (#24728)
  • cli: Add state replace-provider subcommand to allow changing the provider source for existing resources (#24523)
  • cli: The terraform plan and terraform apply commands now recognize changes to root module outputs as side-effects to be approved and applied. This means you can apply root module output changes using the normal plan and apply workflow. (#25047)
  • cli: The new terraform providers mirror subcommand can automatically construct or update a local filesystem mirror directory containing the providers required for the current configuration. (#25084)
  • config: The merge function now returns more precise type information, making it usable for values passed to for_each (#24032)
  • config: Add "sum" function, which takes a list or set of numbers and returns the sum of all elements (#24666)
  • config: added support for passing metadata from modules to providers using HCL (#22583)
  • core: Significant performance enhancements for graph operations, which will help with highly-connected graphs (#23811)
  • core: Data resources can now be evaluated during plan, allowing depends_on to work correctly, and allowing data sources to update immediately when their configuration changes. (#24904)
  • core: Data resource changes detected during planning will now always be reported in the plan output, to highlight a likely reason for effective configurationc changes elsewhere. Previously only data resources deferred to the apply phase would be shown. (#24904)
  • backend/azurerm: switching to use the Giovanni Storage SDK to communicate with Azure (#24669)
  • backend/remote: Now supports terraform state push -force. (#24696)
  • backend/remote: Can now accept -target options when creating a plan using remote operations, if supported by the target server. (Server-side support for this in Terraform Cloud and Terraform Enterprise will follow in forthcoming releases of each.) (#24834)
  • backend/s3: Support automatic region validation for af-south-1 (#24744)
  • backend/swift auth options match OpenStack provider auth ([#23510](https://github.com/hashicorp/terra...
Read more

v0.12.26

27 May 17:12

Choose a tag to compare

ENHANCEMENTS:

  • backend/remote: Can now accept -target options when creating a plan using remote operations, if supported by the target server. (Server-side support for this in Terraform Cloud and Terraform Enterprise will follow in forthcoming releases of each.) (#24834)
  • cli: A special new lifecycle mode for provider plugins where they are assumed to be controlled by an external process outside of Terraform. This is for automated provider plugin testing only, and is not an end-user feature. (#24674)

v0.12.25

13 May 16:57

Choose a tag to compare

NOTES:

  • backend/s3: Region validation now automatically supports the new af-south-1 (Africa (Cape Town)) region. For AWS operations to work in the new region, the region must be explicitly enabled as outlined in the AWS Documentation. When the region is not enabled, the Terraform S3 Backend will return errors during credential validation (e.g. error validating provider credentials: error calling sts:GetCallerIdentity: InvalidClientTokenId: The security token included in the request is invalid). (#24744)

ENHANCEMENTS:

  • backend/s3: Support automatic region validation for af-south-1 (#24744)
  • backend/remote: Add support for force push to remote backend (#24884)

BUG FIXES:

  • core: Destroy provisioners should not evaluate for_each expressions (#24163)
  • core: Fix races in GetVariableValue (#24599)

v0.12.24

19 Mar 15:24

Choose a tag to compare

NOTES:

  • cli: Windows executable signing.

Our Windows 32-bit and 64-bit executables for this version and up will be signed with a HashiCorp cert. Windows users will no longer see a warning about an "unknown publisher" when running our software.

BUG FIXES:

  • command/login: Fix bug when using terraform login on Windows (#24397)
  • registry: Fix panic when server is unreachable (#24411)

v0.12.23

05 Mar 21:21

Choose a tag to compare

v0.12.23

v0.12.22

05 Mar 20:32

Choose a tag to compare

ENHANCEMENTS:

  • registry: Add configurable retries for module and provider discovery requests to the remote registry (#24260)
  • registry: Add configurable request timeout for the remote registry client (#24259)

BUG FIXES:

  • cli: Fix terraform state mv to correctly set the resource each mode based on the target address (#24254)
  • cli: The terraform plan command (and the implied plan run by terraform apply with no arguments) will now print any warnings that were generated even if there are no changes to be made. (#24095)

v0.12.21

19 Feb 18:16

Choose a tag to compare

NEW FEATURES:

  • backend/cos: New backend "cos", supporting using Tencent Cloud Storage as a remote backend.
  • command/login: Enable "terraform login" and add support for UI-generated tokens (#23995)
  • command/logout: Add "terraform logout" command to remove local credentials (#24048)

ENHANCEMENTS:

  • command/workspace delete: release lock after workspace removal warning (#24085)
  • lang/funcs: add setsubtract function (#23424)

BUG FIXES:

  • command/state show: Fix an issue when a resource has a non-default provider configured (#24027)
  • backend/remote-state: Fix issues where lingering lock files remained when deleting non-empty workspaces (#24085)
  • command/import: Release lock if initialization error occurs on import (#23318)
  • terraform: Fix panic when using for_each with a set containing null values (#24047)