fstest: Factor test initialisation into Initialise()

This commit is contained in:
Nick Craig-Wood 2017-07-24 22:46:43 +01:00
parent 1ecf2bcbd5
commit cd4895690a
5 changed files with 48 additions and 78 deletions

View File

@ -23,17 +23,6 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
// Globals
var (
RemoteName = flag.String("remote", "", "Remote to test with, defaults to local filesystem")
SubDir = flag.Bool("subdir", false, "Set to test with a sub directory")
Verbose = flag.Bool("verbose", false, "Set to enable logging")
DumpHeaders = flag.Bool("dump-headers", false, "Set to dump headers (needs -verbose)")
DumpBodies = flag.Bool("dump-bodies", false, "Set to dump bodies (needs -verbose)")
Individual = flag.Bool("individual", false, "Make individual bucket/container/directory for each test - much slower")
LowLevelRetries = flag.Int("low-level-retries", 10, "Number of low level retries")
)
type ( type (
// UnmountFn is called to unmount the file system // UnmountFn is called to unmount the file system
UnmountFn func() error UnmountFn func() error
@ -81,26 +70,17 @@ func newRun() *Run {
umountResult: make(chan error, 1), umountResult: make(chan error, 1),
} }
// Never ask for passwords, fail instead. fstest.Initialise()
// If your local config is encrypted set environment variable
// "RCLONE_CONFIG_PASS=hunter2" (or your password)
*fs.AskPassword = false
fs.LoadConfig()
if *Verbose {
fs.Config.LogLevel = fs.LogLevelDebug
}
fs.Config.DumpHeaders = *DumpHeaders
fs.Config.DumpBodies = *DumpBodies
fs.Config.LowLevelRetries = *LowLevelRetries
var err error var err error
r.fremote, r.fremoteName, r.cleanRemote, err = fstest.RandomRemote(*RemoteName, *SubDir) r.fremote, r.fremoteName, r.cleanRemote, err = fstest.RandomRemote(*fstest.RemoteName, *fstest.SubDir)
if err != nil { if err != nil {
log.Fatalf("Failed to open remote %q: %v", *RemoteName, err) log.Fatalf("Failed to open remote %q: %v", *fstest.RemoteName, err)
} }
err = r.fremote.Mkdir("") err = r.fremote.Mkdir("")
if err != nil { if err != nil {
log.Fatalf("Failed to open mkdir %q: %v", *RemoteName, err) log.Fatalf("Failed to open mkdir %q: %v", *fstest.RemoteName, err)
} }
if runtime.GOOS != "windows" { if runtime.GOOS != "windows" {

View File

@ -43,18 +43,6 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
// Globals
var (
RemoteName = flag.String("remote", "", "Remote to test with, defaults to local filesystem")
SubDir = flag.Bool("subdir", false, "Set to test with a sub directory")
Verbose = flag.Bool("verbose", false, "Set to enable logging")
DumpHeaders = flag.Bool("dump-headers", false, "Set to dump headers (needs -verbose)")
DumpBodies = flag.Bool("dump-bodies", false, "Set to dump bodies (needs -verbose)")
Individual = flag.Bool("individual", false, "Make individual bucket/container/directory for each test - much slower")
LowLevelRetries = flag.Int("low-level-retries", 10, "Number of low level retries")
UseListR = flag.Bool("fast-list", false, "Use recursive list if available. Uses more memory but fewer transactions.")
)
// Some times used in the tests // Some times used in the tests
var ( var (
t1 = fstest.Time("2001-02-03T04:05:06.499999999Z") t1 = fstest.Time("2001-02-03T04:05:06.499999999Z")
@ -65,11 +53,11 @@ var (
// TestMain drives the tests // TestMain drives the tests
func TestMain(m *testing.M) { func TestMain(m *testing.M) {
flag.Parse() flag.Parse()
if !*Individual { if !*fstest.Individual {
oneRun = newRun() oneRun = newRun()
} }
rc := m.Run() rc := m.Run()
if !*Individual { if !*fstest.Individual {
oneRun.Finalise() oneRun.Finalise()
} }
os.Exit(rc) os.Exit(rc)
@ -103,22 +91,12 @@ func newRun() *Run {
mkdir: make(map[string]bool), mkdir: make(map[string]bool),
} }
// Never ask for passwords, fail instead. fstest.Initialise()
// If your local config is encrypted set environment variable
// "RCLONE_CONFIG_PASS=hunter2" (or your password)
*fs.AskPassword = false
fs.LoadConfig()
if *Verbose {
fs.Config.LogLevel = fs.LogLevelDebug
}
fs.Config.DumpHeaders = *DumpHeaders
fs.Config.DumpBodies = *DumpBodies
fs.Config.LowLevelRetries = *LowLevelRetries
fs.Config.UseListR = *UseListR
var err error var err error
r.fremote, r.fremoteName, r.cleanRemote, err = fstest.RandomRemote(*RemoteName, *SubDir) r.fremote, r.fremoteName, r.cleanRemote, err = fstest.RandomRemote(*fstest.RemoteName, *fstest.SubDir)
if err != nil { if err != nil {
r.Fatalf("Failed to open remote %q: %v", *RemoteName, err) r.Fatalf("Failed to open remote %q: %v", *fstest.RemoteName, err)
} }
r.localName, err = ioutil.TempDir("", "rclone") r.localName, err = ioutil.TempDir("", "rclone")
@ -150,7 +128,7 @@ func (d dirsToRemove) Less(i, j int) bool { return len(d[i]) > len(d[j]) }
// Finalise() will tidy them away when done. // Finalise() will tidy them away when done.
func NewRun(t *testing.T) *Run { func NewRun(t *testing.T) *Run {
var r *Run var r *Run
if *Individual { if *fstest.Individual {
r = newRun() r = newRun()
} else { } else {
// If not individual, use the global one with the clean method overridden // If not individual, use the global one with the clean method overridden

View File

@ -102,7 +102,7 @@ func TestServerSideCopy(t *testing.T) {
file1 := r.WriteObject("sub dir/hello world", "hello world", t1) file1 := r.WriteObject("sub dir/hello world", "hello world", t1)
fstest.CheckItems(t, r.fremote, file1) fstest.CheckItems(t, r.fremote, file1)
fremoteCopy, _, finaliseCopy, err := fstest.RandomRemote(*RemoteName, *SubDir) fremoteCopy, _, finaliseCopy, err := fstest.RandomRemote(*fstest.RemoteName, *fstest.SubDir)
require.NoError(t, err) require.NoError(t, err)
defer finaliseCopy() defer finaliseCopy()
t.Logf("Server side copy (if possible) %v -> %v", r.fremote, fremoteCopy) t.Logf("Server side copy (if possible) %v -> %v", r.fremote, fremoteCopy)
@ -735,7 +735,7 @@ func testServerSideMove(t *testing.T, r *Run, fremoteMove fs.Fs, withFilter bool
func TestServerSideMove(t *testing.T) { func TestServerSideMove(t *testing.T) {
r := NewRun(t) r := NewRun(t)
defer r.Finalise() defer r.Finalise()
fremoteMove, _, finaliseMove, err := fstest.RandomRemote(*RemoteName, *SubDir) fremoteMove, _, finaliseMove, err := fstest.RandomRemote(*fstest.RemoteName, *fstest.SubDir)
require.NoError(t, err) require.NoError(t, err)
defer finaliseMove() defer finaliseMove()
testServerSideMove(t, r, fremoteMove, false) testServerSideMove(t, r, fremoteMove, false)
@ -751,7 +751,7 @@ func TestServerSideMoveWithFilter(t *testing.T) {
fs.Config.Filter.MinSize = -1 fs.Config.Filter.MinSize = -1
}() }()
fremoteMove, _, finaliseMove, err := fstest.RandomRemote(*RemoteName, *SubDir) fremoteMove, _, finaliseMove, err := fstest.RandomRemote(*fstest.RemoteName, *fstest.SubDir)
require.NoError(t, err) require.NoError(t, err)
defer finaliseMove() defer finaliseMove()
testServerSideMove(t, r, fremoteMove, true) testServerSideMove(t, r, fremoteMove, true)

View File

@ -24,11 +24,20 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
// Globals
var ( var (
// MatchTestRemote matches the remote names used for testing RemoteName = flag.String("remote", "", "Remote to test with, defaults to local filesystem")
MatchTestRemote = regexp.MustCompile(`^rclone-test-[abcdefghijklmnopqrstuvwxyz0123456789]{24}$`) SubDir = flag.Bool("subdir", false, "Set to test with a sub directory")
Verbose = flag.Bool("verbose", false, "Set to enable logging")
DumpHeaders = flag.Bool("dump-headers", false, "Set to dump headers (needs -verbose)")
DumpBodies = flag.Bool("dump-bodies", false, "Set to dump bodies (needs -verbose)")
Individual = flag.Bool("individual", false, "Make individual bucket/container/directory for each test - much slower")
LowLevelRetries = flag.Int("low-level-retries", 10, "Number of low level retries")
UseListR = flag.Bool("fast-list", false, "Use recursive list if available. Uses more memory but fewer transactions.")
// ListRetries is the number of times to retry a listing to overcome eventual consistency // ListRetries is the number of times to retry a listing to overcome eventual consistency
ListRetries = flag.Int("list-retries", 6, "Number or times to retry listing") ListRetries = flag.Int("list-retries", 6, "Number or times to retry listing")
// MatchTestRemote matches the remote names used for testing
MatchTestRemote = regexp.MustCompile(`^rclone-test-[abcdefghijklmnopqrstuvwxyz0123456789]{24}$`)
) )
// Seed the random number generator // Seed the random number generator
@ -37,6 +46,22 @@ func init() {
} }
// Initialise rclone for testing
func Initialise() {
// Never ask for passwords, fail instead.
// If your local config is encrypted set environment variable
// "RCLONE_CONFIG_PASS=hunter2" (or your password)
*fs.AskPassword = false
fs.LoadConfig()
if *Verbose {
fs.Config.LogLevel = fs.LogLevelDebug
}
fs.Config.DumpHeaders = *DumpHeaders
fs.Config.DumpBodies = *DumpBodies
fs.Config.LowLevelRetries = *LowLevelRetries
fs.Config.UseListR = *UseListR
}
// Item represents an item for checking // Item represents an item for checking
type Item struct { type Item struct {
Path string Path string

View File

@ -7,7 +7,6 @@ package fstests
import ( import (
"bytes" "bytes"
"flag"
"fmt" "fmt"
"io" "io"
"io/ioutil" "io/ioutil"
@ -48,12 +47,8 @@ var (
Path: `hello? sausage/êé/Hello, 世界/ " ' @ < > & ? + ≠/z.txt`, Path: `hello? sausage/êé/Hello, 世界/ " ' @ < > & ? + ≠/z.txt`,
WinPath: `hello_ sausage/êé/Hello, 世界/ _ ' @ _ _ & _ + ≠/z.txt`, WinPath: `hello_ sausage/êé/Hello, 世界/ _ ' @ _ _ & _ + ≠/z.txt`,
} }
file2Contents = "" file2Contents = ""
verbose = flag.Bool("verbose", false, "Set to enable logging") isLocalRemote bool
dumpHeaders = flag.Bool("dump-headers", false, "Dump HTTP headers - may contain sensitive info")
dumpBodies = flag.Bool("dump-bodies", false, "Dump HTTP headers and bodies - may contain sensitive info")
overrideRemote = flag.String("remote", "", "Set this to override the default remote name (eg s3:)")
isLocalRemote bool
) )
// ExtraConfigItem describes a config item added on the fly while testing // ExtraConfigItem describes a config item added on the fly while testing
@ -69,22 +64,14 @@ func TestInit(t *testing.T) {
file2.Path = winPath(file2.Path) file2.Path = winPath(file2.Path)
} }
// Never ask for passwords, fail instead. fstest.Initialise()
// If your local config is encrypted set environment variable
// "RCLONE_CONFIG_PASS=hunter2" (or your password)
*fs.AskPassword = false
fs.LoadConfig()
// Set extra config if supplied // Set extra config if supplied
for _, item := range ExtraConfig { for _, item := range ExtraConfig {
fs.ConfigFileSet(item.Name, item.Key, item.Value) fs.ConfigFileSet(item.Name, item.Key, item.Value)
} }
if *verbose { if *fstest.RemoteName != "" {
fs.Config.LogLevel = fs.LogLevelDebug RemoteName = *fstest.RemoteName
}
fs.Config.DumpHeaders = *dumpHeaders
fs.Config.DumpBodies = *dumpBodies
if *overrideRemote != "" {
RemoteName = *overrideRemote
} }
t.Logf("Using remote %q", RemoteName) t.Logf("Using remote %q", RemoteName)
if RemoteName == "" { if RemoteName == "" {