171 lines
6 KiB
Go
171 lines
6 KiB
Go
// Test Crypt filesystem interface
|
|
package crypt_test
|
|
|
|
import (
|
|
"os"
|
|
"path/filepath"
|
|
"runtime"
|
|
"testing"
|
|
|
|
"github.com/rclone/rclone/backend/crypt"
|
|
_ "github.com/rclone/rclone/backend/drive" // for integration tests
|
|
_ "github.com/rclone/rclone/backend/local"
|
|
_ "github.com/rclone/rclone/backend/swift" // for integration tests
|
|
"github.com/rclone/rclone/fs/config/obscure"
|
|
"github.com/rclone/rclone/fstest"
|
|
"github.com/rclone/rclone/fstest/fstests"
|
|
)
|
|
|
|
// TestIntegration runs integration tests against the remote
|
|
func TestIntegration(t *testing.T) {
|
|
if *fstest.RemoteName == "" {
|
|
t.Skip("Skipping as -remote not set")
|
|
}
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: *fstest.RemoteName,
|
|
NilObject: (*crypt.Object)(nil),
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
})
|
|
}
|
|
|
|
// TestStandard runs integration tests against the remote
|
|
func TestStandardBase32(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-standard")
|
|
name := "TestCrypt"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato")},
|
|
{Name: name, Key: "filename_encryption", Value: "standard"},
|
|
},
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|
|
|
|
func TestStandardBase64(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-standard")
|
|
name := "TestCrypt"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato")},
|
|
{Name: name, Key: "filename_encryption", Value: "standard"},
|
|
{Name: name, Key: "filename_encoding", Value: "base64"},
|
|
},
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|
|
|
|
func TestStandardBase32768(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-standard")
|
|
name := "TestCrypt"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato")},
|
|
{Name: name, Key: "filename_encryption", Value: "standard"},
|
|
{Name: name, Key: "filename_encoding", Value: "base32768"},
|
|
},
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|
|
|
|
// TestOff runs integration tests against the remote
|
|
func TestOff(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-off")
|
|
name := "TestCrypt2"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato2")},
|
|
{Name: name, Key: "filename_encryption", Value: "off"},
|
|
},
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|
|
|
|
// TestObfuscate runs integration tests against the remote
|
|
func TestObfuscate(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
if runtime.GOOS == "darwin" {
|
|
t.Skip("Skipping on macOS as obfuscating control characters makes filenames macOS can't cope with")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-obfuscate")
|
|
name := "TestCrypt3"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato2")},
|
|
{Name: name, Key: "filename_encryption", Value: "obfuscate"},
|
|
},
|
|
SkipBadWindowsCharacters: true,
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|
|
|
|
// TestNoDataObfuscate runs integration tests against the remote
|
|
func TestNoDataObfuscate(t *testing.T) {
|
|
if *fstest.RemoteName != "" {
|
|
t.Skip("Skipping as -remote set")
|
|
}
|
|
if runtime.GOOS == "darwin" {
|
|
t.Skip("Skipping on macOS as obfuscating control characters makes filenames macOS can't cope with")
|
|
}
|
|
tempdir := filepath.Join(os.TempDir(), "rclone-crypt-test-obfuscate")
|
|
name := "TestCrypt4"
|
|
fstests.Run(t, &fstests.Opt{
|
|
RemoteName: name + ":",
|
|
NilObject: (*crypt.Object)(nil),
|
|
ExtraConfig: []fstests.ExtraConfigItem{
|
|
{Name: name, Key: "type", Value: "crypt"},
|
|
{Name: name, Key: "remote", Value: tempdir},
|
|
{Name: name, Key: "password", Value: obscure.MustObscure("potato2")},
|
|
{Name: name, Key: "filename_encryption", Value: "obfuscate"},
|
|
{Name: name, Key: "no_data_encryption", Value: "true"},
|
|
},
|
|
SkipBadWindowsCharacters: true,
|
|
UnimplementableFsMethods: []string{"OpenWriterAt", "OpenChunkWriter"},
|
|
UnimplementableObjectMethods: []string{"MimeType"},
|
|
QuickTestOK: true,
|
|
})
|
|
}
|