Skip to content

Commit

Permalink
Merge pull request #9050 from hashicorp/b-aws-ecr-delete-timeout
Browse files Browse the repository at this point in the history
provider/aws: Add retry logic to the aws_ecr_repository delete func
  • Loading branch information
stack72 authored Sep 28, 2016
2 parents 4c15ca3 + 15c8534 commit 10eb572
Showing 1 changed file with 30 additions and 1 deletion.
31 changes: 30 additions & 1 deletion builtin/providers/aws/resource_aws_ecr_repository.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,14 @@ package aws

import (
"log"
"time"

"fmt"

"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/awserr"
"github.com/aws/aws-sdk-go/service/ecr"
"github.com/hashicorp/terraform/helper/resource"
"github.com/hashicorp/terraform/helper/schema"
)

Expand Down Expand Up @@ -117,7 +119,34 @@ func resourceAwsEcrRepositoryDelete(d *schema.ResourceData, meta interface{}) er
return err
}

log.Printf("[DEBUG] repository %q deleted.", d.Get("arn").(string))
log.Printf("[DEBUG] Waiting for ECR Repository %q to be deleted", d.Id())
err = resource.Retry(20*time.Minute, func() *resource.RetryError {
_, err := conn.DescribeRepositories(&ecr.DescribeRepositoriesInput{
RepositoryNames: []*string{aws.String(d.Id())},
})

if err != nil {
awsErr, ok := err.(awserr.Error)
if !ok {
return resource.NonRetryableError(err)
}

if awsErr.Code() == "RepositoryNotFoundException" {
return nil
}

return resource.NonRetryableError(err)
}

return resource.RetryableError(
fmt.Errorf("%q: Timeout while waiting for the ECR Repository to be deleted", d.Id()))
})
if err != nil {
return err
}

d.SetId("")
log.Printf("[DEBUG] repository %q deleted.", d.Get("name").(string))

return nil
}

0 comments on commit 10eb572

Please sign in to comment.