mirror of
https://github.com/rclone/rclone.git
synced 2025-01-02 12:03:38 +08:00
3ca766b2f1
When f.opt.MaxAge == 0, f.db is never set, however several methods later assume it is set and attempt to access it, causing an invalid memory address error. This change fixes the issue in a few spots (there may still be others I haven't yet encountered.)
46 lines
1.2 KiB
Go
46 lines
1.2 KiB
Go
package hasher_test
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/rclone/rclone/backend/hasher"
|
|
"github.com/rclone/rclone/fstest"
|
|
"github.com/rclone/rclone/fstest/fstests"
|
|
"github.com/rclone/rclone/lib/kv"
|
|
|
|
_ "github.com/rclone/rclone/backend/all" // for integration tests
|
|
)
|
|
|
|
// TestIntegration runs integration tests against the remote
|
|
func TestIntegration(t *testing.T) {
|
|
if !kv.Supported() {
|
|
t.Skip("hasher is not supported on this OS")
|
|
}
|
|
opt := fstests.Opt{
|
|
RemoteName: *fstest.RemoteName,
|
|
NilObject: (*hasher.Object)(nil),
|
|
UnimplementableFsMethods: []string{
|
|
"OpenWriterAt",
|
|
"OpenChunkWriter",
|
|
},
|
|
UnimplementableObjectMethods: []string{},
|
|
}
|
|
if *fstest.RemoteName == "" {
|
|
tempDir := filepath.Join(os.TempDir(), "rclone-hasher-test")
|
|
opt.ExtraConfig = []fstests.ExtraConfigItem{
|
|
{Name: "TestHasher", Key: "type", Value: "hasher"},
|
|
{Name: "TestHasher", Key: "remote", Value: tempDir},
|
|
}
|
|
opt.RemoteName = "TestHasher:"
|
|
opt.QuickTestOK = true
|
|
}
|
|
fstests.Run(t, &opt)
|
|
// test again with MaxAge = 0
|
|
if *fstest.RemoteName == "" {
|
|
opt.ExtraConfig = append(opt.ExtraConfig, fstests.ExtraConfigItem{Name: "TestHasher", Key: "max_age", Value: "0"})
|
|
fstests.Run(t, &opt)
|
|
}
|
|
}
|