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:
Eng Zer Jun 2022-01-30 00:24:56 +08:00 committed by Nick Craig-Wood
parent 18c24014da
commit 8cf76f5e11
10 changed files with 26 additions and 94 deletions

View file

@ -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)

View file

@ -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)

View file

@ -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{

View file

@ -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)

View file

@ -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

View file

@ -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

View file

@ -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

View 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
} }

View file

@ -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")

View file

@ -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)