2013-12-13 16:01:28 -05:00
|
|
|
package googlecompute
|
|
|
|
|
|
|
|
import (
|
2018-01-22 19:03:49 -05:00
|
|
|
"context"
|
2013-12-13 16:01:28 -05:00
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
"time"
|
2018-01-22 20:21:10 -05:00
|
|
|
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2013-12-13 16:01:28 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestStepInstanceInfo_impl(t *testing.T) {
|
|
|
|
var _ multistep.Step = new(StepInstanceInfo)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepInstanceInfo(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepInstanceInfo)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
state.Put("instance_name", "foo")
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.GetNatIPResult = "1.2.3.4"
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionContinue {
|
2013-12-13 16:01:28 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify state
|
|
|
|
if driver.WaitForInstanceState != "RUNNING" {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceState)
|
|
|
|
}
|
|
|
|
if driver.WaitForInstanceZone != config.Zone {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceZone)
|
|
|
|
}
|
|
|
|
if driver.WaitForInstanceName != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceName)
|
|
|
|
}
|
|
|
|
|
|
|
|
ipRaw, ok := state.GetOk("instance_ip")
|
|
|
|
if !ok {
|
|
|
|
t.Fatal("should have ip")
|
|
|
|
}
|
|
|
|
if ip, ok := ipRaw.(string); !ok {
|
|
|
|
t.Fatal("ip is not a string")
|
|
|
|
} else if ip != "1.2.3.4" {
|
|
|
|
t.Fatalf("bad ip: %s", ip)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-29 17:50:11 -04:00
|
|
|
func TestStepInstanceInfo_InternalIP(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepInstanceInfo)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
state.Put("instance_name", "foo")
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
config.UseInternalIP = true
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.GetNatIPResult = "1.2.3.4"
|
|
|
|
driver.GetInternalIPResult = "5.6.7.8"
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionContinue {
|
2015-05-29 17:50:11 -04:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify state
|
|
|
|
if driver.WaitForInstanceState != "RUNNING" {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceState)
|
|
|
|
}
|
|
|
|
if driver.WaitForInstanceZone != config.Zone {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceZone)
|
|
|
|
}
|
|
|
|
if driver.WaitForInstanceName != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", driver.WaitForInstanceName)
|
|
|
|
}
|
|
|
|
|
|
|
|
ipRaw, ok := state.GetOk("instance_ip")
|
|
|
|
if !ok {
|
|
|
|
t.Fatal("should have ip")
|
|
|
|
}
|
|
|
|
if ip, ok := ipRaw.(string); !ok {
|
|
|
|
t.Fatal("ip is not a string")
|
|
|
|
} else if ip != "5.6.7.8" {
|
|
|
|
t.Fatalf("bad ip: %s", ip)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-13 16:01:28 -05:00
|
|
|
func TestStepInstanceInfo_getNatIPError(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepInstanceInfo)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
state.Put("instance_name", "foo")
|
|
|
|
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.GetNatIPErr = errors.New("error")
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionHalt {
|
2013-12-13 16:01:28 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify state
|
|
|
|
if _, ok := state.GetOk("error"); !ok {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
if _, ok := state.GetOk("instance_ip"); ok {
|
|
|
|
t.Fatal("should NOT have instance IP")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepInstanceInfo_waitError(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepInstanceInfo)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
state.Put("instance_name", "foo")
|
|
|
|
|
|
|
|
errCh := make(chan error, 1)
|
|
|
|
errCh <- errors.New("error")
|
|
|
|
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.WaitForInstanceErrCh = errCh
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionHalt {
|
2013-12-13 16:01:28 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify state
|
|
|
|
if _, ok := state.GetOk("error"); !ok {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
if _, ok := state.GetOk("instance_ip"); ok {
|
|
|
|
t.Fatal("should NOT have instance IP")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepInstanceInfo_errorTimeout(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepInstanceInfo)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
errCh := make(chan error, 1)
|
|
|
|
go func() {
|
2019-08-21 19:36:42 -04:00
|
|
|
<-time.After(50 * time.Millisecond)
|
2013-12-13 16:01:28 -05:00
|
|
|
errCh <- nil
|
|
|
|
}()
|
|
|
|
|
|
|
|
state.Put("instance_name", "foo")
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
2019-10-31 10:49:34 -04:00
|
|
|
config.StateTimeout = 1 * time.Millisecond
|
2013-12-13 16:01:28 -05:00
|
|
|
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.WaitForInstanceErrCh = errCh
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionHalt {
|
2013-12-13 16:01:28 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify state
|
|
|
|
if _, ok := state.GetOk("error"); !ok {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
if _, ok := state.GetOk("instance_ip"); ok {
|
|
|
|
t.Fatal("should NOT have instance IP")
|
|
|
|
}
|
|
|
|
}
|