terraform-provider-google/google/resource_dataproc_cluster_iam_test.go
The Magician 3b2900519b Add dataproc iam resources (#3632)
Signed-off-by: Modular Magician <magic-modules@google.com>
2019-05-16 11:24:27 -07:00

227 lines
6.2 KiB
Go

package google
import (
"fmt"
"testing"
"github.com/hashicorp/terraform/helper/acctest"
"github.com/hashicorp/terraform/helper/resource"
)
func TestAccDataprocClusterIamBinding(t *testing.T) {
t.Parallel()
cluster := "tf-dataproc-iam-" + acctest.RandString(10)
account := "tf-dataproc-iam-" + acctest.RandString(10)
role := "roles/editor"
importId := fmt.Sprintf("projects/%s/regions/%s/clusters/%s %s",
getTestProjectFromEnv(), "us-central1", cluster, role)
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
Steps: []resource.TestStep{
{
// Test IAM Binding creation
Config: testAccDataprocClusterIamBinding_basic(cluster, account, role),
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr(
"google_dataproc_cluster_iam_binding.binding", "role", role),
),
},
{
ResourceName: "google_dataproc_cluster_iam_binding.binding",
ImportStateId: importId,
ImportState: true,
ImportStateVerify: true,
},
{
// Test IAM Binding update
Config: testAccDataprocClusterIamBinding_update(cluster, account, role),
},
{
ResourceName: "google_dataproc_cluster_iam_binding.binding",
ImportStateId: importId,
ImportState: true,
ImportStateVerify: true,
},
},
})
}
func TestAccDataprocClusterIamMember(t *testing.T) {
t.Parallel()
cluster := "tf-dataproc-iam-" + acctest.RandString(10)
account := "tf-dataproc-iam-" + acctest.RandString(10)
role := "roles/editor"
importId := fmt.Sprintf("projects/%s/regions/%s/clusters/%s %s serviceAccount:%s",
getTestProjectFromEnv(),
"us-central1",
cluster,
role,
serviceAccountCanonicalEmail(account))
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
Steps: []resource.TestStep{
{
// Test IAM Binding creation
Config: testAccDataprocClusterIamMember(cluster, account, role),
Check: resource.ComposeTestCheckFunc(
resource.TestCheckResourceAttr(
"google_dataproc_cluster_iam_member.member", "role", role),
resource.TestCheckResourceAttr(
"google_dataproc_cluster_iam_member.member", "member", "serviceAccount:"+serviceAccountCanonicalEmail(account)),
),
},
{
ResourceName: "google_dataproc_cluster_iam_member.member",
ImportStateId: importId,
ImportState: true,
ImportStateVerify: true,
},
},
})
}
func TestAccDataprocClusterIamPolicy(t *testing.T) {
t.Parallel()
cluster := "tf-dataproc-iam-" + acctest.RandString(10)
account := "tf-dataproc-iam-" + acctest.RandString(10)
role := "roles/editor"
importId := fmt.Sprintf("projects/%s/regions/%s/clusters/%s",
getTestProjectFromEnv(), "us-central1", cluster)
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
Steps: []resource.TestStep{
{
// Test IAM Binding creation
Config: testAccDataprocClusterIamPolicy(cluster, account, role),
},
{
ResourceName: "google_dataproc_cluster_iam_policy.policy",
ImportStateId: importId,
ImportState: true,
ImportStateVerify: true,
},
},
})
}
func testAccDataprocClusterIamBinding_basic(cluster, account, role string) string {
return fmt.Sprintf(testDataprocIamSingleNodeCluster+`
resource "google_service_account" "test-account1" {
account_id = "%s-1"
display_name = "Dataproc IAM Testing Account"
}
resource "google_service_account" "test-account2" {
account_id = "%s-2"
display_name = "Iam Testing Account"
}
resource "google_dataproc_cluster_iam_binding" "binding" {
cluster = "${google_dataproc_cluster.cluster.name}"
region = "us-central1"
role = "%s"
members = [
"serviceAccount:${google_service_account.test-account1.email}",
]
}
`, cluster, account, account, role)
}
func testAccDataprocClusterIamBinding_update(cluster, account, role string) string {
return fmt.Sprintf(testDataprocIamSingleNodeCluster+`
resource "google_service_account" "test-account1" {
account_id = "%s-1"
display_name = "Dataproc IAM Testing Account"
}
resource "google_service_account" "test-account2" {
account_id = "%s-2"
display_name = "Iam Testing Account"
}
resource "google_dataproc_cluster_iam_binding" "binding" {
cluster = "${google_dataproc_cluster.cluster.name}"
region = "us-central1"
role = "%s"
members = [
"serviceAccount:${google_service_account.test-account1.email}",
"serviceAccount:${google_service_account.test-account2.email}",
]
}
`, cluster, account, account, role)
}
func testAccDataprocClusterIamMember(cluster, account, role string) string {
return fmt.Sprintf(testDataprocIamSingleNodeCluster+`
resource "google_service_account" "test-account" {
account_id = "%s"
display_name = "Dataproc IAM Testing Account"
}
resource "google_dataproc_cluster_iam_member" "member" {
cluster = "${google_dataproc_cluster.cluster.name}"
role = "%s"
member = "serviceAccount:${google_service_account.test-account.email}"
}
`, cluster, account, role)
}
func testAccDataprocClusterIamPolicy(cluster, account, role string) string {
return fmt.Sprintf(testDataprocIamSingleNodeCluster+`
resource "google_service_account" "test-account" {
account_id = "%s"
display_name = "Dataproc IAM Testing Account"
}
data "google_iam_policy" "policy" {
binding {
role = "%s"
members = ["serviceAccount:${google_service_account.test-account.email}"]
}
}
resource "google_dataproc_cluster_iam_policy" "policy" {
cluster = "${google_dataproc_cluster.cluster.name}"
region = "us-central1"
policy_data = "${data.google_iam_policy.policy.policy_data}"
}
`, cluster, account, role)
}
// Smallest cluster possible for testing
var testDataprocIamSingleNodeCluster = `
resource "google_dataproc_cluster" "cluster" {
name = "%s"
region = "us-central1"
cluster_config {
# Keep the costs down with smallest config we can get away with
software_config {
override_properties = {
"dataproc:dataproc.allow.zero.workers" = "true"
}
}
master_config {
num_instances = 1
machine_type = "n1-standard-1"
disk_config {
boot_disk_size_gb = 15
}
}
}
}`