mirror of
https://github.com/letic/terraform-provider-google.git
synced 2024-10-05 02:01:05 +00:00
219bd09496
<!-- This change is generated by MagicModules. --> /cc @rileykarson
189 lines
4.8 KiB
Go
189 lines
4.8 KiB
Go
package google
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func TestAccProjectIamCustomRole_basic(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
roleId := "tfIamCustomRole" + acctest.RandString(10)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckGoogleProjectIamCustomRoleDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
Check: resource.TestCheckResourceAttr("google_project_iam_custom_role.foo", "stage", "GA"),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_update(roleId),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccProjectIamCustomRole_undelete(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
roleId := "tfIamCustomRole" + acctest.RandString(10)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckGoogleProjectIamCustomRoleDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
Check: testAccCheckGoogleProjectIamCustomRoleDeletionStatus("google_project_iam_custom_role.foo", false),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
// Soft-delete
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
Check: testAccCheckGoogleProjectIamCustomRoleDeletionStatus("google_project_iam_custom_role.foo", true),
|
|
Destroy: true,
|
|
},
|
|
// Terraform doesn't have a config because of Destroy: true, so an import step would fail
|
|
// Undelete
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
Check: testAccCheckGoogleProjectIamCustomRoleDeletionStatus("google_project_iam_custom_role.foo", false),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccProjectIamCustomRole_createAfterDestroy(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
roleId := "tfIamCustomRole" + acctest.RandString(10)
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckGoogleProjectIamCustomRoleDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
// Destroy resources
|
|
{
|
|
Config: " ",
|
|
Destroy: true,
|
|
},
|
|
// Re-create with no existing state
|
|
{
|
|
Config: testAccCheckGoogleProjectIamCustomRole_basic(roleId),
|
|
},
|
|
{
|
|
ResourceName: "google_project_iam_custom_role.foo",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func testAccCheckGoogleProjectIamCustomRoleDestroy(s *terraform.State) error {
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
if rs.Type != "google_project_iam_custom_role" {
|
|
continue
|
|
}
|
|
|
|
role, err := config.clientIAM.Projects.Roles.Get(rs.Primary.ID).Do()
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if !role.Deleted {
|
|
return fmt.Errorf("Iam custom role still exists")
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func testAccCheckGoogleProjectIamCustomRoleDeletionStatus(n string, deleted bool) 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 ID is set")
|
|
}
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
role, err := config.clientIAM.Projects.Roles.Get(rs.Primary.ID).Do()
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if deleted != role.Deleted {
|
|
return fmt.Errorf("Incorrect deletion status. Expected %t, got %t", deleted, role.Deleted)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccCheckGoogleProjectIamCustomRole_basic(roleId string) string {
|
|
return fmt.Sprintf(`
|
|
resource "google_project_iam_custom_role" "foo" {
|
|
role_id = "%s"
|
|
title = "My Custom Role"
|
|
description = "foo"
|
|
permissions = ["iam.roles.list"]
|
|
}
|
|
`, roleId)
|
|
}
|
|
|
|
func testAccCheckGoogleProjectIamCustomRole_update(roleId string) string {
|
|
return fmt.Sprintf(`
|
|
resource "google_project_iam_custom_role" "foo" {
|
|
role_id = "%s"
|
|
title = "My Custom Role Updated"
|
|
description = "bar"
|
|
permissions = ["iam.roles.list", "iam.roles.create", "iam.roles.delete"]
|
|
stage = "BETA"
|
|
}
|
|
`, roleId)
|
|
}
|