fix: avoid crash when delete() returns an error in batch expiration (#19909)

This commit is contained in:
Harshavardhana 2024-06-11 06:50:53 -07:00 committed by GitHub
parent 76ebb16688
commit d21b6daa49
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -432,7 +432,7 @@ func batchObjsForDelete(ctx context.Context, r *BatchJobExpire, ri *batchJobInfo
}) })
if err != nil { if err != nil {
stopFn(exp, err) stopFn(exp, err)
batchLogIf(ctx, fmt.Errorf("Failed to expire %s/%s versionID=%s due to %v (attempts=%d)", toExpire[i].Bucket, toExpire[i].Name, toExpire[i].VersionID, err, attempts)) batchLogIf(ctx, fmt.Errorf("Failed to expire %s/%s due to %v (attempts=%d)", exp.Bucket, exp.Name, err, attempts))
} else { } else {
stopFn(exp, err) stopFn(exp, err)
success = true success = true
@ -464,13 +464,13 @@ func batchObjsForDelete(ctx context.Context, r *BatchJobExpire, ri *batchJobInfo
copy(toDelCopy, toDel) copy(toDelCopy, toDel)
var failed int var failed int
errs := r.Expire(ctx, api, vc, toDel) errs := r.Expire(ctx, api, vc, toDel)
// reslice toDel in preparation for next retry // reslice toDel in preparation for next retry attempt
// attempt
toDel = toDel[:0] toDel = toDel[:0]
for i, err := range errs { for i, err := range errs {
if err != nil { if err != nil {
stopFn(toDelCopy[i], err) stopFn(toDelCopy[i], err)
batchLogIf(ctx, fmt.Errorf("Failed to expire %s/%s versionID=%s due to %v (attempts=%d)", ri.Bucket, toDelCopy[i].ObjectName, toDelCopy[i].VersionID, err, attempts)) batchLogIf(ctx, fmt.Errorf("Failed to expire %s/%s versionID=%s due to %v (attempts=%d)", ri.Bucket, toDelCopy[i].ObjectName, toDelCopy[i].VersionID,
err, attempts))
failed++ failed++
if oi, ok := oiCache.Get(toDelCopy[i]); ok { if oi, ok := oiCache.Get(toDelCopy[i]); ok {
ri.trackCurrentBucketObject(r.Bucket, *oi, false, attempts) ri.trackCurrentBucketObject(r.Bucket, *oi, false, attempts)