// ---------------------------------------------------------------------------- // // *** AUTO GENERATED CODE *** AUTO GENERATED CODE *** // // ---------------------------------------------------------------------------- // // This file is automatically generated by Magic Modules and manual // changes will be clobbered when the file is regenerated. // // Please read more about how to change this file in // .github/CONTRIBUTING.md. // // ---------------------------------------------------------------------------- package google import ( "fmt" "strings" "testing" "github.com/hashicorp/terraform/helper/acctest" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" ) func TestAccDnsManagedZone_dnsManagedZoneBasicExample(t *testing.T) { t.Parallel() context := map[string]interface{}{ "random_suffix": acctest.RandString(10), } resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckDnsManagedZoneDestroy, Steps: []resource.TestStep{ { Config: testAccDnsManagedZone_dnsManagedZoneBasicExample(context), }, { ResourceName: "google_dns_managed_zone.example-zone", ImportState: true, ImportStateVerify: true, }, }, }) } func testAccDnsManagedZone_dnsManagedZoneBasicExample(context map[string]interface{}) string { return Nprintf(` resource "google_dns_managed_zone" "example-zone" { name = "example-zone" dns_name = "example-${random_id.rnd.hex}.com." description = "Example DNS zone" labels = { foo = "bar" } } resource "random_id" "rnd" { byte_length = 4 } `, context) } func TestAccDnsManagedZone_dnsManagedZonePrivateExample(t *testing.T) { t.Parallel() context := map[string]interface{}{ "random_suffix": acctest.RandString(10), } resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckDnsManagedZoneDestroy, Steps: []resource.TestStep{ { Config: testAccDnsManagedZone_dnsManagedZonePrivateExample(context), }, { ResourceName: "google_dns_managed_zone.private-zone", ImportState: true, ImportStateVerify: true, }, }, }) } func testAccDnsManagedZone_dnsManagedZonePrivateExample(context map[string]interface{}) string { return Nprintf(` resource "google_dns_managed_zone" "private-zone" { name = "private-zone-%{random_suffix}" dns_name = "private.example.com." description = "Example private DNS zone" labels = { foo = "bar" } visibility = "private" private_visibility_config { networks { network_url = "${google_compute_network.network-1.self_link}" } networks { network_url = "${google_compute_network.network-2.self_link}" } } } resource "google_compute_network" "network-1" { name = "network-1-%{random_suffix}" auto_create_subnetworks = false } resource "google_compute_network" "network-2" { name = "network-2-%{random_suffix}" auto_create_subnetworks = false } `, context) } func testAccCheckDnsManagedZoneDestroy(s *terraform.State) error { for name, rs := range s.RootModule().Resources { if rs.Type != "google_dns_managed_zone" { continue } if strings.HasPrefix(name, "data.") { continue } config := testAccProvider.Meta().(*Config) url, err := replaceVarsForTest(rs, "https://www.googleapis.com/dns/v1/projects/{{project}}/managedZones/{{name}}") if err != nil { return err } _, err = sendRequest(config, "GET", url, nil) if err == nil { return fmt.Errorf("DnsManagedZone still exists at %s", url) } } return nil }