Merge pull request #1057 from hashicorp/digitalocean-droplet-destroy
providers/digitalocean: wait for droplet to be unlocked before destroy
This commit is contained in:
commit
7008880ac8
|
@ -326,10 +326,18 @@ func resourceDigitalOceanDropletUpdate(d *schema.ResourceData, meta interface{})
|
||||||
func resourceDigitalOceanDropletDelete(d *schema.ResourceData, meta interface{}) error {
|
func resourceDigitalOceanDropletDelete(d *schema.ResourceData, meta interface{}) error {
|
||||||
client := meta.(*digitalocean.Client)
|
client := meta.(*digitalocean.Client)
|
||||||
|
|
||||||
|
_, err := WaitForDropletAttribute(
|
||||||
|
d, "false", []string{"", "true"}, "locked", meta)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf(
|
||||||
|
"Error waiting for droplet to be unlocked for destroy (%s): %s", d.Id(), err)
|
||||||
|
}
|
||||||
|
|
||||||
log.Printf("[INFO] Deleting droplet: %s", d.Id())
|
log.Printf("[INFO] Deleting droplet: %s", d.Id())
|
||||||
|
|
||||||
// Destroy the droplet
|
// Destroy the droplet
|
||||||
err := client.DestroyDroplet(d.Id())
|
err = client.DestroyDroplet(d.Id())
|
||||||
|
|
||||||
// Handle remotely destroyed droplets
|
// Handle remotely destroyed droplets
|
||||||
if err != nil && strings.Contains(err.Error(), "404 Not Found") {
|
if err != nil && strings.Contains(err.Error(), "404 Not Found") {
|
||||||
|
|
Loading…
Reference in New Issue