forked from TrueCloudLab/rclone
operations: fix server side copies on partial upload backends after refactor
After the copy refactor:
179f978f75
operations: refactor Copy into methods on an temporary object
There was some confusion in the code about server side copies - should
they or shouldn't they use partials?
This manifested in unit test failures for remotes which supported
server side Copy and PartialUploads. This combination is rare and only
exists in the sftp backend with the --sftp-copy-is-hardlink flag.
This fix makes the choice that backends which set PartialUploads
always use partials even for server side copies.
This commit is contained in:
parent
af8ba18580
commit
23ab6fa3a0
1 changed files with 1 additions and 4 deletions
|
@ -146,11 +146,8 @@ func (c *copy) serverSideCopy(ctx context.Context) (actionTaken string, newDst f
|
||||||
newDst, err = doCopy(ctx, c.src, c.remoteForCopy)
|
newDst, err = doCopy(ctx, c.src, c.remoteForCopy)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
in.ServerSideCopyEnd(newDst.Size()) // account the bytes for the server-side transfer
|
in.ServerSideCopyEnd(newDst.Size()) // account the bytes for the server-side transfer
|
||||||
_ = in.Close()
|
|
||||||
c.inplace = true
|
|
||||||
} else {
|
|
||||||
_ = in.Close()
|
|
||||||
}
|
}
|
||||||
|
_ = in.Close()
|
||||||
if errors.Is(err, fs.ErrorCantCopy) {
|
if errors.Is(err, fs.ErrorCantCopy) {
|
||||||
c.tr.Reset(ctx) // skip incomplete accounting - will be overwritten by the manual copy
|
c.tr.Reset(ctx) // skip incomplete accounting - will be overwritten by the manual copy
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue