Merge pull request #4370 from TimeIncOSS/b-cloudformation-params-fix
provider/aws: CloudFormation - Use body or URL for all updates
This commit is contained in:
commit
da2c545c8c
|
@ -268,12 +268,14 @@ func resourceAwsCloudFormationStackUpdate(d *schema.ResourceData, meta interface
|
||||||
StackName: aws.String(d.Get("name").(string)),
|
StackName: aws.String(d.Get("name").(string)),
|
||||||
}
|
}
|
||||||
|
|
||||||
if d.HasChange("template_body") {
|
// Either TemplateBody or TemplateURL are required for each change
|
||||||
input.TemplateBody = aws.String(normalizeJson(d.Get("template_body").(string)))
|
if v, ok := d.GetOk("template_body"); ok {
|
||||||
|
input.TemplateBody = aws.String(normalizeJson(v.(string)))
|
||||||
}
|
}
|
||||||
if d.HasChange("template_url") {
|
if v, ok := d.GetOk("template_url"); ok {
|
||||||
input.TemplateURL = aws.String(d.Get("template_url").(string))
|
input.TemplateURL = aws.String(v.(string))
|
||||||
}
|
}
|
||||||
|
|
||||||
if d.HasChange("capabilities") {
|
if d.HasChange("capabilities") {
|
||||||
input.Capabilities = expandStringList(d.Get("capabilities").(*schema.Set).List())
|
input.Capabilities = expandStringList(d.Get("capabilities").(*schema.Set).List())
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,6 +64,31 @@ func TestAccAWSCloudFormation_allAttributes(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Regression for https://github.com/hashicorp/terraform/issues/4332
|
||||||
|
func TestAccAWSCloudFormation_withParams(t *testing.T) {
|
||||||
|
var stack cloudformation.Stack
|
||||||
|
|
||||||
|
resource.Test(t, resource.TestCase{
|
||||||
|
PreCheck: func() { testAccPreCheck(t) },
|
||||||
|
Providers: testAccProviders,
|
||||||
|
CheckDestroy: testAccCheckAWSCloudFormationDestroy,
|
||||||
|
Steps: []resource.TestStep{
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccAWSCloudFormationConfig_withParams,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckCloudFormationStackExists("aws_cloudformation_stack.with_params", &stack),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccAWSCloudFormationConfig_withParams_modified,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckCloudFormationStackExists("aws_cloudformation_stack.with_params", &stack),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func testAccCheckCloudFormationStackExists(n string, stack *cloudformation.Stack) resource.TestCheckFunc {
|
func testAccCheckCloudFormationStackExists(n string, stack *cloudformation.Stack) resource.TestCheckFunc {
|
||||||
return func(s *terraform.State) error {
|
return func(s *terraform.State) error {
|
||||||
rs, ok := s.RootModule().Resources[n]
|
rs, ok := s.RootModule().Resources[n]
|
||||||
|
@ -228,3 +253,43 @@ resource "aws_sns_topic" "cf-updates" {
|
||||||
name = "tf-cf-notifications"
|
name = "tf-cf-notifications"
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
|
||||||
|
var tpl_testAccAWSCloudFormationConfig_withParams = `
|
||||||
|
resource "aws_cloudformation_stack" "with_params" {
|
||||||
|
name = "tf-stack-with-params"
|
||||||
|
parameters {
|
||||||
|
VpcCIDR = "%s"
|
||||||
|
}
|
||||||
|
template_body = <<STACK
|
||||||
|
{
|
||||||
|
"Parameters" : {
|
||||||
|
"VpcCIDR" : {
|
||||||
|
"Description" : "CIDR to be used for the VPC",
|
||||||
|
"Type" : "String"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"Resources" : {
|
||||||
|
"MyVPC": {
|
||||||
|
"Type" : "AWS::EC2::VPC",
|
||||||
|
"Properties" : {
|
||||||
|
"CidrBlock" : {"Ref": "VpcCIDR"},
|
||||||
|
"Tags" : [
|
||||||
|
{"Key": "Name", "Value": "Primary_CF_VPC"}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
STACK
|
||||||
|
|
||||||
|
on_failure = "DELETE"
|
||||||
|
timeout_in_minutes = 1
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
var testAccAWSCloudFormationConfig_withParams = fmt.Sprintf(
|
||||||
|
tpl_testAccAWSCloudFormationConfig_withParams,
|
||||||
|
"10.0.0.0/16")
|
||||||
|
var testAccAWSCloudFormationConfig_withParams_modified = fmt.Sprintf(
|
||||||
|
tpl_testAccAWSCloudFormationConfig_withParams,
|
||||||
|
"12.0.0.0/16")
|
||||||
|
|
Loading…
Reference in New Issue