Skip to content

Commit

Permalink
Merge pull request hashicorp#39690 from hashicorp/b-ecs-task-defn-dis…
Browse files Browse the repository at this point in the history
…appears

resource/aws_ecs_task_definition: Prevents failures when target was deleted outside of Terraform
  • Loading branch information
gdavison authored Oct 15, 2024
2 parents 4691dea + 685d624 commit baf1751
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 79 deletions.
18 changes: 12 additions & 6 deletions internal/service/ecs/task_definition.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,15 @@ import (
"context"
"fmt"
"log"
"net/http"
"strings"

"github.com/YakDriver/regexache"
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/aws/arn"
"github.com/aws/aws-sdk-go-v2/service/ecs"
awstypes "github.com/aws/aws-sdk-go-v2/service/ecs/types"
"github.com/hashicorp/aws-sdk-go-base/v2/tfawserr"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/retry"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
Expand Down Expand Up @@ -586,7 +588,6 @@ func resourceTaskDefinitionRead(ctx context.Context, d *schema.ResourceData, met
d.SetId("")
return diags
}

if err != nil {
return sdkdiag.AppendErrorf(diags, "reading ECS Task Definition (%s): %s", familyOrARN, err)
}
Expand Down Expand Up @@ -663,8 +664,9 @@ func resourceTaskDefinitionDelete(ctx context.Context, d *schema.ResourceData, m
_, err := conn.DeregisterTaskDefinition(ctx, &ecs.DeregisterTaskDefinitionInput{
TaskDefinition: aws.String(d.Get(names.AttrARN).(string)),
})

if err != nil {
if tfawserr.ErrMessageContains(err, "ClientException", "in the process of being deleted") {
return diags
} else if err != nil {
return sdkdiag.AppendErrorf(diags, "deleting ECS Task Definition (%s): %s", d.Id(), err)
}

Expand All @@ -673,8 +675,12 @@ func resourceTaskDefinitionDelete(ctx context.Context, d *schema.ResourceData, m

func findTaskDefinition(ctx context.Context, conn *ecs.Client, input *ecs.DescribeTaskDefinitionInput) (*awstypes.TaskDefinition, []awstypes.Tag, error) {
output, err := conn.DescribeTaskDefinition(ctx, input)

if err != nil {
if tfawserr.ErrHTTPStatusCodeEquals(err, http.StatusBadRequest) {
return nil, nil, &retry.NotFoundError{
LastError: err,
LastRequest: input,
}
} else if err != nil {
return nil, nil, err
}

Expand Down Expand Up @@ -704,7 +710,7 @@ func findTaskDefinitionByFamilyOrARN(ctx context.Context, conn *ecs.Client, fami
return nil, nil, err
}

if status := taskDefinition.Status; status == awstypes.TaskDefinitionStatusInactive {
if status := taskDefinition.Status; status == awstypes.TaskDefinitionStatusInactive || status == awstypes.TaskDefinitionStatusDeleteInProgress {
return nil, nil, &retry.NotFoundError{
Message: string(status),
LastRequest: input,
Expand Down
Loading

0 comments on commit baf1751

Please sign in to comment.