mirror of
https://github.com/letic/terraform-provider-google.git
synced 2024-10-15 07:27:15 +00:00
0bcb01266c
Adds support for log exclusions in billingAccounts, organizations, folders and projects, see: https://cloud.google.com/logging/docs/exclusions ``` ==> Checking that code complies with gofmt requirements... TF_ACC=1 go test ./google -v -run=Exclusion -timeout 120m === RUN TestAccLoggingBillingAccountExclusion_basic === PAUSE TestAccLoggingBillingAccountExclusion_basic === RUN TestAccLoggingBillingAccountExclusion_update === PAUSE TestAccLoggingBillingAccountExclusion_update === RUN TestAccLoggingFolderExclusion_basic === PAUSE TestAccLoggingFolderExclusion_basic === RUN TestAccLoggingFolderExclusion_folderAcceptsFullFolderPath === PAUSE TestAccLoggingFolderExclusion_folderAcceptsFullFolderPath === RUN TestAccLoggingFolderExclusion_update === PAUSE TestAccLoggingFolderExclusion_update === RUN TestAccLoggingOrganizationExclusion_basic === PAUSE TestAccLoggingOrganizationExclusion_basic === RUN TestAccLoggingOrganizationExclusion_update === PAUSE TestAccLoggingOrganizationExclusion_update === RUN TestAccLoggingProjectExclusion_basic === PAUSE TestAccLoggingProjectExclusion_basic === RUN TestAccLoggingProjectExclusion_disablePreservesFilter === PAUSE TestAccLoggingProjectExclusion_disablePreservesFilter === RUN TestAccLoggingProjectExclusion_update === PAUSE TestAccLoggingProjectExclusion_update === CONT TestAccLoggingBillingAccountExclusion_basic === CONT TestAccLoggingOrganizationExclusion_update === CONT TestAccLoggingProjectExclusion_update === CONT TestAccLoggingFolderExclusion_folderAcceptsFullFolderPath === CONT TestAccLoggingOrganizationExclusion_basic --- PASS: TestAccLoggingProjectExclusion_update (3.60s) --- PASS: TestAccLoggingOrganizationExclusion_update (4.40s) === CONT TestAccLoggingFolderExclusion_update --- PASS: TestAccLoggingOrganizationExclusion_basic (1.90s) === CONT TestAccLoggingFolderExclusion_basic --- PASS: TestAccLoggingBillingAccountExclusion_basic (6.21s) === CONT TestAccLoggingBillingAccountExclusion_update --- PASS: TestAccLoggingBillingAccountExclusion_update (5.90s) === CONT TestAccLoggingProjectExclusion_disablePreservesFilter --- PASS: TestAccLoggingProjectExclusion_disablePreservesFilter (3.90s) === CONT TestAccLoggingProjectExclusion_basic --- PASS: TestAccLoggingFolderExclusion_folderAcceptsFullFolderPath (16.67s) --- PASS: TestAccLoggingProjectExclusion_basic (1.96s) --- PASS: TestAccLoggingFolderExclusion_basic (15.30s) --- PASS: TestAccLoggingFolderExclusion_update (18.35s) PASS ok github.com/terraform-providers/terraform-provider-google/google 22.810s ```
226 lines
7.4 KiB
Go
226 lines
7.4 KiB
Go
package google
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
"google.golang.org/api/logging/v2"
|
|
)
|
|
|
|
func TestAccLoggingProjectExclusion_basic(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
exclusionName := "tf-test-exclusion-" + acctest.RandString(10)
|
|
|
|
var exclusion logging.LogExclusion
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckLoggingProjectExclusionDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccLoggingProjectExclusion_basic(exclusionName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckLoggingProjectExclusionExists("google_logging_project_exclusion.basic", &exclusion),
|
|
testAccCheckLoggingProjectExclusion(&exclusion, "google_logging_project_exclusion.basic")),
|
|
},
|
|
{
|
|
ResourceName: "google_logging_project_exclusion.basic",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccLoggingProjectExclusion_disablePreservesFilter(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
exclusionName := "tf-test-exclusion-" + acctest.RandString(10)
|
|
|
|
var exclusionBefore, exclusionAfter logging.LogExclusion
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckLoggingProjectExclusionDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccLoggingProjectExclusion_basic(exclusionName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckLoggingProjectExclusionExists("google_logging_project_exclusion.basic", &exclusionBefore),
|
|
testAccCheckLoggingProjectExclusion(&exclusionBefore, "google_logging_project_exclusion.basic"),
|
|
),
|
|
},
|
|
{
|
|
Config: testAccLoggingProjectExclusion_basicDisabled(exclusionName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckLoggingProjectExclusionExists("google_logging_project_exclusion.basic", &exclusionAfter),
|
|
testAccCheckLoggingProjectExclusion(&exclusionAfter, "google_logging_project_exclusion.basic"),
|
|
),
|
|
},
|
|
{
|
|
ResourceName: "google_logging_project_exclusion.basic",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
|
|
// Description and Disabled should have changed, but Filter should be the same
|
|
if exclusionBefore.Description == exclusionAfter.Description {
|
|
t.Errorf("Expected Description to change, but it didn't: Description = %#v", exclusionBefore.Description)
|
|
}
|
|
if exclusionBefore.Filter != exclusionAfter.Filter {
|
|
t.Errorf("Expected Filter to be the same, but it differs: before = %#v, after = %#v",
|
|
exclusionBefore.Filter, exclusionAfter.Filter)
|
|
}
|
|
if exclusionBefore.Disabled == exclusionAfter.Disabled {
|
|
t.Errorf("Expected Disabled to change, but it didn't: Disabled = %#v", exclusionBefore.Disabled)
|
|
}
|
|
}
|
|
|
|
func TestAccLoggingProjectExclusion_update(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
exclusionName := "tf-test-exclusion-" + acctest.RandString(10)
|
|
|
|
var exclusionBefore, exclusionAfter logging.LogExclusion
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckLoggingProjectExclusionDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccLoggingProjectExclusion_basic(exclusionName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckLoggingProjectExclusionExists("google_logging_project_exclusion.basic", &exclusionBefore),
|
|
testAccCheckLoggingProjectExclusion(&exclusionBefore, "google_logging_project_exclusion.basic"),
|
|
),
|
|
},
|
|
{
|
|
Config: testAccLoggingProjectExclusion_basicUpdated(exclusionName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckLoggingProjectExclusionExists("google_logging_project_exclusion.basic", &exclusionAfter),
|
|
testAccCheckLoggingProjectExclusion(&exclusionAfter, "google_logging_project_exclusion.basic"),
|
|
),
|
|
},
|
|
{
|
|
ResourceName: "google_logging_project_exclusion.basic",
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
|
|
// Filter should have changed, but Description and Disabled should be the same
|
|
if exclusionBefore.Description != exclusionAfter.Description {
|
|
t.Errorf("Expected Description to be the same, but it differs: before = %#v, after = %#v",
|
|
exclusionBefore.Description, exclusionAfter.Description)
|
|
}
|
|
if exclusionBefore.Filter == exclusionAfter.Filter {
|
|
t.Errorf("Expected Filter to change, but it didn't: Filter = %#v", exclusionBefore.Filter)
|
|
}
|
|
if exclusionBefore.Disabled != exclusionAfter.Disabled {
|
|
t.Errorf("Expected Disabled to be the same, but it differs: before = %#v, after = %#v",
|
|
exclusionBefore.Disabled, exclusionAfter.Disabled)
|
|
}
|
|
}
|
|
|
|
func testAccCheckLoggingProjectExclusionDestroy(s *terraform.State) error {
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
if rs.Type != "google_logging_project_exclusion" {
|
|
continue
|
|
}
|
|
|
|
attributes := rs.Primary.Attributes
|
|
|
|
_, err := config.clientLogging.Projects.Exclusions.Get(attributes["id"]).Do()
|
|
if err == nil {
|
|
return fmt.Errorf("project exclusion still exists")
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func testAccCheckLoggingProjectExclusionExists(n string, exclusion *logging.LogExclusion) resource.TestCheckFunc {
|
|
return func(s *terraform.State) error {
|
|
attributes, err := getResourceAttributes(n, s)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
si, err := config.clientLogging.Projects.Exclusions.Get(attributes["id"]).Do()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
*exclusion = *si
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccCheckLoggingProjectExclusion(exclusion *logging.LogExclusion, n string) resource.TestCheckFunc {
|
|
return func(s *terraform.State) error {
|
|
attributes, err := getResourceAttributes(n, s)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if exclusion.Description != attributes["description"] {
|
|
return fmt.Errorf("mismatch on description: api has %s but client has %s", exclusion.Description, attributes["description"])
|
|
}
|
|
|
|
if exclusion.Filter != attributes["filter"] {
|
|
return fmt.Errorf("mismatch on filter: api has %s but client has %s", exclusion.Filter, attributes["filter"])
|
|
}
|
|
|
|
disabledAttribute, err := toBool(attributes["disabled"])
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if exclusion.Disabled != disabledAttribute {
|
|
return fmt.Errorf("mismatch on disabled: api has %t but client has %t", exclusion.Disabled, disabledAttribute)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccLoggingProjectExclusion_basic(name string) string {
|
|
return fmt.Sprintf(`
|
|
resource "google_logging_project_exclusion" "basic" {
|
|
name = "%s"
|
|
description = "Basic Project Logging Exclusion"
|
|
filter = "logName=\"projects/%s/logs/compute.googleapis.com%%2Factivity_log\" AND severity>=ERROR"
|
|
}`, name, getTestProjectFromEnv())
|
|
}
|
|
|
|
func testAccLoggingProjectExclusion_basicUpdated(name string) string {
|
|
return fmt.Sprintf(`
|
|
resource "google_logging_project_exclusion" "basic" {
|
|
name = "%s"
|
|
description = "Basic Project Logging Exclusion"
|
|
filter = "logName=\"projects/%s/logs/compute.googleapis.com%%2Factivity_log\" AND severity>=INFO"
|
|
}`, name, getTestProjectFromEnv())
|
|
}
|
|
|
|
func testAccLoggingProjectExclusion_basicDisabled(name string) string {
|
|
return fmt.Sprintf(`
|
|
resource "google_logging_project_exclusion" "basic" {
|
|
name = "%s"
|
|
description = ""
|
|
filter = "logName=\"projects/%s/logs/compute.googleapis.com%%2Factivity_log\" AND severity>=ERROR"
|
|
disabled = true
|
|
}`, name, getTestProjectFromEnv())
|
|
}
|