From 55dd263d692cb58a7dd56f0778f4352a403046f9 Mon Sep 17 00:00:00 2001 From: chroju Date: Sat, 25 Jan 2020 04:08:14 +0900 Subject: [PATCH] resource/aws_ssm_parameter: Enable to change type from SecureString to String (#9843) (#10819) Output from acceptance testing: ``` --- PASS: TestAccAWSSSMParameter_disappears (14.20s) --- PASS: TestAccAWSSSMParameter_fullPath (20.62s) --- PASS: TestAccAWSSSMParameter_secure (21.53s) --- PASS: TestAccAWSSSMParameter_basic (21.98s) --- PASS: TestAccAWSSSMParameter_updateDescription (34.06s) --- PASS: TestAccAWSSSMParameter_changeNameForcesNew (34.44s) --- PASS: TestAccAWSSSMParameter_updateType (35.23s) --- PASS: TestAccAWSSSMParameter_overwrite (36.26s) --- PASS: TestAccAWSSSMParameter_Tier (46.00s) --- PASS: TestAccAWSSSMParameter_tags (48.53s) --- PASS: TestAccAWSSSMParameter_secure_with_key (51.77s) --- PASS: TestAccAWSSSMParameter_secure_keyUpdate (69.76s) ``` --- aws/resource_aws_ssm_parameter.go | 2 +- aws/resource_aws_ssm_parameter_test.go | 44 ++++++++++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/aws/resource_aws_ssm_parameter.go b/aws/resource_aws_ssm_parameter.go index 6aef7c26db8..fe5e66e1fcb 100644 --- a/aws/resource_aws_ssm_parameter.go +++ b/aws/resource_aws_ssm_parameter.go @@ -214,7 +214,7 @@ func resourceAwsSsmParameterPut(d *schema.ResourceData, meta interface{}) error paramInput.Description = aws.String(n.(string)) } - if keyID, ok := d.GetOk("key_id"); ok { + if keyID, ok := d.GetOk("key_id"); d.Get("type") == "SecureString" && ok { log.Printf("[DEBUG] Setting key_id for SSM Parameter %v: %s", d.Get("name"), keyID) paramInput.SetKeyId(keyID.(string)) } diff --git a/aws/resource_aws_ssm_parameter_test.go b/aws/resource_aws_ssm_parameter_test.go index 22a86267c68..244248c98ec 100644 --- a/aws/resource_aws_ssm_parameter_test.go +++ b/aws/resource_aws_ssm_parameter_test.go @@ -182,6 +182,36 @@ func TestAccAWSSSMParameter_tags(t *testing.T) { }) } +func TestAccAWSSSMParameter_updateType(t *testing.T) { + var param ssm.Parameter + name := fmt.Sprintf("%s_%s", t.Name(), acctest.RandString(10)) + resourceName := "aws_ssm_parameter.test" + + resource.ParallelTest(t, resource.TestCase{ + PreCheck: func() { testAccPreCheck(t) }, + Providers: testAccProviders, + CheckDestroy: testAccCheckAWSSSMParameterDestroy, + Steps: []resource.TestStep{ + { + Config: testAccAWSSSMParameterBasicConfig(name, "SecureString", "test2"), + }, + { + ResourceName: resourceName, + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"overwrite"}, + }, + { + Config: testAccAWSSSMParameterBasicConfigTypeUpdated(name, "String", "test2"), + Check: resource.ComposeTestCheckFunc( + testAccCheckAWSSSMParameterExists(resourceName, ¶m), + resource.TestCheckResourceAttr(resourceName, "type", "String"), + ), + }, + }, + }) +} + func TestAccAWSSSMParameter_updateDescription(t *testing.T) { var param ssm.Parameter name := fmt.Sprintf("%s_%s", t.Name(), acctest.RandString(10)) @@ -508,6 +538,20 @@ resource "aws_ssm_parameter" "test" { `, rName, tagKey1, tagValue1, tagKey2, tagValue2) } +func testAccAWSSSMParameterBasicConfigTypeUpdated(rName, pType, value string) string { + return fmt.Sprintf(` +resource "aws_ssm_parameter" "test" { + name = "%s" + type = "%s" + value = "%s" + + tags = { + Name = "My Parameter" + } +} +`, rName, pType, value) +} + func testAccAWSSSMParameterBasicConfigOverwrite(rName, pType, value string) string { return fmt.Sprintf(` resource "aws_ssm_parameter" "test" {