2013-12-13 21:26:00 -05:00
|
|
|
package googlecompute
|
|
|
|
|
|
|
|
import (
|
2014-11-24 11:36:14 -05:00
|
|
|
"errors"
|
2013-12-13 21:26:00 -05:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mitchellh/multistep"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestStepCreateImage_impl(t *testing.T) {
|
|
|
|
var _ multistep.Step = new(StepCreateImage)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepCreateImage(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepCreateImage)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
2014-11-24 11:36:14 -05:00
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
2016-05-24 20:13:36 -04:00
|
|
|
driver.CreateImageProjectId = "createimage-project"
|
|
|
|
driver.CreateImageSizeGb = 100
|
2013-12-13 21:26:00 -05:00
|
|
|
|
|
|
|
// run the step
|
|
|
|
if action := step.Run(state); action != multistep.ActionContinue {
|
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
2016-05-24 20:13:36 -04:00
|
|
|
|
|
|
|
uncastImage, ok := state.GetOk("image")
|
|
|
|
if !ok {
|
|
|
|
t.Fatal("should have image")
|
|
|
|
}
|
|
|
|
image, ok := uncastImage.(Image)
|
|
|
|
if !ok {
|
|
|
|
t.Fatal("image is not an Image")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify created Image results.
|
|
|
|
if image.Name != config.ImageName {
|
|
|
|
t.Fatalf("Created image name, %s, does not match config name, %s.", image.Name, config.ImageName)
|
|
|
|
}
|
|
|
|
if driver.CreateImageProjectId != image.ProjectId {
|
|
|
|
t.Fatalf("Created image project ID, %s, does not match driver project ID, %s.", image.ProjectId, driver.CreateImageProjectId)
|
|
|
|
}
|
|
|
|
if driver.CreateImageSizeGb != image.SizeGb {
|
|
|
|
t.Fatalf("Created image size, %d, does not match the expected test value, %d.", image.SizeGb, driver.CreateImageSizeGb)
|
|
|
|
}
|
2013-12-13 21:26:00 -05:00
|
|
|
|
2016-05-24 20:13:36 -04:00
|
|
|
// Verify proper args passed to driver.CreateImage.
|
2014-11-24 11:36:14 -05:00
|
|
|
if driver.CreateImageName != config.ImageName {
|
|
|
|
t.Fatalf("bad: %#v", driver.CreateImageName)
|
|
|
|
}
|
|
|
|
if driver.CreateImageDesc != config.ImageDescription {
|
|
|
|
t.Fatalf("bad: %#v", driver.CreateImageDesc)
|
2013-12-13 21:26:00 -05:00
|
|
|
}
|
2016-05-06 07:43:39 -04:00
|
|
|
if driver.CreateImageFamily != config.ImageFamily {
|
|
|
|
t.Fatalf("bad: %#v", driver.CreateImageFamily)
|
|
|
|
}
|
2014-11-24 11:36:14 -05:00
|
|
|
if driver.CreateImageZone != config.Zone {
|
|
|
|
t.Fatalf("bad: %#v", driver.CreateImageZone)
|
2013-12-13 21:26:00 -05:00
|
|
|
}
|
2014-11-24 11:36:14 -05:00
|
|
|
if driver.CreateImageDisk != config.DiskName {
|
|
|
|
t.Fatalf("bad: %#v", driver.CreateImageDisk)
|
2013-12-13 21:26:00 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-11-24 11:36:14 -05:00
|
|
|
func TestStepCreateImage_errorOnChannel(t *testing.T) {
|
2013-12-13 21:26:00 -05:00
|
|
|
state := testState(t)
|
|
|
|
step := new(StepCreateImage)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
2014-11-24 11:36:14 -05:00
|
|
|
errCh := make(chan error, 1)
|
|
|
|
errCh <- errors.New("error")
|
|
|
|
|
|
|
|
driver := state.Get("driver").(*DriverMock)
|
|
|
|
driver.CreateImageErrCh = errCh
|
2013-12-13 21:26:00 -05:00
|
|
|
|
|
|
|
// run the step
|
|
|
|
if action := step.Run(state); action != multistep.ActionHalt {
|
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, ok := state.GetOk("error"); !ok {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
2014-11-24 11:36:14 -05:00
|
|
|
if _, ok := state.GetOk("image_name"); ok {
|
2013-12-13 21:26:00 -05:00
|
|
|
t.Fatal("should NOT have image")
|
|
|
|
}
|
|
|
|
}
|