diff --git a/outscale/resource_outscale_vm.go b/outscale/resource_outscale_vm.go index 13bfe6c05..61dd9b278 100644 --- a/outscale/resource_outscale_vm.go +++ b/outscale/resource_outscale_vm.go @@ -1112,10 +1112,23 @@ func resourceOAPIVMDelete(d *schema.ResourceData, meta interface{}) error { conn := meta.(*OutscaleClient).OSCAPI id := d.Id() + var err error - log.Printf("[INFO] Terminating VM: %s", id) + err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { + _, httpResp, err := conn.VmApi.StopVms(context.Background()).StopVmsRequest(oscgo.StopVmsRequest{ + VmIds: []string{id}, + ForceStop: oscgo.PtrBool(true), + }).Execute() + if err != nil { + return utils.CheckThrottling(httpResp, err) + } + return nil + }) + + if err != nil { + return fmt.Errorf("Error Froce stopping vms before destroy %s", err) + } - var err error err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { _, httpResp, err := conn.VmApi.DeleteVms(context.Background()).DeleteVmsRequest(oscgo.DeleteVmsRequest{ VmIds: []string{id},