package google import ( "fmt" "testing" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" "google.golang.org/api/compute/v1" ) func TestAccComputeVpnTunnel_basic(t *testing.T) { resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckComputeVpnTunnelDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: testAccComputeVpnTunnel_basic, Check: resource.ComposeTestCheckFunc( testAccCheckComputeVpnTunnelExists( "google_compute_vpn_tunnel.foobar"), ), }, }, }) } func testAccCheckComputeVpnTunnelDestroy(s *terraform.State) error { config := testAccProvider.Meta().(*Config) project := config.Project vpnTunnelsService := compute.NewVpnTunnelsService(config.clientCompute) for _, rs := range s.RootModule().Resources { if rs.Type != "google_compute_network" { continue } region := rs.Primary.Attributes["region"] name := rs.Primary.Attributes["name"] _, err := vpnTunnelsService.Get(project, region, name).Do() if err == nil { return fmt.Errorf("Error, VPN Tunnel %s in region %s still exists", name, region) } } return nil } func testAccCheckComputeVpnTunnelExists(n string) 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) name := rs.Primary.Attributes["name"] region := rs.Primary.Attributes["region"] project := config.Project vpnTunnelsService := compute.NewVpnTunnelsService(config.clientCompute) _, err := vpnTunnelsService.Get(project, region, name).Do() if err != nil { return fmt.Errorf("Error Reading VPN Tunnel %s: %s", name, err) } return nil } } const testAccComputeVpnTunnel_basic = ` resource "google_compute_network" "foobar" { name = "tf-test-network" ipv4_range = "10.0.0.0/16" } resource "google_compute_address" "foobar" { name = "tf-test-static-ip" region = "us-central1" } resource "google_compute_vpn_gateway" "foobar" { name = "tf-test-vpn-gateway" network = "${google_compute_network.foobar.self_link}" region = "${google_compute_address.foobar.region}" } resource "google_compute_forwarding_rule" "foobar_esp" { name = "tf-test-fr-esp" region = "${google_compute_vpn_gateway.foobar.region}" ip_protocol = "ESP" ip_address = "${google_compute_address.foobar.address}" target = "${google_compute_vpn_gateway.foobar.self_link}" } resource "google_compute_forwarding_rule" "foobar_udp500" { name = "tf-test-fr-udp500" region = "${google_compute_forwarding_rule.foobar_esp.region}" ip_protocol = "UDP" port_range = "500" ip_address = "${google_compute_address.foobar.address}" target = "${google_compute_vpn_gateway.foobar.self_link}" } resource "google_compute_forwarding_rule" "foobar_udp4500" { name = "tf-test-fr-udp4500" region = "${google_compute_forwarding_rule.foobar_udp500.region}" ip_protocol = "UDP" port_range = "4500" ip_address = "${google_compute_address.foobar.address}" target = "${google_compute_vpn_gateway.foobar.self_link}" } resource "google_compute_vpn_tunnel" "foobar" { name = "tf-test-vpn-tunnel" region = "${google_compute_forwarding_rule.foobar_udp4500.region}" target_vpn_gateway = "${google_compute_vpn_gateway.foobar.self_link}" shared_secret = "unguessable" peer_ip = "0.0.0.0" }`