forked from TrueCloudLab/rclone
test: use T.TempDir
to create temporary test directory
The directory created by `T.TempDir` is automatically removed when the test and all its subtests complete. Reference: https://pkg.go.dev/testing#T.TempDir Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
This commit is contained in:
parent
18c24014da
commit
8cf76f5e11
10 changed files with 26 additions and 94 deletions
|
@ -422,11 +422,7 @@ func (f *Fs) InternalTestCopyID(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
o := obj.(*Object)
|
o := obj.(*Object)
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "rclone-drive-copyid-test")
|
dir := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
defer func() {
|
|
||||||
_ = os.RemoveAll(dir)
|
|
||||||
}()
|
|
||||||
|
|
||||||
checkFile := func(name string) {
|
checkFile := func(name string) {
|
||||||
filePath := filepath.Join(dir, name)
|
filePath := filepath.Join(dir, name)
|
||||||
|
@ -491,19 +487,11 @@ func (f *Fs) InternalTestAgeQuery(t *testing.T) {
|
||||||
subFs, isDriveFs := subFsResult.(*Fs)
|
subFs, isDriveFs := subFsResult.(*Fs)
|
||||||
require.True(t, isDriveFs)
|
require.True(t, isDriveFs)
|
||||||
|
|
||||||
tempDir1, err := ioutil.TempDir("", "rclone-drive-agequery1-test")
|
tempDir1 := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
defer func() {
|
|
||||||
_ = os.RemoveAll(tempDir1)
|
|
||||||
}()
|
|
||||||
tempFs1, err := fs.NewFs(defCtx, tempDir1)
|
tempFs1, err := fs.NewFs(defCtx, tempDir1)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
tempDir2, err := ioutil.TempDir("", "rclone-drive-agequery2-test")
|
tempDir2 := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
defer func() {
|
|
||||||
_ = os.RemoveAll(tempDir2)
|
|
||||||
}()
|
|
||||||
tempFs2, err := fs.NewFs(defCtx, tempDir2)
|
tempFs2, err := fs.NewFs(defCtx, tempDir2)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,6 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -20,19 +18,12 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
// MakeTestDirs makes directories in /tmp for testing
|
// MakeTestDirs makes directories in /tmp for testing
|
||||||
func MakeTestDirs(t *testing.T, n int) (dirs []string, clean func()) {
|
func MakeTestDirs(t *testing.T, n int) (dirs []string) {
|
||||||
for i := 1; i <= n; i++ {
|
for i := 1; i <= n; i++ {
|
||||||
dir, err := ioutil.TempDir("", fmt.Sprintf("rclone-union-test-%d", n))
|
dir := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
dirs = append(dirs, dir)
|
dirs = append(dirs, dir)
|
||||||
}
|
}
|
||||||
clean = func() {
|
return dirs
|
||||||
for _, dir := range dirs {
|
|
||||||
err := os.RemoveAll(dir)
|
|
||||||
assert.NoError(t, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return dirs, clean
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *Fs) TestInternalReadOnly(t *testing.T) {
|
func (f *Fs) TestInternalReadOnly(t *testing.T) {
|
||||||
|
@ -95,8 +86,7 @@ func TestMoveCopy(t *testing.T) {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
dirs, clean := MakeTestDirs(t, 1)
|
dirs := MakeTestDirs(t, 1)
|
||||||
defer clean()
|
|
||||||
fsString := fmt.Sprintf(":union,upstreams='%s :memory:bucket':", dirs[0])
|
fsString := fmt.Sprintf(":union,upstreams='%s :memory:bucket':", dirs[0])
|
||||||
f, err := fs.NewFs(ctx, fsString)
|
f, err := fs.NewFs(ctx, fsString)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
|
@ -27,8 +27,7 @@ func TestStandard(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
||||||
name := "TestUnion"
|
name := "TestUnion"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
@ -49,8 +48,7 @@ func TestRO(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + ":ro " + dirs[2] + ":ro"
|
upstreams := dirs[0] + " " + dirs[1] + ":ro " + dirs[2] + ":ro"
|
||||||
name := "TestUnionRO"
|
name := "TestUnionRO"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
@ -71,8 +69,7 @@ func TestNC(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + ":nc " + dirs[2] + ":nc"
|
upstreams := dirs[0] + " " + dirs[1] + ":nc " + dirs[2] + ":nc"
|
||||||
name := "TestUnionNC"
|
name := "TestUnionNC"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
@ -93,8 +90,7 @@ func TestPolicy1(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
||||||
name := "TestUnionPolicy1"
|
name := "TestUnionPolicy1"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
@ -115,8 +111,7 @@ func TestPolicy2(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
||||||
name := "TestUnionPolicy2"
|
name := "TestUnionPolicy2"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
@ -137,8 +132,7 @@ func TestPolicy3(t *testing.T) {
|
||||||
if *fstest.RemoteName != "" {
|
if *fstest.RemoteName != "" {
|
||||||
t.Skip("Skipping as -remote set")
|
t.Skip("Skipping as -remote set")
|
||||||
}
|
}
|
||||||
dirs, clean := union.MakeTestDirs(t, 3)
|
dirs := union.MakeTestDirs(t, 3)
|
||||||
defer clean()
|
|
||||||
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
upstreams := dirs[0] + " " + dirs[1] + " " + dirs[2]
|
||||||
name := "TestUnionPolicy3"
|
name := "TestUnionPolicy3"
|
||||||
fstests.Run(t, &fstests.Opt{
|
fstests.Run(t, &fstests.Opt{
|
||||||
|
|
|
@ -35,19 +35,14 @@ func TestRc(t *testing.T) {
|
||||||
getMountTypes := rc.Calls.Get("mount/types")
|
getMountTypes := rc.Calls.Get("mount/types")
|
||||||
assert.NotNil(t, getMountTypes)
|
assert.NotNil(t, getMountTypes)
|
||||||
|
|
||||||
localDir, err := ioutil.TempDir("", "rclone-mountlib-localDir")
|
localDir := t.TempDir()
|
||||||
require.NoError(t, err)
|
err := ioutil.WriteFile(filepath.Join(localDir, "file.txt"), []byte("hello"), 0666)
|
||||||
defer func() { _ = os.RemoveAll(localDir) }()
|
|
||||||
err = ioutil.WriteFile(filepath.Join(localDir, "file.txt"), []byte("hello"), 0666)
|
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
mountPoint, err := ioutil.TempDir("", "rclone-mountlib-mountPoint")
|
mountPoint := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
if runtime.GOOS == "windows" {
|
if runtime.GOOS == "windows" {
|
||||||
// Windows requires the mount point not to exist
|
// Windows requires the mount point not to exist
|
||||||
require.NoError(t, os.RemoveAll(mountPoint))
|
require.NoError(t, os.RemoveAll(mountPoint))
|
||||||
} else {
|
|
||||||
defer func() { _ = os.RemoveAll(mountPoint) }()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
out, err := getMountTypes.Fn(ctx, nil)
|
out, err := getMountTypes.Fn(ctx, nil)
|
||||||
|
|
|
@ -7,9 +7,7 @@ import (
|
||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -113,14 +111,7 @@ func TestResticHandler(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// setup rclone with a local backend in a temporary directory
|
// setup rclone with a local backend in a temporary directory
|
||||||
tempdir, err := ioutil.TempDir("", "rclone-restic-test-")
|
tempdir := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
|
|
||||||
// make sure the tempdir is properly removed
|
|
||||||
defer func() {
|
|
||||||
err := os.RemoveAll(tempdir)
|
|
||||||
require.NoError(t, err)
|
|
||||||
}()
|
|
||||||
|
|
||||||
// globally set append-only mode
|
// globally set append-only mode
|
||||||
prev := appendOnly
|
prev := appendOnly
|
||||||
|
|
|
@ -7,9 +7,7 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -35,14 +33,7 @@ func TestResticPrivateRepositories(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
// setup rclone with a local backend in a temporary directory
|
// setup rclone with a local backend in a temporary directory
|
||||||
tempdir, err := ioutil.TempDir("", "rclone-restic-test-")
|
tempdir := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
|
|
||||||
// make sure the tempdir is properly removed
|
|
||||||
defer func() {
|
|
||||||
err := os.RemoveAll(tempdir)
|
|
||||||
require.NoError(t, err)
|
|
||||||
}()
|
|
||||||
|
|
||||||
// globally set private-repos mode & test user
|
// globally set private-repos mode & test user
|
||||||
prev := privateRepos
|
prev := privateRepos
|
||||||
|
|
|
@ -102,8 +102,7 @@ var envInitial []string
|
||||||
// sets testConfig to testFolder/rclone.config.
|
// sets testConfig to testFolder/rclone.config.
|
||||||
func createTestEnvironment(t *testing.T) {
|
func createTestEnvironment(t *testing.T) {
|
||||||
//Set temporary folder for config and test data
|
//Set temporary folder for config and test data
|
||||||
tempFolder, err := ioutil.TempDir("", "rclone_cmdtest_")
|
tempFolder := t.TempDir()
|
||||||
require.NoError(t, err)
|
|
||||||
testFolder = filepath.ToSlash(tempFolder)
|
testFolder = filepath.ToSlash(tempFolder)
|
||||||
|
|
||||||
// Set path to temporary config file
|
// Set path to temporary config file
|
||||||
|
|
|
@ -2,7 +2,6 @@ package webgui
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
@ -24,13 +23,12 @@ func init() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func setCacheDir(t *testing.T) string {
|
func setCacheDir(t *testing.T) string {
|
||||||
cacheDir, err := ioutil.TempDir("", "rclone-cache-dir")
|
cacheDir := t.TempDir()
|
||||||
assert.Nil(t, err)
|
|
||||||
PluginsPath = filepath.Join(cacheDir, "plugins")
|
PluginsPath = filepath.Join(cacheDir, "plugins")
|
||||||
pluginsConfigPath = filepath.Join(cacheDir, "config")
|
pluginsConfigPath = filepath.Join(cacheDir, "config")
|
||||||
|
|
||||||
loadedPlugins = newPlugins(availablePluginsJSONPath)
|
loadedPlugins = newPlugins(availablePluginsJSONPath)
|
||||||
err = loadedPlugins.readFromFile()
|
err := loadedPlugins.readFromFile()
|
||||||
assert.Nil(t, err)
|
assert.Nil(t, err)
|
||||||
return cacheDir
|
return cacheDir
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,15 +13,6 @@ import (
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Create a test directory then tidy up
|
|
||||||
func testDir(t *testing.T) (string, func()) {
|
|
||||||
dir, err := ioutil.TempDir("", "rclone-test")
|
|
||||||
require.NoError(t, err)
|
|
||||||
return dir, func() {
|
|
||||||
assert.NoError(t, os.RemoveAll(dir))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// This lists dir and checks the listing is as expected without checking the size
|
// This lists dir and checks the listing is as expected without checking the size
|
||||||
func checkListingNoSize(t *testing.T, dir string, want []string) {
|
func checkListingNoSize(t *testing.T, dir string, want []string) {
|
||||||
var got []string
|
var got []string
|
||||||
|
@ -46,8 +37,7 @@ func checkListing(t *testing.T, dir string, want []string) {
|
||||||
|
|
||||||
// Test we can rename an open file
|
// Test we can rename an open file
|
||||||
func TestOpenFileRename(t *testing.T) {
|
func TestOpenFileRename(t *testing.T) {
|
||||||
dir, tidy := testDir(t)
|
dir := t.TempDir()
|
||||||
defer tidy()
|
|
||||||
|
|
||||||
filepath := path.Join(dir, "file1")
|
filepath := path.Join(dir, "file1")
|
||||||
f, err := Create(filepath)
|
f, err := Create(filepath)
|
||||||
|
@ -71,8 +61,7 @@ func TestOpenFileRename(t *testing.T) {
|
||||||
|
|
||||||
// Test we can delete an open file
|
// Test we can delete an open file
|
||||||
func TestOpenFileDelete(t *testing.T) {
|
func TestOpenFileDelete(t *testing.T) {
|
||||||
dir, tidy := testDir(t)
|
dir := t.TempDir()
|
||||||
defer tidy()
|
|
||||||
|
|
||||||
filepath := path.Join(dir, "file1")
|
filepath := path.Join(dir, "file1")
|
||||||
f, err := Create(filepath)
|
f, err := Create(filepath)
|
||||||
|
@ -103,8 +92,7 @@ func TestOpenFileDelete(t *testing.T) {
|
||||||
|
|
||||||
// Smoke test the Open, OpenFile and Create functions
|
// Smoke test the Open, OpenFile and Create functions
|
||||||
func TestOpenFileOperations(t *testing.T) {
|
func TestOpenFileOperations(t *testing.T) {
|
||||||
dir, tidy := testDir(t)
|
dir := t.TempDir()
|
||||||
defer tidy()
|
|
||||||
|
|
||||||
filepath := path.Join(dir, "file1")
|
filepath := path.Join(dir, "file1")
|
||||||
|
|
||||||
|
|
|
@ -15,8 +15,7 @@ import (
|
||||||
|
|
||||||
// Basic test from golang's os/path_test.go
|
// Basic test from golang's os/path_test.go
|
||||||
func TestMkdirAll(t *testing.T) {
|
func TestMkdirAll(t *testing.T) {
|
||||||
tmpDir, tidy := testDir(t)
|
tmpDir := t.TempDir()
|
||||||
defer tidy()
|
|
||||||
|
|
||||||
path := tmpDir + "/dir/./dir2"
|
path := tmpDir + "/dir/./dir2"
|
||||||
err := MkdirAll(path, 0777)
|
err := MkdirAll(path, 0777)
|
||||||
|
@ -99,8 +98,7 @@ func checkMkdirAllSubdirs(t *testing.T, path string, valid bool, errormsg string
|
||||||
|
|
||||||
// Testing paths on existing drive
|
// Testing paths on existing drive
|
||||||
func TestMkdirAllOnDrive(t *testing.T) {
|
func TestMkdirAllOnDrive(t *testing.T) {
|
||||||
path, tidy := testDir(t)
|
path := t.TempDir()
|
||||||
defer tidy()
|
|
||||||
|
|
||||||
dir, err := os.Stat(path)
|
dir, err := os.Stat(path)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
Loading…
Reference in a new issue