From 044395aa20023739796ddd13b4504fe628dc9f9e Mon Sep 17 00:00:00 2001 From: VenelinMartinov Date: Mon, 19 Aug 2024 20:28:46 +0100 Subject: [PATCH] Enable PRC by default in pulumi-azure (#2306) Enables PlanResourceChange by default in pulumi-azure. Part of https://github.com/pulumi/pulumi-terraform-bridge/issues/1785 Also contains https://github.com/pulumi/pulumi-azure/pull/2325 Also contains https://github.com/pulumi/pulumi-azure/pull/2331 fixes https://github.com/pulumi/pulumi-azure/issues/2322 fixes https://github.com/pulumi/pulumi-azure/issues/2323 fixes https://github.com/pulumi/pulumi-azure/issues/2330 --- examples/examples_nodejs_test.go | 4 +++- provider/resources.go | 22 +++++++++++++++++++--- 2 files changed, 22 insertions(+), 4 deletions(-) diff --git a/examples/examples_nodejs_test.go b/examples/examples_nodejs_test.go index 04a8fcb114..b3c17ee32f 100644 --- a/examples/examples_nodejs_test.go +++ b/examples/examples_nodejs_test.go @@ -70,7 +70,9 @@ func TestAccAciVolumeMount(t *testing.T) { test := getJSBaseOptions(t). With(integration.ProgramTestOptions{ Dir: filepath.Join(getCwd(t), "aci-volume-mount"), - RunUpdateTest: true, + RunUpdateTest: false, + SkipEmptyPreviewUpdate: true, + ExpectRefreshChanges: true, }) integration.ProgramTest(t, &test) diff --git a/provider/resources.go b/provider/resources.go index 74e5b4fdc7..1715e0ecb9 100644 --- a/provider/resources.go +++ b/provider/resources.go @@ -502,9 +502,9 @@ var metadata []byte // // nolint: lll func Provider() tfbridge.ProviderInfo { - p := shimv2.NewProvider(shim.NewProvider(), shimv2.WithPlanResourceChange(func(tfResourceType string) bool { - return tfResourceType == "azurerm_storage_account" - })) + p := shimv2.NewProvider(shim.NewProvider(), + shimv2.WithPlanResourceChange(func(string) bool { return true }), + ) // Adjust the defaults if running in Azure Cloud Shell. // Environment variables still take preference, e.g. USE_MSI=false disables the MSI endpoint. @@ -1891,6 +1891,14 @@ func Provider() tfbridge.ProviderInfo { Transform: strings.ToLower, }), }, + TransformFromState: func(_ context.Context, pm resource.PropertyMap) (resource.PropertyMap, error) { + // if the defaultOutboundAccessEnabled property is not set, set it to the default value of true + // this prevents an unnecessary replacement when upgrading the provider + if _, ok := pm["defaultOutboundAccessEnabled"]; !ok { + pm["defaultOutboundAccessEnabled"] = resource.NewBoolProperty(true) + } + return pm, nil + }, }, "azurerm_subnet_network_security_group_association": {Tok: azureResource(azureNetwork, "SubnetNetworkSecurityGroupAssociation")}, "azurerm_subnet_route_table_association": {Tok: azureResource(azureNetwork, "SubnetRouteTableAssociation")}, @@ -2053,6 +2061,14 @@ func Provider() tfbridge.ProviderInfo { Transform: strings.ToLower, }), }, + TransformFromState: func(_ context.Context, pm resource.PropertyMap) (resource.PropertyMap, error) { + // This prevents unnecessary replacement when upgrading from a version of the Azure provider + // prior to this parameter being added. + if _, ok := pm["encryptionScopeOverrideEnabled"]; !ok { + pm["encryptionScopeOverrideEnabled"] = resource.NewBoolProperty(true) + } + return pm, nil + }, }, "azurerm_storage_share": {Tok: azureResource(azureStorage, "Share")}, "azurerm_storage_share_directory": {Tok: azureResource(azureStorage, "ShareDirectory")},