forked from TrueCloudLab/rclone
ulozto: revert the temporary file size limitations
This commit is contained in:
parent
748c43d525
commit
c9ce384ec7
2 changed files with 1 additions and 40 deletions
|
@ -38,8 +38,6 @@ const (
|
||||||
maxSleep = 2 * time.Second
|
maxSleep = 2 * time.Second
|
||||||
decayConstant = 2 // bigger for slower decay, exponential
|
decayConstant = 2 // bigger for slower decay, exponential
|
||||||
rootURL = "https://apis.uloz.to"
|
rootURL = "https://apis.uloz.to"
|
||||||
// TODO temporary limitation, remove with chunked upload impl
|
|
||||||
maxFileSizeBytes = 2500 * 1024 * 1024
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Options defines the configuration for this backend
|
// Options defines the configuration for this backend
|
||||||
|
@ -194,9 +192,7 @@ func errorHandler(resp *http.Response) error {
|
||||||
// retryErrorCodes is a slice of error codes that we will retry
|
// retryErrorCodes is a slice of error codes that we will retry
|
||||||
var retryErrorCodes = []int{
|
var retryErrorCodes = []int{
|
||||||
429, // Too Many Requests.
|
429, // Too Many Requests.
|
||||||
// TODO: random 500s should be retried but the error code corresponds to a known issue with uploading large files,
|
500, // Internal Server Error
|
||||||
// leading to numerous (slow & resource consuming) retries. Don't retry them until the root cause is addressed.
|
|
||||||
// 500, // Internal Server Error
|
|
||||||
502, // Bad Gateway
|
502, // Bad Gateway
|
||||||
503, // Service Unavailable
|
503, // Service Unavailable
|
||||||
504, // Gateway Timeout
|
504, // Gateway Timeout
|
||||||
|
@ -447,10 +443,6 @@ func (f *Fs) uploadUnchecked(ctx context.Context, name, parentSlug string, info
|
||||||
|
|
||||||
// Put implements the mandatory method fs.Fs.Put.
|
// Put implements the mandatory method fs.Fs.Put.
|
||||||
func (f *Fs) Put(ctx context.Context, in io.Reader, src fs.ObjectInfo, options ...fs.OpenOption) (fs.Object, error) {
|
func (f *Fs) Put(ctx context.Context, in io.Reader, src fs.ObjectInfo, options ...fs.OpenOption) (fs.Object, error) {
|
||||||
// TODO: workaround for uloz.to's bug. Remove when chunked upload support is implemented.
|
|
||||||
if src.Size() > maxFileSizeBytes {
|
|
||||||
return nil, errors.New("file size over the supported max threshold")
|
|
||||||
}
|
|
||||||
existingObj, err := f.NewObject(ctx, src.Remote())
|
existingObj, err := f.NewObject(ctx, src.Remote())
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package ulozto
|
package ulozto
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -10,7 +9,6 @@ import (
|
||||||
"github.com/rclone/rclone/backend/ulozto/api"
|
"github.com/rclone/rclone/backend/ulozto/api"
|
||||||
"github.com/rclone/rclone/fs"
|
"github.com/rclone/rclone/fs"
|
||||||
"github.com/rclone/rclone/fs/hash"
|
"github.com/rclone/rclone/fs/hash"
|
||||||
"github.com/rclone/rclone/fs/object"
|
|
||||||
"github.com/rclone/rclone/fs/operations"
|
"github.com/rclone/rclone/fs/operations"
|
||||||
"github.com/rclone/rclone/fstest"
|
"github.com/rclone/rclone/fstest"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
@ -86,32 +84,3 @@ func TestListWithoutMetadata(t *testing.T) {
|
||||||
// Tear down
|
// Tear down
|
||||||
require.NoError(t, operations.Purge(ctx, f, ""))
|
require.NoError(t, operations.Purge(ctx, f, ""))
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestUploadLargeFile verifies that files over the supported threshold are not uploaded.
|
|
||||||
func TestUploadLargeFile(t *testing.T) {
|
|
||||||
const (
|
|
||||||
remoteName = "TestUlozto:"
|
|
||||||
payload = "foobar"
|
|
||||||
filesize = maxFileSizeBytes + 1
|
|
||||||
)
|
|
||||||
ctx := context.Background()
|
|
||||||
fstest.Initialise()
|
|
||||||
subRemoteName, subRemoteLeaf, err := fstest.RandomRemoteName(remoteName)
|
|
||||||
require.NoError(t, err)
|
|
||||||
f, err := fs.NewFs(ctx, subRemoteName)
|
|
||||||
if errors.Is(err, fs.ErrorNotFoundInConfigFile) {
|
|
||||||
t.Logf("Didn't find %q in config file - skipping tests", remoteName)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
require.NoError(t, err)
|
|
||||||
|
|
||||||
file := fstest.Item{ModTime: time.UnixMilli(123456789), Path: subRemoteLeaf, Size: int64(filesize)}
|
|
||||||
obji := object.NewStaticObjectInfo(file.Path, file.ModTime, file.Size, true, nil, nil)
|
|
||||||
// The payload buffer is just a placeholder which shouldn't be used
|
|
||||||
_, err = f.Put(ctx, bytes.NewBufferString(payload), obji)
|
|
||||||
|
|
||||||
require.Error(t, err, "File size over the supported max threshold.")
|
|
||||||
|
|
||||||
// Verify the remote stayed intact
|
|
||||||
fstest.CheckListing(t, f, []fstest.Item{})
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue