package aws import ( "fmt" "strings" "testing" "github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws/awserr" "github.com/aws/aws-sdk-go/service/iam" "github.com/hashicorp/terraform/helper/acctest" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" ) func TestAccAWSGroupMembership_basic(t *testing.T) { var group iam.GetGroupOutput rString := acctest.RandStringFromCharSet(10, acctest.CharSetAlpha) configBase := fmt.Sprintf(testAccAWSGroupMemberConfig, rString, rString, rString) configUpdate := fmt.Sprintf(testAccAWSGroupMemberConfigUpdate, rString, rString, rString, rString, rString) configUpdateDown := fmt.Sprintf(testAccAWSGroupMemberConfigUpdateDown, rString, rString, rString) testUser := fmt.Sprintf("test-user-%s", rString) testUserTwo := fmt.Sprintf("test-user-two-%s", rString) testUserThree := fmt.Sprintf("test-user-three-%s", rString) resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckAWSGroupMembershipDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: configBase, Check: resource.ComposeTestCheckFunc( testAccCheckAWSGroupMembershipExists("aws_iam_group_membership.team", &group), testAccCheckAWSGroupMembershipAttributes(&group, []string{testUser}), ), }, resource.TestStep{ Config: configUpdate, Check: resource.ComposeTestCheckFunc( testAccCheckAWSGroupMembershipExists("aws_iam_group_membership.team", &group), testAccCheckAWSGroupMembershipAttributes(&group, []string{testUserTwo, testUserThree}), ), }, resource.TestStep{ Config: configUpdateDown, Check: resource.ComposeTestCheckFunc( testAccCheckAWSGroupMembershipExists("aws_iam_group_membership.team", &group), testAccCheckAWSGroupMembershipAttributes(&group, []string{testUserThree}), ), }, }, }) } func TestAccAWSGroupMembership_paginatedUserList(t *testing.T) { var group iam.GetGroupOutput resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckAWSGroupMembershipDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: testAccAWSGroupMemberConfigPaginatedUserList, Check: resource.ComposeTestCheckFunc( testAccCheckAWSGroupMembershipExists("aws_iam_group_membership.team", &group), resource.TestCheckResourceAttr( "aws_iam_group_membership.team", "users.#", "101"), ), }, }, }) } func testAccCheckAWSGroupMembershipDestroy(s *terraform.State) error { conn := testAccProvider.Meta().(*AWSClient).iamconn for _, rs := range s.RootModule().Resources { if rs.Type != "aws_iam_group_membership" { continue } group := rs.Primary.Attributes["group"] _, err := conn.GetGroup(&iam.GetGroupInput{ GroupName: aws.String(group), }) if err != nil { // Verify the error is what we want if ae, ok := err.(awserr.Error); ok && ae.Code() == "NoSuchEntity" { continue } return err } return fmt.Errorf("still exists") } return nil } func testAccCheckAWSGroupMembershipExists(n string, g *iam.GetGroupOutput) 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 User name is set") } conn := testAccProvider.Meta().(*AWSClient).iamconn gn := rs.Primary.Attributes["group"] resp, err := conn.GetGroup(&iam.GetGroupInput{ GroupName: aws.String(gn), }) if err != nil { return fmt.Errorf("Error: Group (%s) not found", gn) } *g = *resp return nil } } func testAccCheckAWSGroupMembershipAttributes(group *iam.GetGroupOutput, users []string) resource.TestCheckFunc { return func(s *terraform.State) error { if !strings.Contains(*group.Group.GroupName, "test-group") { return fmt.Errorf("Bad group membership: expected %s, got %s", "test-group", *group.Group.GroupName) } uc := len(users) for _, u := range users { for _, gu := range group.Users { if u == *gu.UserName { uc-- } } } if uc > 0 { return fmt.Errorf("Bad group membership count, expected (%d), but only (%d) found", len(users), uc) } return nil } } const testAccAWSGroupMemberConfig = ` resource "aws_iam_group" "group" { name = "test-group-%s" } resource "aws_iam_user" "user" { name = "test-user-%s" } resource "aws_iam_group_membership" "team" { name = "tf-testing-group-membership-%s" users = ["${aws_iam_user.user.name}"] group = "${aws_iam_group.group.name}" } ` const testAccAWSGroupMemberConfigUpdate = ` resource "aws_iam_group" "group" { name = "test-group-%s" } resource "aws_iam_user" "user" { name = "test-user-%s" } resource "aws_iam_user" "user_two" { name = "test-user-two-%s" } resource "aws_iam_user" "user_three" { name = "test-user-three-%s" } resource "aws_iam_group_membership" "team" { name = "tf-testing-group-membership-%s" users = [ "${aws_iam_user.user_two.name}", "${aws_iam_user.user_three.name}", ] group = "${aws_iam_group.group.name}" } ` const testAccAWSGroupMemberConfigUpdateDown = ` resource "aws_iam_group" "group" { name = "test-group-%s" } resource "aws_iam_user" "user_three" { name = "test-user-three-%s" } resource "aws_iam_group_membership" "team" { name = "tf-testing-group-membership-%s" users = [ "${aws_iam_user.user_three.name}", ] group = "${aws_iam_group.group.name}" } ` const testAccAWSGroupMemberConfigPaginatedUserList = ` resource "aws_iam_group" "group" { name = "test-paginated-group" } resource "aws_iam_group_membership" "team" { name = "tf-testing-paginated-group-membership" users = ["${aws_iam_user.user.*.name}"] group = "${aws_iam_group.group.name}" } resource "aws_iam_user" "user" { count = 101 name = "${format("paged-test-user-%d", count.index + 1)}" } `