|
|
|
|
@ -8,6 +8,7 @@ import (
|
|
|
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
|
"google.golang.org/api/compute/v1"
|
|
|
|
|
"strings"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestAccComputeInstanceTemplate_basic(t *testing.T) {
|
|
|
|
|
@ -73,6 +74,47 @@ func TestAccComputeInstanceTemplate_disks(t *testing.T) {
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestAccComputeInstanceTemplate_subnet_auto(t *testing.T) {
|
|
|
|
|
var instanceTemplate compute.InstanceTemplate
|
|
|
|
|
network := "network-" + acctest.RandString(10)
|
|
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
CheckDestroy: testAccCheckComputeInstanceTemplateDestroy,
|
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
|
resource.TestStep{
|
|
|
|
|
Config: testAccComputeInstanceTemplate_subnet_auto(network),
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
|
testAccCheckComputeInstanceTemplateExists(
|
|
|
|
|
"google_compute_instance_template.foobar", &instanceTemplate),
|
|
|
|
|
testAccCheckComputeInstanceTemplateNetworkName(&instanceTemplate, network),
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestAccComputeInstanceTemplate_subnet_custom(t *testing.T) {
|
|
|
|
|
var instanceTemplate compute.InstanceTemplate
|
|
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
CheckDestroy: testAccCheckComputeInstanceTemplateDestroy,
|
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
|
resource.TestStep{
|
|
|
|
|
Config: testAccComputeInstanceTemplate_subnet_custom,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
|
testAccCheckComputeInstanceTemplateExists(
|
|
|
|
|
"google_compute_instance_template.foobar", &instanceTemplate),
|
|
|
|
|
testAccCheckComputeInstanceTemplateSubnetwork(&instanceTemplate),
|
|
|
|
|
),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccCheckComputeInstanceTemplateDestroy(s *terraform.State) error {
|
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
|
|
|
|
|
|
@ -158,6 +200,18 @@ func testAccCheckComputeInstanceTemplateNetwork(instanceTemplate *compute.Instan
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccCheckComputeInstanceTemplateNetworkName(instanceTemplate *compute.InstanceTemplate, network string) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
for _, i := range instanceTemplate.Properties.NetworkInterfaces {
|
|
|
|
|
if !strings.Contains(i.Network, network) {
|
|
|
|
|
return fmt.Errorf("Network doesn't match expected value, Expected: %s Actual: %s", network, i.Network[strings.LastIndex("/", i.Network)+1:])
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccCheckComputeInstanceTemplateDisk(instanceTemplate *compute.InstanceTemplate, source string, delete bool, boot bool) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if instanceTemplate.Properties.Disks == nil {
|
|
|
|
|
@ -186,6 +240,18 @@ func testAccCheckComputeInstanceTemplateDisk(instanceTemplate *compute.InstanceT
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccCheckComputeInstanceTemplateSubnetwork(instanceTemplate *compute.InstanceTemplate) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
for _, i := range instanceTemplate.Properties.NetworkInterfaces {
|
|
|
|
|
if i.Subnetwork == "" {
|
|
|
|
|
return fmt.Errorf("no subnet")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccCheckComputeInstanceTemplateTag(instanceTemplate *compute.InstanceTemplate, n string) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if instanceTemplate.Properties.Tags == nil {
|
|
|
|
|
@ -293,3 +359,65 @@ resource "google_compute_instance_template" "foobar" {
|
|
|
|
|
foo = "bar"
|
|
|
|
|
}
|
|
|
|
|
}`, acctest.RandString(10), acctest.RandString(10))
|
|
|
|
|
|
|
|
|
|
func testAccComputeInstanceTemplate_subnet_auto(network string) string {
|
|
|
|
|
return fmt.Sprintf(`
|
|
|
|
|
resource "google_compute_network" "auto-network" {
|
|
|
|
|
name = "%s"
|
|
|
|
|
auto_create_subnetworks = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
resource "google_compute_instance_template" "foobar" {
|
|
|
|
|
name = "instance-tpl-%s"
|
|
|
|
|
machine_type = "n1-standard-1"
|
|
|
|
|
|
|
|
|
|
disk {
|
|
|
|
|
source_image = "debian-7-wheezy-v20160211"
|
|
|
|
|
auto_delete = true
|
|
|
|
|
disk_size_gb = 10
|
|
|
|
|
boot = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
network_interface {
|
|
|
|
|
network = "${google_compute_network.auto-network.name}"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
metadata {
|
|
|
|
|
foo = "bar"
|
|
|
|
|
}
|
|
|
|
|
}`, network, acctest.RandString(10))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var testAccComputeInstanceTemplate_subnet_custom = fmt.Sprintf(`
|
|
|
|
|
resource "google_compute_network" "network" {
|
|
|
|
|
name = "network-%s"
|
|
|
|
|
auto_create_subnetworks = false
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
resource "google_compute_subnetwork" "subnetwork" {
|
|
|
|
|
name = "subnetwork-%s"
|
|
|
|
|
ip_cidr_range = "10.0.0.0/24"
|
|
|
|
|
region = "us-central1"
|
|
|
|
|
network = "${google_compute_network.network.self_link}"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
resource "google_compute_instance_template" "foobar" {
|
|
|
|
|
name = "instance-test-%s"
|
|
|
|
|
machine_type = "n1-standard-1"
|
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
|
|
disk {
|
|
|
|
|
source_image = "debian-7-wheezy-v20160211"
|
|
|
|
|
auto_delete = true
|
|
|
|
|
disk_size_gb = 10
|
|
|
|
|
boot = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
network_interface {
|
|
|
|
|
subnetwork = "${google_compute_subnetwork.subnetwork.name}"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
metadata {
|
|
|
|
|
foo = "bar"
|
|
|
|
|
}
|
|
|
|
|
}`, acctest.RandString(10), acctest.RandString(10), acctest.RandString(10))
|
|
|
|
|
|