builder/googlecompute: -force

This commit is contained in:
Valentin Tjoncke 2016-09-23 14:21:43 +02:00
parent fcaae838fc
commit 6f545af7f7
3 changed files with 29 additions and 13 deletions

View File

@ -52,6 +52,7 @@ type Config struct {
Account AccountFile
privateKeyBytes []byte
stateTimeout time.Duration
imageAlreadyExists bool
ctx interpolate.Context
}

View File

@ -17,15 +17,17 @@ func (s *StepCheckExistingImage) Run(state multistep.StateBag) multistep.StepAct
d := state.Get("driver").(Driver)
ui := state.Get("ui").(packer.Ui)
if !c.PackerForce {
ui.Say("Checking image does not exist...")
exists := d.ImageExists(c.ImageName)
if exists {
err := fmt.Errorf("Image %s already exists", c.ImageName)
c.imageAlreadyExists = d.ImageExists(c.ImageName)
if c.imageAlreadyExists {
err := fmt.Errorf("Image %s already exists.\n"+
"Use the force flag to delete it prior to building.", c.ImageName)
state.Put("error", err)
ui.Error(err.Error())
return multistep.ActionHalt
}
}
return multistep.ActionContinue
}

View File

@ -22,6 +22,19 @@ func (s *StepCreateImage) Run(state multistep.StateBag) multistep.StepAction {
driver := state.Get("driver").(Driver)
ui := state.Get("ui").(packer.Ui)
if config.PackerForce && config.imageAlreadyExists {
ui.Say("Deleting previous image...")
errCh := driver.DeleteImage(config.ImageName)
err := <-errCh
if err != nil {
err := fmt.Errorf("Error deleting image: %s", err)
state.Put("error", err)
ui.Error(err.Error())
return multistep.ActionHalt
}
}
ui.Say("Creating image...")
imageCh, errCh := driver.CreateImage(