Skip to content

Commit

Permalink
Merge pull request #2800 from loivis/2648-import-launch-configuration…
Browse files Browse the repository at this point in the history
…-with-user-data-and-security-groups

r/aws_launch_configuration: support security groups and user data for import
  • Loading branch information
bflad authored Apr 9, 2018
2 parents d717e36 + f9eac46 commit aba7629
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 3 deletions.
2 changes: 1 addition & 1 deletion aws/import_aws_launch_configuration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ func TestAccAWSLaunchConfiguration_importBasic(t *testing.T) {
ResourceName: resourceName,
ImportState: true,
ImportStateVerify: true,
ImportStateVerifyIgnore: []string{"associate_public_ip_address", "user_data"},
ImportStateVerifyIgnore: []string{"associate_public_ip_address"},
},
},
})
Expand Down
12 changes: 10 additions & 2 deletions aws/resource_aws_launch_configuration.go
Original file line number Diff line number Diff line change
Expand Up @@ -508,6 +508,7 @@ func resourceAwsLaunchConfigurationRead(d *schema.ResourceData, meta interface{}
}

lc := describConfs.LaunchConfigurations[0]
log.Printf("[DEBUG] launch configuration output: %s", lc)

d.Set("key_name", lc.KeyName)
d.Set("image_id", lc.ImageId)
Expand All @@ -518,11 +519,18 @@ func resourceAwsLaunchConfigurationRead(d *schema.ResourceData, meta interface{}
d.Set("ebs_optimized", lc.EbsOptimized)
d.Set("spot_price", lc.SpotPrice)
d.Set("enable_monitoring", lc.InstanceMonitoring.Enabled)
d.Set("security_groups", lc.SecurityGroups)
d.Set("associate_public_ip_address", lc.AssociatePublicIpAddress)
if err := d.Set("security_groups", flattenStringList(lc.SecurityGroups)); err != nil {
return fmt.Errorf("error setting security_groups: %s", err)
}
if aws.StringValue(lc.UserData) != "" {
d.Set("user_data", userDataHashSum(*lc.UserData))
}

d.Set("vpc_classic_link_id", lc.ClassicLinkVPCId)
d.Set("vpc_classic_link_security_groups", lc.ClassicLinkVPCSecurityGroups)
if err := d.Set("vpc_classic_link_security_groups", flattenStringList(lc.ClassicLinkVPCSecurityGroups)); err != nil {
return fmt.Errorf("error setting vpc_classic_link_security_groups: %s", err)
}

if err := readLCBlockDevices(d, lc, ec2conn); err != nil {
return err
Expand Down
5 changes: 5 additions & 0 deletions aws/resource_aws_launch_configuration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,11 @@ func TestAccAWSLaunchConfiguration_withVpcClassicLink(t *testing.T) {
testAccCheckAWSSecurityGroupExists("aws_security_group.foo", &group),
),
},
{
ResourceName: "aws_launch_configuration.foo",
ImportState: true,
ImportStateVerify: true,
},
},
})
}
Expand Down

0 comments on commit aba7629

Please sign in to comment.