This repository was archived by the owner on Aug 3, 2023. It is now read-only.
Update Terraform hashicorp/terraform to ~> 1.5.0#11
Open
renovate[bot] wants to merge 1 commit into
Open
Conversation
efc7936 to
ca80eff
Compare
ca80eff to
4fff667
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
~> 1.2.0->~> 1.5.0Release Notes
hashicorp/terraform (hashicorp/terraform)
v1.5.3Compare Source
1.5.3 (July 12, 2023)
BUG FIXES:
consul CAS failed with transaction errorsno longer shows an error instance memory address, but an actual error message. (#33108)v1.5.2Compare Source
1.5.2 (June 28, 2023)
BUG FIXES:
importblocks with the sameidstring no longer result in a validation error (#33434)v1.5.1Compare Source
1.5.1 (June 21, 2023)
BUG FIXES:
v1.5.0Compare Source
1.5.0 (June 12, 2023)
NEW FEATURES:
checkblocks for validating infrastructure: Module and configuration authors can now write independent check blocks within their configuration to validate assertions about their infrastructure.The new independent
checkblocks must specify at least oneassertblock, but possibly many, each one with aconditionexpression and anerror_messageexpression matching the existing Custom Condition Checks.Additionally, check blocks can optionally load a scoped data source. Scoped data sources match the existing data sources with the exception that they can only be referenced from within their check block.
Unlike the existing
preconditionandpostconditionblocks, Terraform will not halt execution should the scoped data block fail or error or if any of the assertions fail.This allows practitioners to continually validate the state of their infrastructure outside the usual lifecycle management cycle.
importblocks for importing infrastructure: Root module authors can now use theimportblock to declare their intent that Terraform adopt an existing resource.Import is now a configuration-driven, plannable action, and is processed as part of a normal plan. Running
terraform planwill show a summary of the resources that Terraform has planned to import, along with any other plan changes.The existing
terraform importCLI command has not been modified.This is an early version of the
importblock feature, for which we are actively seeking user feedback to shape future development. Theimportblock currently does not support interpolation in theidfield, which must be a string.Generating configuration for imported resources: in conjunction with the
importblock, this feature enables easy templating of configuration when importing existing resources into Terraform. A new flag-generate-config-out=PATHis added toterraform plan. When this flag is set, Terraform will generate HCL configuration for any resource included in animportblock that does not already have associated configuration, and write it to a new file atPATH. Before applying, review the generated configuration and edit it as necessary.Adds a new
plantimestampfunction that returns the timestamp at plan time. This is similar to thetimestampfunction which returns the timestamp at apply time (#32980).Adds a new
strcontainsfunction that checks whether a given string contains a given substring. (#33069)UPGRADE NOTES:
This is the last version of Terraform for which macOS 10.13 High Sierra or 10.14 Mojave are officially supported. Future Terraform versions may not function correctly on these older versions of macOS.
This is the last version of Terraform for which Windows 7, 8, Server 2008, and Server 2012 are supported by Terraform's main implementation language, Go. We already ended explicit support for versions earlier than Windows 10 in Terraform v0.15.0, but future Terraform versions may malfunction in more significant ways on these older Windows versions.
On Linux (and some other non-macOS Unix platforms we don't officially support), Terraform will now notice the
trust-adoption in/etc/resolv.confand, if set, will set the "authentic data" option in outgoing DNS requests in order to better match the behavior of the GNU libc resolver.Terraform does not pay any attention to the corresponding option in responses, but some DNSSEC-aware recursive resolvers return different responses when the request option isn't set. This should therefore avoid some potential situations where a DNS request from Terraform might get a different response than a similar request from other software on your system.
ENHANCEMENTS:
pgbackend: Now supports thePG_CONN_STR,PG_SCHEMA_NAME,PG_SKIP_SCHEMA_CREATION,PG_SKIP_TABLE_CREATIONandPG_SKIP_INDEX_CREATIONenvironment variables. (#33045)BUG FIXES:
terraform init: Fixed crash with invalid blank module name. (#32781)movedblocks: Fixed a typo in the error message that Terraform raises when you use-targetto exclude an object that has been moved. (#33149)Previous Releases
For information on prior major and minor releases, see their changelogs:
v1.4.6Compare Source
1.4.6 (April 26, 2023)
BUG FIXES
terraform show -jsonoutput. (#33059)# forces replacementsuffix. (#33065)v1.4.5Compare Source
1.4.5 (April 12, 2023)
terraform_datato fail when being replaced withcreate_before_destroy(#32988)v1.4.4Compare Source
1.4.4 (March 30, 2023)
Due to an incident while migrating build systems for the 1.4.3 release where
CGO_ENABLED=0was not set, we are rebuilding that version as 1.4.4 with theflag set. No other changes have been made between 1.4.3 and 1.4.4.
v1.4.3Compare Source
1.4.3 (March 30, 2023)
BUG FIXES:
v1.4.2Compare Source
1.4.2 (March 16, 2023)
BUG FIXES:
setproductcaused Terraform to crash (#32860)v1.4.1Compare Source
1.4.1 (March 15, 2023)
BUG FIXES:
depends_onattribute set, while still preventing thedepends_onattribute itself from being overridden. (#32796)terraform providers mirror: when a dependency lock file is present, mirror the resolved providers versions, not the latest available based on configuration. (#32749)TF_CLI_CONFIG_FILE(#32846)v1.4.0Compare Source
1.4.0 (March 08, 2023)
UPGRADE NOTES:
config: The
textencodebase64function when called with encoding "GB18030" will now encode the euro symbol € as the two-byte sequence0xA2,0xE3, as required by the GB18030 standard, before applying base64 encoding.config: The
textencodebase64function when called with encoding "GBK" or "CP936" will now encode the euro symbol € as the single byte0x80before applying base64 encoding. This matches the behavior of the Windows API when encoding to this Windows-specific character encoding.terraform init: When interpreting the hostname portion of a provider source address or the address of a module in a module registry, Terraform will now use non-transitional IDNA2008 mapping rules instead of the transitional mapping rules previously used.This matches a change to the WHATWG URL spec's rules for interpreting non-ASCII domain names which is being gradually adopted by web browsers. Terraform aims to follow the interpretation of hostnames used by web browsers for consistency. For some hostnames containing non-ASCII characters this may cause Terraform to now request a different "punycode" hostname when resolving.
terraform initwill now ignore entries in the optional global provider cache directory unless they match a checksum already tracked in the current configuration's dependency lock file. This therefore avoids the long-standing problem that when installing a new provider for the first time from the cache we can't determine the full set of checksums to include in the lock file. Once the lock file has been updated to include a checksum covering the item in the global cache, Terraform will then use the cache entry for subsequent installation of the same provider package. There is an interim CLI configuration opt-out for those who rely on the previous incorrect behavior. (#32129)The Terraform plan renderer has been completely rewritten to aid with future Terraform Cloud integration. Users should not see any material change in the plan output between 1.3 and 1.4. If you notice any significant differences, or if Terraform fails to plan successfully due to rendering problems, please open a bug report issue.
BUG FIXES:
yamldecodefunction now correctly handles entirely-nil YAML documents. Previously it would incorrectly return an unknown value instead of a null value. It will now return a null value as documented. (#32151)terraform workspacenow returns a non-zero exit when given an invalid argument (#31318)-jsonmode, messages will now be written in JSON format (#32451)ENHANCEMENTS:
terraform plancan now store a plan file even when encountering errors, which can later be inspected to help identify the source of the failures (#32395)terraform_datais a new builtin managed resource type, which can replace the use ofnull_resource, and can store data of any type (#31757)terraform initwill now ignore entries in the optional global provider cache directory unless they match a checksum already tracked in the current configuration's dependency lock file. This therefore avoids the long-standing problem that when installing a new provider for the first time from the cache we can't determine the full set of checksums to include in the lock file. Once the lock file has been updated to include a checksum covering the item in the global cache, Terraform will then use the cache entry for subsequent installation of the same provider package. There is an interim CLI configuration opt-out for those who rely on the previous incorrect behavior. (#32129)-or-createflag was added toterraform workspace select, to aid in creating workspaces in automated situations (#31633)terraform metadata functions -json(#32487)kms_encryption_keyargument, to allow encryption of state files using Cloud KMS keys. (#24967)storage_custom_endpointargument, to allow communication with the backend via a Private Service Connect endpoint. (#28856)gcswithterraform_remote_state(#32065)cloudbackendterraform workspace deletewill use Terraform Cloud's Safe Delete API if the-forceflag is not provided. (#31949)quietargument. Ifquietis set totrue, Terraform will not print the entire command to stdout during plan. (#32116)terraform showwill now print an explanation when called on a Terraform workspace with empty state detailing why no resources are shown. (#32629)GOOGLE_BACKEND_IMPERSONATE_SERVICE_ACCOUNTenv var to allow impersonating a different service account whenGOOGLE_IMPERSONATE_SERVICE_ACCOUNTis configured for the GCP provider. (#32557)assume_roleauthentication method with thetencentcloudprovider. This can be configured via the Terraform config or environment variables.security_tokenauthentication method with thetencentcloudprovider. This can be configured via the Terraform config or environment variables.EXPERIMENTS:
Since its introduction the
yamlencodefunction's documentation carried a warning that it was experimental. This predated our more formalized idea of language experiments and so wasn't guarded by an explicit opt-in, but the intention was to allow for small adjustments to its behavior if we learned it was producing invalid YAML in some cases, due to the relative complexity of the YAML specification.From Terraform v1.4 onwards,
yamlencodeis no longer documented as experimental and is now subject to the Terraform v1.x Compatibility Promises. There are no changes to its previous behavior in v1.3 and so no special action is required when upgrading.v1.3.9Compare Source
1.3.9 (February 15, 2023)
BUG FIXES:
v1.3.8Compare Source
1.3.8 (February 09, 2023)
BUG FIXES:
before_sensitive/after_sensitiveannotations in JSON plan output for deeply nested structures. This was only observed in the wild on the rancher/rancher2 provider, and resulted in glitched display in Terraform Cloud's structured plan log view. (#32543)v1.3.7Compare Source
1.3.7 (January 04, 2023)
BUG FIXES:
ignore_changes(#32428)v1.3.6Compare Source
1.3.6 (November 30, 2022)
BUG FIXES:
v1.3.5Compare Source
1.3.5 (November 17, 2022)
BUG FIXES:
(sensitive value)instead of sometimes as(sensitive)[GH32004]v1.3.4Compare Source
1.3.4 (November 02, 2022)
BUG FIXES:
consolewhen outputs contain preconditions (#32051)oidc_tokenandoidc_token_file_pathproperties (#31966)regex,regexall, andreplacefunctions, to avoid unbounded memory usage for maliciously-crafted patterns. This change should not affect any reasonable patterns intended for practical use. (#32135)v1.3.3Compare Source
1.3.3 (October 19, 2022)
BUG FIXES:
v1.3.2Compare Source
1.3.2 (October 06, 2022)
BUG FIXES:
ignore_changes = allcould cause persistent diffs with legacy providers (#31914)import(#31878)v1.3.1Compare Source
1.3.1 (September 28, 2022)
NOTE:
darwin/amd64anddarwin/arm64architectures,terraformbinaries are now built with CGO enabled. This should not have any user-facing impact, except in cases where the pure Go DNS resolver causes problems on recent versions of macOS: using CGO may mitigate these issues. Please see the upstream bug https://github.com/golang/go/issues/52839 for more details.BUG FIXES:
v1.3.0Compare Source
1.3.0 (September 21, 2022)
NEW FEATURES:
Optional attributes for object type constraints: When declaring an input variable whose type constraint includes an object type, you can now declare individual attributes as optional, and specify a default value to use if the caller doesn't set it. For example:
Assigning
{ a = "foo" }to this variable will result in the value{ a = "foo", b = null, c = 127 }.Added functions:
startswithandendswithallow you to check whether a given string has a specified prefix or suffix. (#31220)UPGRADE NOTES:
terraform show -json: Output changes now include more detail about the unknown-ness of the planned value. Previously, a planned output would be marked as either fully known or partially unknown, with theafter_unknownfield having valuefalseortruerespectively. Now outputs correctly expose the full structure of unknownness for complex values, allowing consumers of the JSON output format to determine which values in a collection are known only after apply.terraform import: The-allow-missing-confighas been removed, and at least an empty configuration block must exist to import a resource.Consumers of the JSON output format expecting on the
after_unknownfield to be onlyfalseortrueshould be updated to support the change representation described in the documentation, and as was already used for resource changes. (#31235)AzureRM Backend: This release concludes the deprecation cycle started in Terraform v1.1 for the
azurermbackend's support of "ADAL" authentication. This backend now supports only "MSAL" (Microsoft Graph) authentication.This follows from Microsoft's own deprecation of Azure AD Graph, and so you must follow the migration instructions presented in that Azure documentation to adopt Microsoft Graph and then change your backend configuration to use MSAL authentication before upgrading to Terraform v1.3.
When making requests to HTTPS servers, Terraform will now reject invalid handshakes that have duplicate extensions, as required by RFC 5246 section 7.4.1.4 and RFC 8446 section 4.2. This may cause new errors when interacting with existing buggy or misconfigured TLS servers, but should not affect correct servers.
This only applies to requests made directly by Terraform CLI, such as provider installation and remote state storage. Terraform providers are separate programs which decide their own policy for handling of TLS handshakes.
The following backends, which were deprecated in v1.2.3, have now been removed:
artifactory,etcd,etcdv3,manta,swift. The legacy backend nameazurehas also been removed, because the current Azure backend is namedazurerm. (#31711)ENHANCEMENTS:
timecmpallows determining the ordering relationship between two timestamps while taking potentially-different UTC offsets into account. (#31687)movedblocks can now describe resources moving to and from modules in separate module packages. (#31556)terraform fmtnow accepts multiple target paths, allowing formatting of several individual files at once. (#31687)terraform init: provider installation errors now mention which host Terraform was downloading from (#31524)PlanResourceChangefor compatible providers when destroying resource instances. (#31179)BUG FIXES:
terraform show -json: Fixed missing markers for unknown values in the encoding of partially unknown tuples and sets. (#31236)terraform outputCLI help documentation is now more consistent with web-based documentation. (#29354)terraform init: Error messages now handle the situation where the underlying HTTP client library does not indicate a hostname for a failed request. (#31542)terraform init: Don't panic if a child module contains a resource with a syntactically-invalid resource type name. (#31573)nulloutput values in a destroy plan will no longer report them as being deleted, which avoids reporting the deletion of an output value that was already absent. (#31471)terraform import: Better handling of resources or modules that usefor_each, and situations where data resources are needed to complete the operation. (#31283)EXPERIMENTS:
This release concludes the
module_variable_optional_attrsexperiment, which started in Terraform v0.14.0. The final design of the optional attributes feature is similar to the experimental form in the previous releases, but with two major differences:optionalfunction-like modifier for declaring an optional attribute now accepts an optional second argument for specifying a default value to use when the attribute isn't set by the caller. If not specified, the default value is a null value of the appropriate type as before.defaultsfunction, previously used to meet the use-case of replacing null values with default values, will not graduate to stable and has been removed. Use the second argument ofoptionalinline in your type constraint to declare default values instead.If you have any experimental modules that were participating in this experiment, you will need to remove the experiment opt-in and adopt the new syntax for declaring default values in order to migrate your existing module to the stablized version of this feature. If you are writing a shared module for others to use, we recommend declaring that your module requires Terraform v1.3.0 or later to give specific feedback when using the new feature on older Terraform versions, in place of the previous declaration to use the experimental form of this feature:
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by Mend Renovate. View repository job log here.