Commit 0e251176 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

builder/amazon/common: if instance query returns none, ignore

parent d0c3cede
...@@ -25,6 +25,8 @@ BUG FIXES: ...@@ -25,6 +25,8 @@ BUG FIXES:
* builder/amazon/all: When copying AMI to multiple regions, copy * builder/amazon/all: When copying AMI to multiple regions, copy
the metadata (tags and attributes) as well. [GH-388] the metadata (tags and attributes) as well. [GH-388]
* builder/amazon/all: Fix panic case where eventually consistent
instance state caused an index out of bounds.
* builder/vmware: Autoanswer VMware dialogs. [GH-393] * builder/vmware: Autoanswer VMware dialogs. [GH-393]
* command/inspect: Fix weird output for default values for optional vars. * command/inspect: Fix weird output for default values for optional vars.
......
...@@ -40,6 +40,12 @@ func InstanceStateRefreshFunc(conn *ec2.EC2, i *ec2.Instance) StateRefreshFunc { ...@@ -40,6 +40,12 @@ func InstanceStateRefreshFunc(conn *ec2.EC2, i *ec2.Instance) StateRefreshFunc {
return nil, "", err return nil, "", err
} }
if len(resp.Reservations) == 0 || len(resp.Reservations[0].Instances) == 0 {
// Sometimes AWS just has consistency issues and doesn't see
// our instance yet. Return an empty state.
return nil, "", nil
}
i = &resp.Reservations[0].Instances[0] i = &resp.Reservations[0].Instances[0]
return i, i.State.Name, nil return i, i.State.Name, nil
} }
...@@ -57,6 +63,9 @@ func WaitForState(conf *StateChangeConf) (i interface{}, err error) { ...@@ -57,6 +63,9 @@ func WaitForState(conf *StateChangeConf) (i interface{}, err error) {
return return
} }
// Check states only if we were able to refresh to an instance
// that exists.
if i != nil {
if currentState == conf.Target { if currentState == conf.Target {
return return
} }
...@@ -79,6 +88,7 @@ func WaitForState(conf *StateChangeConf) (i interface{}, err error) { ...@@ -79,6 +88,7 @@ func WaitForState(conf *StateChangeConf) (i interface{}, err error) {
fmt.Errorf("unexpected state '%s', wanted target '%s'", currentState, conf.Target) fmt.Errorf("unexpected state '%s', wanted target '%s'", currentState, conf.Target)
return return
} }
}
time.Sleep(2 * time.Second) time.Sleep(2 * time.Second)
} }
......
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