From 49a7d08a4097ce7e4c872915651def9450608c13 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Thu, 25 Jun 2020 14:44:48 +0100 Subject: [PATCH] qingstor: cancel in progress multipart uploads on rclone exit #4300 --- backend/qingstor/upload.go | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/backend/qingstor/upload.go b/backend/qingstor/upload.go index fb9202106..642a47c84 100644 --- a/backend/qingstor/upload.go +++ b/backend/qingstor/upload.go @@ -15,6 +15,7 @@ import ( "github.com/pkg/errors" "github.com/rclone/rclone/fs" + "github.com/rclone/rclone/lib/atexit" qs "github.com/yunify/qingstor-sdk-go/v3/service" ) @@ -346,12 +347,15 @@ func (mu *multiUploader) multiPartUpload(firstBuf io.ReadSeeker) (err error) { if err = mu.initiate(); err != nil { return err } - defer func() { - // Abort the transfer if returning an error - if err != nil { - _ = mu.abort() + + // Cancel the session if something went wrong + defer atexit.OnError(&err, func() { + fs.Debugf(mu, "Cancelling multipart upload: %v", err) + cancelErr := mu.abort() + if cancelErr != nil { + fs.Logf(mu, "Failed to cancel multipart upload: %v", cancelErr) } - }() + })() ch := make(chan chunk, mu.cfg.concurrency) for i := 0; i < mu.cfg.concurrency; i++ {