2017-07-04 03:59:26 +00:00
|
|
|
package google
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
|
|
"google.golang.org/api/cloudresourcemanager/v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Test that an IAM binding can be applied to a project
|
|
|
|
func TestAccGoogleProjectIamMember_basic(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-11-20 23:45:51 +00:00
|
|
|
org := getTestOrgFromEnv(t)
|
2017-07-04 03:59:26 +00:00
|
|
|
pid := "terraform-" + acctest.RandString(10)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
// Create a new project
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProject_create(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccGoogleProjectExistingPolicy(pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
// Apply an IAM binding
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProjectAssociateMemberBasic(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleProjectIamBindingExists("google_project_iam_member.acceptance", &cloudresourcemanager.Binding{
|
|
|
|
Role: "roles/compute.instanceAdmin",
|
|
|
|
Members: []string{"user:admin@hashicorptest.com"},
|
|
|
|
}, pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test that multiple IAM bindings can be applied to a project
|
|
|
|
func TestAccGoogleProjectIamMember_multiple(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-11-20 23:45:51 +00:00
|
|
|
org := getTestOrgFromEnv(t)
|
2017-11-21 01:01:39 +00:00
|
|
|
skipIfEnvNotSet(t, "GOOGLE_ORG")
|
|
|
|
|
2017-07-04 03:59:26 +00:00
|
|
|
pid := "terraform-" + acctest.RandString(10)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
// Create a new project
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProject_create(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccGoogleProjectExistingPolicy(pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
// Apply an IAM binding
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProjectAssociateMemberBasic(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleProjectIamBindingExists("google_project_iam_member.acceptance", &cloudresourcemanager.Binding{
|
|
|
|
Role: "roles/compute.instanceAdmin",
|
|
|
|
Members: []string{"user:admin@hashicorptest.com"},
|
|
|
|
}, pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
// Apply another IAM binding
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProjectAssociateMemberMultiple(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleProjectIamBindingExists("google_project_iam_member.multiple", &cloudresourcemanager.Binding{
|
|
|
|
Role: "roles/compute.instanceAdmin",
|
|
|
|
Members: []string{"user:admin@hashicorptest.com", "user:paddy@hashicorp.com"},
|
|
|
|
}, pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test that an IAM binding can be removed from a project
|
|
|
|
func TestAccGoogleProjectIamMember_remove(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-11-20 23:45:51 +00:00
|
|
|
org := getTestOrgFromEnv(t)
|
2017-11-21 01:01:39 +00:00
|
|
|
skipIfEnvNotSet(t, "GOOGLE_ORG")
|
|
|
|
|
2017-07-04 03:59:26 +00:00
|
|
|
pid := "terraform-" + acctest.RandString(10)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
// Create a new project
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProject_create(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccGoogleProjectExistingPolicy(pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
// Apply multiple IAM bindings
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProjectAssociateMemberMultiple(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleProjectIamBindingExists("google_project_iam_member.acceptance", &cloudresourcemanager.Binding{
|
|
|
|
Role: "roles/compute.instanceAdmin",
|
|
|
|
Members: []string{"user:admin@hashicorptest.com", "user:paddy@hashicorp.com"},
|
|
|
|
}, pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
// Remove the bindings
|
2017-07-27 20:39:23 +00:00
|
|
|
{
|
2017-07-04 03:59:26 +00:00
|
|
|
Config: testAccGoogleProject_create(pid, pname, org),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccGoogleProjectExistingPolicy(pid),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func testAccGoogleProjectAssociateMemberBasic(pid, name, org string) string {
|
|
|
|
return fmt.Sprintf(`
|
|
|
|
resource "google_project" "acceptance" {
|
2017-07-25 19:17:20 +00:00
|
|
|
project_id = "%s"
|
|
|
|
name = "%s"
|
|
|
|
org_id = "%s"
|
2017-07-04 03:59:26 +00:00
|
|
|
}
|
2017-07-25 19:17:20 +00:00
|
|
|
|
2017-07-04 03:59:26 +00:00
|
|
|
resource "google_project_iam_member" "acceptance" {
|
2017-07-25 19:17:20 +00:00
|
|
|
project = "${google_project.acceptance.project_id}"
|
|
|
|
member = "user:admin@hashicorptest.com"
|
|
|
|
role = "roles/compute.instanceAdmin"
|
2017-07-04 03:59:26 +00:00
|
|
|
}
|
|
|
|
`, pid, name, org)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testAccGoogleProjectAssociateMemberMultiple(pid, name, org string) string {
|
|
|
|
return fmt.Sprintf(`
|
|
|
|
resource "google_project" "acceptance" {
|
2017-07-25 19:17:20 +00:00
|
|
|
project_id = "%s"
|
|
|
|
name = "%s"
|
|
|
|
org_id = "%s"
|
2017-07-04 03:59:26 +00:00
|
|
|
}
|
2017-07-25 19:17:20 +00:00
|
|
|
|
2017-07-04 03:59:26 +00:00
|
|
|
resource "google_project_iam_member" "acceptance" {
|
2017-07-25 19:17:20 +00:00
|
|
|
project = "${google_project.acceptance.project_id}"
|
|
|
|
member = "user:admin@hashicorptest.com"
|
|
|
|
role = "roles/compute.instanceAdmin"
|
2017-07-04 03:59:26 +00:00
|
|
|
}
|
2017-07-25 19:17:20 +00:00
|
|
|
|
2017-07-04 03:59:26 +00:00
|
|
|
resource "google_project_iam_member" "multiple" {
|
2017-07-25 19:17:20 +00:00
|
|
|
project = "${google_project.acceptance.project_id}"
|
|
|
|
member = "user:paddy@hashicorp.com"
|
|
|
|
role = "roles/compute.instanceAdmin"
|
2017-07-04 03:59:26 +00:00
|
|
|
}
|
|
|
|
`, pid, name, org)
|
|
|
|
}
|