restic/internal/backend/local/local_test.go

134 lines
2.7 KiB
Go
Raw Normal View History

2016-01-23 16:08:03 +00:00
package local_test
import (
"context"
"os"
"path/filepath"
2017-05-01 20:46:51 +00:00
"testing"
2016-01-23 16:08:03 +00:00
2017-07-23 12:21:03 +00:00
"github.com/restic/restic/internal/backend/local"
"github.com/restic/restic/internal/backend/test"
2017-07-24 15:42:25 +00:00
"github.com/restic/restic/internal/restic"
2017-10-02 13:06:39 +00:00
rtest "github.com/restic/restic/internal/test"
2016-01-23 16:08:03 +00:00
)
func newTestSuite(t testing.TB) *test.Suite[local.Config] {
return &test.Suite[local.Config]{
2017-05-01 20:46:51 +00:00
// NewConfig returns a config for a new temporary backend that will be used in tests.
NewConfig: func() (local.Config, error) {
dir, err := os.MkdirTemp(rtest.TestTempDir, "restic-test-local-")
2017-05-01 20:46:51 +00:00
if err != nil {
t.Fatal(err)
}
t.Logf("create new backend at %v", dir)
cfg := local.Config{
Path: dir,
Connections: 2,
2017-05-01 20:46:51 +00:00
}
return cfg, nil
},
// CreateFn is a function that creates a temporary repository for the tests.
Create: func(cfg local.Config) (restic.Backend, error) {
return local.Create(context.TODO(), cfg)
2017-05-01 20:46:51 +00:00
},
// OpenFn is a function that opens a previously created temporary repository.
Open: func(cfg local.Config) (restic.Backend, error) {
return local.Open(context.TODO(), cfg)
2017-05-01 20:46:51 +00:00
},
// CleanupFn removes data created during the tests.
Cleanup: func(cfg local.Config) error {
2017-10-02 13:06:39 +00:00
if !rtest.TestCleanupTempDirs {
2017-05-01 20:46:51 +00:00
t.Logf("leaving test backend dir at %v", cfg.Path)
}
2017-10-02 13:06:39 +00:00
rtest.RemoveAll(t, cfg.Path)
2016-01-23 16:08:03 +00:00
return nil
2017-05-01 20:46:51 +00:00
},
2016-01-23 16:08:03 +00:00
}
2017-05-13 19:45:41 +00:00
}
func TestBackend(t *testing.T) {
newTestSuite(t).RunTests(t)
}
2017-05-01 20:46:51 +00:00
2017-05-13 19:45:41 +00:00
func BenchmarkBackend(t *testing.B) {
newTestSuite(t).RunBenchmarks(t)
2016-01-23 16:08:03 +00:00
}
func readdirnames(t testing.TB, dir string) []string {
f, err := os.Open(dir)
if err != nil {
t.Fatal(err)
}
entries, err := f.Readdirnames(-1)
if err != nil {
t.Fatal(err)
}
err = f.Close()
if err != nil {
t.Fatal(err)
}
return entries
}
func empty(t testing.TB, dir string) {
entries := readdirnames(t, dir)
if len(entries) != 0 {
t.Fatalf("directory %v is not empty, contains: %v", dir, entries)
}
}
func openclose(t testing.TB, dir string) {
cfg := local.Config{Path: dir}
be, err := local.Open(context.TODO(), cfg)
if err != nil {
t.Logf("Open returned error %v", err)
}
if be != nil {
err = be.Close()
if err != nil {
t.Logf("Close returned error %v", err)
}
}
}
func mkdir(t testing.TB, dir string) {
err := os.Mkdir(dir, 0700)
if err != nil {
t.Fatal(err)
}
}
func removeAll(t testing.TB, dir string) {
err := os.RemoveAll(dir)
if err != nil {
t.Fatal(err)
}
}
func TestOpenNotExistingDirectory(t *testing.T) {
dir := rtest.TempDir(t)
// local.Open must not create any files dirs in the repo
openclose(t, filepath.Join(dir, "repo"))
empty(t, dir)
openclose(t, dir)
empty(t, dir)
mkdir(t, filepath.Join(dir, "data"))
openclose(t, dir)
removeAll(t, filepath.Join(dir, "data"))
empty(t, dir)
}