diff --git a/outscale/resource_outscale_net.go b/outscale/resource_outscale_net.go index 1ba48e041..cad6176f1 100644 --- a/outscale/resource_outscale_net.go +++ b/outscale/resource_outscale_net.go @@ -186,7 +186,7 @@ func resourceOutscaleOAPINetDelete(d *schema.ResourceData, meta interface{}) err state = nats[0].GetState() return resp, state, nil } - return nil, state, nil + return resp, state, nil }, Timeout: 8 * time.Minute, MinTimeout: 30 * time.Second, diff --git a/outscale/resource_outscale_vm.go b/outscale/resource_outscale_vm.go index abf3f51ed..f680ee77a 100644 --- a/outscale/resource_outscale_vm.go +++ b/outscale/resource_outscale_vm.go @@ -1120,9 +1120,41 @@ func resourceOAPIVMDelete(d *schema.ResourceData, meta interface{}) error { log.Printf("[DEBUG] Waiting for VM (%s) to become terminated", id) stateConf := &resource.StateChangeConf{ - Pending: []string{"pending", "running", "shutting-down", "stopped", "stopping"}, - Target: []string{"terminated"}, - Refresh: vmStateRefreshFunc(conn, id, ""), + Pending: []string{"pending", "running", "shutting-down", "stopped", "stopping"}, + Target: []string{"terminated"}, + Refresh: func() (interface{}, string, error) { + var resp oscgo.ReadVmsResponse + err := resource.Retry(30*time.Second, func() *resource.RetryError { + rp, httpResp, err := conn.VmApi.ReadVms(context.Background()).ReadVmsRequest(oscgo.ReadVmsRequest{ + Filters: &oscgo.FiltersVm{ + VmIds: &[]string{id}, + }, + }).Execute() + if err != nil { + return utils.CheckThrottling(httpResp, err) + } + resp = rp + return nil + }) + if err != nil { + log.Printf("[ERROR] error on InstanceStateRefresh: %s", err) + return nil, "", err + } + + if !resp.HasVms() || len(resp.GetVms()) < 1 { + return resp, "terminated", nil + } + + vm := resp.GetVms()[0] + state := vm.GetState() + + if state != "terminated" { + return vm, state, fmt.Errorf("Failed to reach target state. Reason: %v", *vm.State) + + } + + return vm, state, nil + }, Timeout: d.Timeout(schema.TimeoutDelete), Delay: 10 * time.Second, MinTimeout: 3 * time.Second,