provisioner/shell: retry the upload if command fails as well
This improves reboot handling robustness
This commit is contained in:
parent
f4f433d0d8
commit
99a7116939
|
@ -236,17 +236,6 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
}
|
}
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
log.Printf("Uploading %s => %s", path, p.config.RemotePath)
|
|
||||||
err = p.retryable(func() error {
|
|
||||||
return comm.Upload(p.config.RemotePath, f)
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("Error uploading shell script: %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Close the original file since we copied it
|
|
||||||
f.Close()
|
|
||||||
|
|
||||||
// Flatten the environment variables
|
// Flatten the environment variables
|
||||||
flattendVars := strings.Join(envVars, " ")
|
flattendVars := strings.Join(envVars, " ")
|
||||||
|
|
||||||
|
@ -259,16 +248,31 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
return fmt.Errorf("Error processing command: %s", err)
|
return fmt.Errorf("Error processing command: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd := &packer.RemoteCmd{Command: command}
|
// Upload the file and run the command. Do this in the context of
|
||||||
log.Printf("Executing command: %s", cmd.Command)
|
// a single retryable function so that we don't end up with
|
||||||
|
// the case that the upload succeeded, a restart is initiated,
|
||||||
|
// and then the command is executed but the file doesn't exist
|
||||||
|
// any longer.
|
||||||
|
var cmd *packer.RemoteCmd
|
||||||
err = p.retryable(func() error {
|
err = p.retryable(func() error {
|
||||||
|
if _, err := f.Seek(0, 0); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := comm.Upload(p.config.RemotePath, f); err != nil {
|
||||||
|
return fmt.Errorf("Error uploading script: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd = &packer.RemoteCmd{Command: command}
|
||||||
return cmd.StartWithUi(comm, ui)
|
return cmd.StartWithUi(comm, ui)
|
||||||
})
|
})
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Close the original file since we copied it
|
||||||
|
f.Close()
|
||||||
|
|
||||||
if cmd.ExitStatus != 0 {
|
if cmd.ExitStatus != 0 {
|
||||||
return fmt.Errorf("Script exited with non-zero exit status: %d", cmd.ExitStatus)
|
return fmt.Errorf("Script exited with non-zero exit status: %d", cmd.ExitStatus)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue