mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-08 15:13:56 -06:00
9dd4e5bcb0
* provider/aws: Add support for targets to aws_ssm_association Fixes: #13975 ``` % make testacc TEST=./builtin/providers/aws TESTARGS='-run=TestAccAWSSSMAssociation_' ==> Checking that code complies with gofmt requirements... go generate $(go list ./... | grep -v /terraform/vendor/) 2017/05/05 20:32:43 Generated command/internal_plugin_list.go TF_ACC=1 go test ./builtin/providers/aws -v -run=TestAccAWSSSMAssociation_ -timeout 120m === RUN TestAccAWSSSMAssociation_basic --- PASS: TestAccAWSSSMAssociation_basic (139.13s) === RUN TestAccAWSSSMAssociation_withTargets --- PASS: TestAccAWSSSMAssociation_withTargets (33.19s) PASS ok github.com/hashicorp/terraform/builtin/providers/aws 172.343s ``` * Update ssm_association.html.markdown
189 lines
4.4 KiB
Go
189 lines
4.4 KiB
Go
package aws
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
"github.com/aws/aws-sdk-go/aws/awserr"
|
|
"github.com/aws/aws-sdk-go/service/ssm"
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func TestAccAWSSSMAssociation_basic(t *testing.T) {
|
|
name := acctest.RandString(10)
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckAWSSSMAssociationDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccAWSSSMAssociationBasicConfig(name),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckAWSSSMAssociationExists("aws_ssm_association.foo"),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSSSMAssociation_withTargets(t *testing.T) {
|
|
name := acctest.RandString(10)
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckAWSSSMAssociationDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccAWSSSMAssociationBasicConfigWithTargets(name),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckAWSSSMAssociationExists("aws_ssm_association.foo"),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func testAccCheckAWSSSMAssociationExists(n string) resource.TestCheckFunc {
|
|
return func(s *terraform.State) error {
|
|
rs, ok := s.RootModule().Resources[n]
|
|
if !ok {
|
|
return fmt.Errorf("Not found: %s", n)
|
|
}
|
|
|
|
if rs.Primary.ID == "" {
|
|
return fmt.Errorf("No SSM Assosciation ID is set")
|
|
}
|
|
|
|
conn := testAccProvider.Meta().(*AWSClient).ssmconn
|
|
|
|
_, err := conn.DescribeAssociation(&ssm.DescribeAssociationInput{
|
|
AssociationId: aws.String(rs.Primary.Attributes["association_id"]),
|
|
})
|
|
|
|
if err != nil {
|
|
if wserr, ok := err.(awserr.Error); ok && wserr.Code() == "AssociationDoesNotExist" {
|
|
return nil
|
|
}
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccCheckAWSSSMAssociationDestroy(s *terraform.State) error {
|
|
conn := testAccProvider.Meta().(*AWSClient).ssmconn
|
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
if rs.Type != "aws_ssm_association" {
|
|
continue
|
|
}
|
|
|
|
out, err := conn.DescribeAssociation(&ssm.DescribeAssociationInput{
|
|
AssociationId: aws.String(rs.Primary.Attributes["association_id"]),
|
|
})
|
|
|
|
if err != nil {
|
|
if wserr, ok := err.(awserr.Error); ok && wserr.Code() == "AssociationDoesNotExist" {
|
|
return nil
|
|
}
|
|
return err
|
|
}
|
|
|
|
if out != nil {
|
|
return fmt.Errorf("Expected AWS SSM Association to be gone, but was still found")
|
|
}
|
|
}
|
|
|
|
return fmt.Errorf("Default error in SSM Association Test")
|
|
}
|
|
|
|
func testAccAWSSSMAssociationBasicConfigWithTargets(rName string) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_ssm_document" "foo_document" {
|
|
name = "test_document_association-%s",
|
|
document_type = "Command"
|
|
content = <<DOC
|
|
{
|
|
"schemaVersion": "1.2",
|
|
"description": "Check ip configuration of a Linux instance.",
|
|
"parameters": {
|
|
|
|
},
|
|
"runtimeConfig": {
|
|
"aws:runShellScript": {
|
|
"properties": [
|
|
{
|
|
"id": "0.aws:runShellScript",
|
|
"runCommand": ["ifconfig"]
|
|
}
|
|
]
|
|
}
|
|
}
|
|
}
|
|
DOC
|
|
}
|
|
|
|
resource "aws_ssm_association" "foo" {
|
|
name = "${aws_ssm_document.foo_document.name}",
|
|
targets {
|
|
key = "tag:Name"
|
|
values = ["acceptanceTest"]
|
|
}
|
|
}`, rName)
|
|
}
|
|
|
|
func testAccAWSSSMAssociationBasicConfig(rName string) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_security_group" "tf_test_foo" {
|
|
name = "tf_test_foo-%s"
|
|
description = "foo"
|
|
ingress {
|
|
protocol = "icmp"
|
|
from_port = -1
|
|
to_port = -1
|
|
cidr_blocks = ["0.0.0.0/0"]
|
|
}
|
|
}
|
|
|
|
resource "aws_instance" "foo" {
|
|
ami = "ami-4fccb37f"
|
|
availability_zone = "us-west-2a"
|
|
instance_type = "m1.small"
|
|
security_groups = ["${aws_security_group.tf_test_foo.name}"]
|
|
}
|
|
|
|
resource "aws_ssm_document" "foo_document" {
|
|
name = "test_document_association-%s",
|
|
document_type = "Command"
|
|
content = <<DOC
|
|
{
|
|
"schemaVersion": "1.2",
|
|
"description": "Check ip configuration of a Linux instance.",
|
|
"parameters": {
|
|
|
|
},
|
|
"runtimeConfig": {
|
|
"aws:runShellScript": {
|
|
"properties": [
|
|
{
|
|
"id": "0.aws:runShellScript",
|
|
"runCommand": ["ifconfig"]
|
|
}
|
|
]
|
|
}
|
|
}
|
|
}
|
|
DOC
|
|
}
|
|
|
|
resource "aws_ssm_association" "foo" {
|
|
name = "test_document_association-%s",
|
|
instance_id = "${aws_instance.foo.id}"
|
|
}
|
|
`, rName, rName, rName)
|
|
}
|