Commit 587f057b authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

builder/googlecompute: StepUploadImage

parent 20a074b4
...@@ -60,9 +60,9 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe ...@@ -60,9 +60,9 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
new(common.StepProvision), new(common.StepProvision),
new(StepUpdateGsutil), new(StepUpdateGsutil),
new(StepCreateImage), new(StepCreateImage),
new(StepUploadImage),
} }
/* /*
new(stepUploadImage),
new(stepRegisterImage), new(stepRegisterImage),
}*/ }*/
......
...@@ -7,34 +7,39 @@ import ( ...@@ -7,34 +7,39 @@ import (
"github.com/mitchellh/packer/packer" "github.com/mitchellh/packer/packer"
) )
// stepUploadImage represents a Packer build step that uploads GCE machine images. // StepUploadImage represents a Packer build step that uploads GCE machine images.
type stepUploadImage int type StepUploadImage int
// Run executes the Packer build step that uploads a GCE machine image. // Run executes the Packer build step that uploads a GCE machine image.
func (s *stepUploadImage) Run(state multistep.StateBag) multistep.StepAction { func (s *StepUploadImage) Run(state multistep.StateBag) multistep.StepAction {
var ( comm := state.Get("communicator").(packer.Communicator)
config = state.Get("config").(*Config) config := state.Get("config").(*Config)
comm = state.Get("communicator").(packer.Communicator) imageFilename := state.Get("image_file_name").(string)
sudoPrefix = "" ui := state.Get("ui").(packer.Ui)
ui = state.Get("ui").(packer.Ui)
imageFilename = state.Get("image_file_name").(string) sudoPrefix := ""
)
ui.Say("Uploading image...")
if config.SSHUsername != "root" { if config.SSHUsername != "root" {
sudoPrefix = "sudo " sudoPrefix = "sudo "
} }
ui.Say("Uploading image...")
cmd := new(packer.RemoteCmd) cmd := new(packer.RemoteCmd)
cmd.Command = fmt.Sprintf("%s/usr/local/bin/gsutil cp %s gs://%s", cmd.Command = fmt.Sprintf("%s/usr/local/bin/gsutil cp %s gs://%s",
sudoPrefix, imageFilename, config.BucketName) sudoPrefix, imageFilename, config.BucketName)
err := cmd.StartWithUi(comm, ui) err := cmd.StartWithUi(comm, ui)
if err == nil && cmd.ExitStatus != 0 {
err = fmt.Errorf(
"gsutil exited with non-zero exit status: %d", cmd.ExitStatus)
}
if err != nil { if err != nil {
err := fmt.Errorf("Error uploading image: %s", err) err := fmt.Errorf("Error uploading image: %s", err)
state.Put("error", err) state.Put("error", err)
ui.Error(err.Error()) ui.Error(err.Error())
return multistep.ActionHalt return multistep.ActionHalt
} }
return multistep.ActionContinue return multistep.ActionContinue
} }
// Cleanup. // Cleanup.
func (s *stepUploadImage) Cleanup(state multistep.StateBag) {} func (s *StepUploadImage) Cleanup(state multistep.StateBag) {}
package googlecompute
import (
"strings"
"testing"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
)
func TestStepUploadImage_impl(t *testing.T) {
var _ multistep.Step = new(StepUploadImage)
}
func TestStepUploadImage(t *testing.T) {
state := testState(t)
step := new(StepUploadImage)
defer step.Cleanup(state)
comm := new(packer.MockCommunicator)
state.Put("communicator", comm)
state.Put("image_file_name", "foo")
// run the step
if action := step.Run(state); action != multistep.ActionContinue {
t.Fatalf("bad action: %#v", action)
}
// Verify
if !comm.StartCalled {
t.Fatal("start should be called")
}
if strings.HasPrefix(comm.StartCmd.Command, "sudo") {
t.Fatal("should not sudo")
}
if !strings.Contains(comm.StartCmd.Command, "gsutil cp") {
t.Fatalf("bad command: %#v", comm.StartCmd.Command)
}
}
func TestStepUploadImage_badExitStatus(t *testing.T) {
state := testState(t)
step := new(StepUploadImage)
defer step.Cleanup(state)
comm := new(packer.MockCommunicator)
comm.StartExitStatus = 12
state.Put("communicator", comm)
state.Put("image_file_name", "foo")
// 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")
}
}
func TestStepUploadImage_nonRoot(t *testing.T) {
state := testState(t)
step := new(StepUploadImage)
defer step.Cleanup(state)
comm := new(packer.MockCommunicator)
state.Put("communicator", comm)
state.Put("image_file_name", "foo")
config := state.Get("config").(*Config)
config.SSHUsername = "bob"
// run the step
if action := step.Run(state); action != multistep.ActionContinue {
t.Fatalf("bad action: %#v", action)
}
// Verify
if !comm.StartCalled {
t.Fatal("start should be called")
}
if !strings.HasPrefix(comm.StartCmd.Command, "sudo") {
t.Fatal("should sudo")
}
if !strings.Contains(comm.StartCmd.Command, "gsutil cp") {
t.Fatalf("bad command: %#v", comm.StartCmd.Command)
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment