diff --git a/builder/amazon/common/step_pre_validate.go b/builder/amazon/common/step_pre_validate.go index 592f9d539..5aeecc2f6 100644 --- a/builder/amazon/common/step_pre_validate.go +++ b/builder/amazon/common/step_pre_validate.go @@ -85,19 +85,20 @@ func (s *StepPreValidate) Run(ctx context.Context, state multistep.StateBag) mul ec2conn := state.Get("ec2").(*ec2.EC2) ui.Say(fmt.Sprintf("Prevalidating AMI Name: %s", s.DestAmiName)) - resp, err := ec2conn.DescribeImages(&ec2.DescribeImagesInput{ + req, resp := ec2conn.DescribeImagesRequest(&ec2.DescribeImagesInput{ Filters: []*ec2.Filter{{ Name: aws.String("name"), Values: []*string{aws.String(s.DestAmiName)}, }}}) + req.RetryCount = 11 + err := req.Send() if err != nil { err := fmt.Errorf("Error querying AMI: %s", err) state.Put("error", err) ui.Error(err.Error()) return multistep.ActionHalt } - if len(resp.Images) > 0 { err := fmt.Errorf("Error: AMI Name: '%s' is used by an existing AMI: %s", *resp.Images[0].Name, *resp.Images[0].ImageId) state.Put("error", err) diff --git a/provisioner/ansible/provisioner.go b/provisioner/ansible/provisioner.go index d61d4d44e..f129d8c79 100644 --- a/provisioner/ansible/provisioner.go +++ b/provisioner/ansible/provisioner.go @@ -240,6 +240,10 @@ func (p *Provisioner) Provision(ctx context.Context, ui packer.Ui, comm packer.C } hostSigner, err := newSigner(p.config.SSHHostKeyFile) + if err != nil { + return fmt.Errorf("error creating host signer: %s", err) + } + // Remove the private key file if len(k.privKeyFile) > 0 { defer os.Remove(k.privKeyFile) diff --git a/provisioner/inspec/provisioner.go b/provisioner/inspec/provisioner.go index 618802f9f..f9d52d36c 100644 --- a/provisioner/inspec/provisioner.go +++ b/provisioner/inspec/provisioner.go @@ -217,6 +217,10 @@ func (p *Provisioner) Provision(ctx context.Context, ui packer.Ui, comm packer.C } hostSigner, err := newSigner(p.config.SSHHostKeyFile) + if err != nil { + return fmt.Errorf("error creating host signer: %s", err) + } + // Remove the private key file if len(k.privKeyFile) > 0 { defer os.Remove(k.privKeyFile) diff --git a/website/source/layouts/docs.erb b/website/source/layouts/docs.erb index 26fd0ab85..11c9f8a49 100644 --- a/website/source/layouts/docs.erb +++ b/website/source/layouts/docs.erb @@ -182,6 +182,9 @@