forked from TrueCloudLab/restic
remove usages of repo.Backend() from tests
This commit is contained in:
parent
aa4647f773
commit
8a425c2f0a
18 changed files with 96 additions and 95 deletions
|
@ -1970,7 +1970,7 @@ func TestArchiverContextCanceled(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
// Ensure that the archiver itself reports the canceled context and not just the backend
|
// Ensure that the archiver itself reports the canceled context and not just the backend
|
||||||
repo := repository.TestRepositoryWithBackend(t, &noCancelBackend{mem.New()}, 0, repository.Options{})
|
repo, _ := repository.TestRepositoryWithBackend(t, &noCancelBackend{mem.New()}, 0, repository.Options{})
|
||||||
|
|
||||||
back := rtest.Chdir(t, tempdir)
|
back := rtest.Chdir(t, tempdir)
|
||||||
defer back()
|
defer back()
|
||||||
|
|
|
@ -73,7 +73,7 @@ func assertOnlyMixedPackHints(t *testing.T, hints []error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCheckRepo(t *testing.T) {
|
func TestCheckRepo(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
chkr := checker.New(repo, false)
|
chkr := checker.New(repo, false)
|
||||||
|
@ -91,7 +91,7 @@ func TestCheckRepo(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMissingPack(t *testing.T) {
|
func TestMissingPack(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
packID := restic.TestParseID("657f7fb64f6a854fff6fe9279998ee09034901eded4e6db9bcee0e59745bbce6")
|
packID := restic.TestParseID("657f7fb64f6a854fff6fe9279998ee09034901eded4e6db9bcee0e59745bbce6")
|
||||||
|
@ -117,7 +117,7 @@ func TestMissingPack(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUnreferencedPack(t *testing.T) {
|
func TestUnreferencedPack(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
// index 3f1a only references pack 60e0
|
// index 3f1a only references pack 60e0
|
||||||
|
@ -145,7 +145,7 @@ func TestUnreferencedPack(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUnreferencedBlobs(t *testing.T) {
|
func TestUnreferencedBlobs(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
snapshotID := restic.TestParseID("51d249d28815200d59e4be7b3f21a157b864dc343353df9d8e498220c2499b02")
|
snapshotID := restic.TestParseID("51d249d28815200d59e4be7b3f21a157b864dc343353df9d8e498220c2499b02")
|
||||||
|
@ -180,7 +180,7 @@ func TestUnreferencedBlobs(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestModifiedIndex(t *testing.T) {
|
func TestModifiedIndex(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, be, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
done := make(chan struct{})
|
done := make(chan struct{})
|
||||||
|
@ -208,13 +208,13 @@ func TestModifiedIndex(t *testing.T) {
|
||||||
}()
|
}()
|
||||||
wr := io.Writer(tmpfile)
|
wr := io.Writer(tmpfile)
|
||||||
var hw *hashing.Writer
|
var hw *hashing.Writer
|
||||||
if repo.Backend().Hasher() != nil {
|
if be.Hasher() != nil {
|
||||||
hw = hashing.NewWriter(wr, repo.Backend().Hasher())
|
hw = hashing.NewWriter(wr, be.Hasher())
|
||||||
wr = hw
|
wr = hw
|
||||||
}
|
}
|
||||||
|
|
||||||
// read the file from the backend
|
// read the file from the backend
|
||||||
err = repo.Backend().Load(context.TODO(), h, 0, 0, func(rd io.Reader) error {
|
err = be.Load(context.TODO(), h, 0, 0, func(rd io.Reader) error {
|
||||||
_, err := io.Copy(wr, rd)
|
_, err := io.Copy(wr, rd)
|
||||||
return err
|
return err
|
||||||
})
|
})
|
||||||
|
@ -236,7 +236,7 @@ func TestModifiedIndex(t *testing.T) {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = repo.Backend().Save(context.TODO(), h2, rd)
|
err = be.Save(context.TODO(), h2, rd)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -257,7 +257,7 @@ func TestModifiedIndex(t *testing.T) {
|
||||||
var checkerDuplicateIndexTestData = filepath.Join("testdata", "duplicate-packs-in-index-test-repo.tar.gz")
|
var checkerDuplicateIndexTestData = filepath.Join("testdata", "duplicate-packs-in-index-test-repo.tar.gz")
|
||||||
|
|
||||||
func TestDuplicatePacksInIndex(t *testing.T) {
|
func TestDuplicatePacksInIndex(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerDuplicateIndexTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerDuplicateIndexTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
chkr := checker.New(repo, false)
|
chkr := checker.New(repo, false)
|
||||||
|
@ -334,11 +334,11 @@ func (b *errorOnceBackend) Load(ctx context.Context, h backend.Handle, length in
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCheckerModifiedData(t *testing.T) {
|
func TestCheckerModifiedData(t *testing.T) {
|
||||||
repo := repository.TestRepository(t)
|
repo, be := repository.TestRepositoryWithVersion(t, 0)
|
||||||
sn := archiver.TestSnapshot(t, repo, ".", nil)
|
sn := archiver.TestSnapshot(t, repo, ".", nil)
|
||||||
t.Logf("archived as %v", sn.ID().Str())
|
t.Logf("archived as %v", sn.ID().Str())
|
||||||
|
|
||||||
errBe := &errorBackend{Backend: repo.Backend()}
|
errBe := &errorBackend{Backend: be}
|
||||||
|
|
||||||
for _, test := range []struct {
|
for _, test := range []struct {
|
||||||
name string
|
name string
|
||||||
|
@ -360,7 +360,7 @@ func TestCheckerModifiedData(t *testing.T) {
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"errorOnceBackend",
|
"errorOnceBackend",
|
||||||
&errorOnceBackend{Backend: repo.Backend()},
|
&errorOnceBackend{Backend: be},
|
||||||
func() {},
|
func() {},
|
||||||
func(t *testing.T, err error) {
|
func(t *testing.T, err error) {
|
||||||
if !strings.Contains(err.Error(), "check successful on second attempt, original error pack") {
|
if !strings.Contains(err.Error(), "check successful on second attempt, original error pack") {
|
||||||
|
@ -427,7 +427,7 @@ func (r *loadTreesOnceRepository) LoadTree(ctx context.Context, id restic.ID) (*
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCheckerNoDuplicateTreeDecodes(t *testing.T) {
|
func TestCheckerNoDuplicateTreeDecodes(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
checkRepo := &loadTreesOnceRepository{
|
checkRepo := &loadTreesOnceRepository{
|
||||||
Repository: repo,
|
Repository: repo,
|
||||||
|
@ -575,7 +575,7 @@ func TestCheckerBlobTypeConfusion(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadBenchRepository(t *testing.B) (*checker.Checker, restic.Repository, func()) {
|
func loadBenchRepository(t *testing.B) (*checker.Checker, restic.Repository, func()) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, checkerTestData)
|
repo, _, cleanup := repository.TestFromFixture(t, checkerTestData)
|
||||||
|
|
||||||
chkr := checker.New(repo, false)
|
chkr := checker.New(repo, false)
|
||||||
hints, errs := chkr.LoadIndex(context.TODO(), nil)
|
hints, errs := chkr.LoadIndex(context.TODO(), nil)
|
||||||
|
|
|
@ -15,7 +15,7 @@ import (
|
||||||
var repoFixture = filepath.Join("..", "repository", "testdata", "test-repo.tar.gz")
|
var repoFixture = filepath.Join("..", "repository", "testdata", "test-repo.tar.gz")
|
||||||
|
|
||||||
func TestRepositoryForAllIndexes(t *testing.T) {
|
func TestRepositoryForAllIndexes(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, repoFixture)
|
repo, _, cleanup := repository.TestFromFixture(t, repoFixture)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
expectedIndexIDs := restic.NewIDSet()
|
expectedIndexIDs := restic.NewIDSet()
|
||||||
|
|
|
@ -342,7 +342,7 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
func createFilledRepo(t testing.TB, snapshots int, version uint) restic.Repository {
|
func createFilledRepo(t testing.TB, snapshots int, version uint) restic.Repository {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
for i := 0; i < snapshots; i++ {
|
for i := 0; i < snapshots; i++ {
|
||||||
restic.TestCreateSnapshot(t, repo, snapshotTime.Add(time.Duration(i)*time.Second), depth)
|
restic.TestCreateSnapshot(t, repo, snapshotTime.Add(time.Duration(i)*time.Second), depth)
|
||||||
|
|
|
@ -8,7 +8,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestUpgradeRepoV2(t *testing.T) {
|
func TestUpgradeRepoV2(t *testing.T) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, 1)
|
repo, _ := repository.TestRepositoryWithVersion(t, 1)
|
||||||
if repo.Config().Version != 1 {
|
if repo.Config().Version != 1 {
|
||||||
t.Fatal("test repo has wrong version")
|
t.Fatal("test repo has wrong version")
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ func FuzzSaveLoadBlob(f *testing.F) {
|
||||||
}
|
}
|
||||||
|
|
||||||
id := restic.Hash(blob)
|
id := restic.Hash(blob)
|
||||||
repo := TestRepositoryWithVersion(t, 2)
|
repo, _ := TestRepositoryWithVersion(t, 2)
|
||||||
|
|
||||||
var wg errgroup.Group
|
var wg errgroup.Group
|
||||||
repo.StartPackUploader(context.TODO(), &wg)
|
repo.StartPackUploader(context.TODO(), &wg)
|
||||||
|
|
|
@ -19,7 +19,7 @@ import (
|
||||||
|
|
||||||
type backendWrapper func(r backend.Backend) (backend.Backend, error)
|
type backendWrapper func(r backend.Backend) (backend.Backend, error)
|
||||||
|
|
||||||
func openLockTestRepo(t *testing.T, wrapper backendWrapper) *Repository {
|
func openLockTestRepo(t *testing.T, wrapper backendWrapper) (*Repository, backend.Backend) {
|
||||||
be := backend.Backend(mem.New())
|
be := backend.Backend(mem.New())
|
||||||
// initialize repo
|
// initialize repo
|
||||||
TestRepositoryWithBackend(t, be, 0, Options{})
|
TestRepositoryWithBackend(t, be, 0, Options{})
|
||||||
|
@ -31,7 +31,7 @@ func openLockTestRepo(t *testing.T, wrapper backendWrapper) *Repository {
|
||||||
rtest.OK(t, err)
|
rtest.OK(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return TestOpenBackend(t, be)
|
return TestOpenBackend(t, be), be
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkedLockRepo(ctx context.Context, t *testing.T, repo *Repository, lockerInst *locker, retryLock time.Duration) (*Unlocker, context.Context) {
|
func checkedLockRepo(ctx context.Context, t *testing.T, repo *Repository, lockerInst *locker, retryLock time.Duration) (*Unlocker, context.Context) {
|
||||||
|
@ -46,7 +46,7 @@ func checkedLockRepo(ctx context.Context, t *testing.T, repo *Repository, locker
|
||||||
|
|
||||||
func TestLock(t *testing.T) {
|
func TestLock(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, _ := openLockTestRepo(t, nil)
|
||||||
|
|
||||||
lock, wrappedCtx := checkedLockRepo(context.Background(), t, repo, lockerInst, 0)
|
lock, wrappedCtx := checkedLockRepo(context.Background(), t, repo, lockerInst, 0)
|
||||||
lock.Unlock()
|
lock.Unlock()
|
||||||
|
@ -57,7 +57,7 @@ func TestLock(t *testing.T) {
|
||||||
|
|
||||||
func TestLockCancel(t *testing.T) {
|
func TestLockCancel(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, _ := openLockTestRepo(t, nil)
|
||||||
|
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
defer cancel()
|
defer cancel()
|
||||||
|
@ -73,8 +73,8 @@ func TestLockCancel(t *testing.T) {
|
||||||
|
|
||||||
func TestLockConflict(t *testing.T) {
|
func TestLockConflict(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, be := openLockTestRepo(t, nil)
|
||||||
repo2 := TestOpenBackend(t, repo.Backend())
|
repo2 := TestOpenBackend(t, be)
|
||||||
|
|
||||||
lock, _, err := Lock(context.Background(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
lock, _, err := Lock(context.Background(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
||||||
test.OK(t, err)
|
test.OK(t, err)
|
||||||
|
@ -101,7 +101,7 @@ func (b *writeOnceBackend) Save(ctx context.Context, h backend.Handle, rd backen
|
||||||
|
|
||||||
func TestLockFailedRefresh(t *testing.T) {
|
func TestLockFailedRefresh(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
repo, _ := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
||||||
return &writeOnceBackend{Backend: r}, nil
|
return &writeOnceBackend{Backend: r}, nil
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -138,7 +138,7 @@ func (b *loggingBackend) Save(ctx context.Context, h backend.Handle, rd backend.
|
||||||
|
|
||||||
func TestLockSuccessfulRefresh(t *testing.T) {
|
func TestLockSuccessfulRefresh(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
repo, _ := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
||||||
return &loggingBackend{
|
return &loggingBackend{
|
||||||
Backend: r,
|
Backend: r,
|
||||||
t: t,
|
t: t,
|
||||||
|
@ -190,7 +190,7 @@ func (b *slowBackend) Save(ctx context.Context, h backend.Handle, rd backend.Rew
|
||||||
func TestLockSuccessfulStaleRefresh(t *testing.T) {
|
func TestLockSuccessfulStaleRefresh(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
var sb *slowBackend
|
var sb *slowBackend
|
||||||
repo := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
repo, _ := openLockTestRepo(t, func(r backend.Backend) (backend.Backend, error) {
|
||||||
sb = &slowBackend{Backend: r}
|
sb = &slowBackend{Backend: r}
|
||||||
return sb, nil
|
return sb, nil
|
||||||
})
|
})
|
||||||
|
@ -238,7 +238,7 @@ func TestLockSuccessfulStaleRefresh(t *testing.T) {
|
||||||
|
|
||||||
func TestLockWaitTimeout(t *testing.T) {
|
func TestLockWaitTimeout(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, _ := openLockTestRepo(t, nil)
|
||||||
|
|
||||||
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
||||||
test.OK(t, err)
|
test.OK(t, err)
|
||||||
|
@ -260,7 +260,7 @@ func TestLockWaitTimeout(t *testing.T) {
|
||||||
|
|
||||||
func TestLockWaitCancel(t *testing.T) {
|
func TestLockWaitCancel(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, _ := openLockTestRepo(t, nil)
|
||||||
|
|
||||||
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
||||||
test.OK(t, err)
|
test.OK(t, err)
|
||||||
|
@ -286,7 +286,7 @@ func TestLockWaitCancel(t *testing.T) {
|
||||||
|
|
||||||
func TestLockWaitSuccess(t *testing.T) {
|
func TestLockWaitSuccess(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
repo := openLockTestRepo(t, nil)
|
repo, _ := openLockTestRepo(t, nil)
|
||||||
|
|
||||||
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
elock, _, err := Lock(context.TODO(), repo, true, 0, func(msg string) {}, func(format string, args ...interface{}) {})
|
||||||
test.OK(t, err)
|
test.OK(t, err)
|
||||||
|
|
|
@ -14,7 +14,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func testPrune(t *testing.T, opts repository.PruneOptions, errOnUnused bool) {
|
func testPrune(t *testing.T, opts repository.PruneOptions, errOnUnused bool) {
|
||||||
repo := repository.TestRepository(t)
|
repo, be := repository.TestRepositoryWithVersion(t, 0)
|
||||||
createRandomBlobs(t, repo, 4, 0.5, true)
|
createRandomBlobs(t, repo, 4, 0.5, true)
|
||||||
createRandomBlobs(t, repo, 5, 0.5, true)
|
createRandomBlobs(t, repo, 5, 0.5, true)
|
||||||
keep, _ := selectBlobs(t, repo, 0.5)
|
keep, _ := selectBlobs(t, repo, 0.5)
|
||||||
|
@ -37,7 +37,7 @@ func testPrune(t *testing.T, opts repository.PruneOptions, errOnUnused bool) {
|
||||||
|
|
||||||
rtest.OK(t, plan.Execute(context.TODO(), &progress.NoopPrinter{}))
|
rtest.OK(t, plan.Execute(context.TODO(), &progress.NoopPrinter{}))
|
||||||
|
|
||||||
repo = repository.TestOpenBackend(t, repo.Backend())
|
repo = repository.TestOpenBackend(t, be)
|
||||||
checker.TestCheckRepo(t, repo, true)
|
checker.TestCheckRepo(t, repo, true)
|
||||||
|
|
||||||
if errOnUnused {
|
if errOnUnused {
|
||||||
|
|
|
@ -215,7 +215,7 @@ func TestRepack(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testRepack(t *testing.T, version uint) {
|
func testRepack(t *testing.T, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
seed := time.Now().UnixNano()
|
seed := time.Now().UnixNano()
|
||||||
rand.Seed(seed)
|
rand.Seed(seed)
|
||||||
|
@ -293,8 +293,8 @@ func (r oneConnectionRepo) Connections() uint {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testRepackCopy(t *testing.T, version uint) {
|
func testRepackCopy(t *testing.T, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
dstRepo := repository.TestRepositoryWithVersion(t, version)
|
dstRepo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
// test with minimal possible connection count
|
// test with minimal possible connection count
|
||||||
repoWrapped := &oneConnectionRepo{repo}
|
repoWrapped := &oneConnectionRepo{repo}
|
||||||
|
@ -340,7 +340,7 @@ func TestRepackWrongBlob(t *testing.T) {
|
||||||
|
|
||||||
func testRepackWrongBlob(t *testing.T, version uint) {
|
func testRepackWrongBlob(t *testing.T, version uint) {
|
||||||
// disable verification to allow adding corrupted blobs to the repository
|
// disable verification to allow adding corrupted blobs to the repository
|
||||||
repo := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
repo, _ := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
||||||
|
|
||||||
seed := time.Now().UnixNano()
|
seed := time.Now().UnixNano()
|
||||||
rand.Seed(seed)
|
rand.Seed(seed)
|
||||||
|
@ -366,7 +366,7 @@ func TestRepackBlobFallback(t *testing.T) {
|
||||||
|
|
||||||
func testRepackBlobFallback(t *testing.T, version uint) {
|
func testRepackBlobFallback(t *testing.T, version uint) {
|
||||||
// disable verification to allow adding corrupted blobs to the repository
|
// disable verification to allow adding corrupted blobs to the repository
|
||||||
repo := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
repo, _ := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
||||||
|
|
||||||
seed := time.Now().UnixNano()
|
seed := time.Now().UnixNano()
|
||||||
rand.Seed(seed)
|
rand.Seed(seed)
|
||||||
|
|
|
@ -16,16 +16,16 @@ func listIndex(t *testing.T, repo restic.Lister) restic.IDSet {
|
||||||
return listFiles(t, repo, restic.IndexFile)
|
return listFiles(t, repo, restic.IndexFile)
|
||||||
}
|
}
|
||||||
|
|
||||||
func testRebuildIndex(t *testing.T, readAllPacks bool, damage func(t *testing.T, repo *repository.Repository)) {
|
func testRebuildIndex(t *testing.T, readAllPacks bool, damage func(t *testing.T, repo *repository.Repository, be backend.Backend)) {
|
||||||
repo := repository.TestRepository(t)
|
repo, be := repository.TestRepositoryWithVersion(t, 0)
|
||||||
createRandomBlobs(t, repo, 4, 0.5, true)
|
createRandomBlobs(t, repo, 4, 0.5, true)
|
||||||
createRandomBlobs(t, repo, 5, 0.5, true)
|
createRandomBlobs(t, repo, 5, 0.5, true)
|
||||||
indexes := listIndex(t, repo)
|
indexes := listIndex(t, repo)
|
||||||
t.Logf("old indexes %v", indexes)
|
t.Logf("old indexes %v", indexes)
|
||||||
|
|
||||||
damage(t, repo)
|
damage(t, repo, be)
|
||||||
|
|
||||||
repo = repository.TestOpenBackend(t, repo.Backend())
|
repo = repository.TestOpenBackend(t, be)
|
||||||
rtest.OK(t, repository.RepairIndex(context.TODO(), repo, repository.RepairIndexOptions{
|
rtest.OK(t, repository.RepairIndex(context.TODO(), repo, repository.RepairIndexOptions{
|
||||||
ReadAllPacks: readAllPacks,
|
ReadAllPacks: readAllPacks,
|
||||||
}, &progress.NoopPrinter{}))
|
}, &progress.NoopPrinter{}))
|
||||||
|
@ -40,17 +40,17 @@ func testRebuildIndex(t *testing.T, readAllPacks bool, damage func(t *testing.T,
|
||||||
func TestRebuildIndex(t *testing.T) {
|
func TestRebuildIndex(t *testing.T) {
|
||||||
for _, test := range []struct {
|
for _, test := range []struct {
|
||||||
name string
|
name string
|
||||||
damage func(t *testing.T, repo *repository.Repository)
|
damage func(t *testing.T, repo *repository.Repository, be backend.Backend)
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
"valid index",
|
"valid index",
|
||||||
func(t *testing.T, repo *repository.Repository) {},
|
func(t *testing.T, repo *repository.Repository, be backend.Backend) {},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"damaged index",
|
"damaged index",
|
||||||
func(t *testing.T, repo *repository.Repository) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend) {
|
||||||
index := listIndex(t, repo).List()[0]
|
index := listIndex(t, repo).List()[0]
|
||||||
replaceFile(t, repo, backend.Handle{Type: restic.IndexFile, Name: index.String()}, func(b []byte) []byte {
|
replaceFile(t, be, backend.Handle{Type: restic.IndexFile, Name: index.String()}, func(b []byte) []byte {
|
||||||
b[0] ^= 0xff
|
b[0] ^= 0xff
|
||||||
return b
|
return b
|
||||||
})
|
})
|
||||||
|
@ -58,16 +58,16 @@ func TestRebuildIndex(t *testing.T) {
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"missing index",
|
"missing index",
|
||||||
func(t *testing.T, repo *repository.Repository) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend) {
|
||||||
index := listIndex(t, repo).List()[0]
|
index := listIndex(t, repo).List()[0]
|
||||||
rtest.OK(t, repo.Backend().Remove(context.TODO(), backend.Handle{Type: restic.IndexFile, Name: index.String()}))
|
rtest.OK(t, be.Remove(context.TODO(), backend.Handle{Type: restic.IndexFile, Name: index.String()}))
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"missing pack",
|
"missing pack",
|
||||||
func(t *testing.T, repo *repository.Repository) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend) {
|
||||||
pack := listPacks(t, repo).List()[0]
|
pack := listPacks(t, repo).List()[0]
|
||||||
rtest.OK(t, repo.Backend().Remove(context.TODO(), backend.Handle{Type: restic.PackFile, Name: pack.String()}))
|
rtest.OK(t, be.Remove(context.TODO(), backend.Handle{Type: restic.PackFile, Name: pack.String()}))
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
|
|
|
@ -24,12 +24,12 @@ func listBlobs(repo restic.Repository) restic.BlobSet {
|
||||||
return blobs
|
return blobs
|
||||||
}
|
}
|
||||||
|
|
||||||
func replaceFile(t *testing.T, repo *repository.Repository, h backend.Handle, damage func([]byte) []byte) {
|
func replaceFile(t *testing.T, be backend.Backend, h backend.Handle, damage func([]byte) []byte) {
|
||||||
buf, err := backendtest.LoadAll(context.TODO(), repo.Backend(), h)
|
buf, err := backendtest.LoadAll(context.TODO(), be, h)
|
||||||
test.OK(t, err)
|
test.OK(t, err)
|
||||||
buf = damage(buf)
|
buf = damage(buf)
|
||||||
test.OK(t, repo.Backend().Remove(context.TODO(), h))
|
test.OK(t, be.Remove(context.TODO(), h))
|
||||||
test.OK(t, repo.Backend().Save(context.TODO(), h, backend.NewByteReader(buf, repo.Backend().Hasher())))
|
test.OK(t, be.Save(context.TODO(), h, backend.NewByteReader(buf, be.Hasher())))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRepairBrokenPack(t *testing.T) {
|
func TestRepairBrokenPack(t *testing.T) {
|
||||||
|
@ -39,17 +39,17 @@ func TestRepairBrokenPack(t *testing.T) {
|
||||||
func testRepairBrokenPack(t *testing.T, version uint) {
|
func testRepairBrokenPack(t *testing.T, version uint) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
damage func(t *testing.T, repo *repository.Repository, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet)
|
damage func(t *testing.T, repo *repository.Repository, be backend.Backend, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet)
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
"valid pack",
|
"valid pack",
|
||||||
func(t *testing.T, repo *repository.Repository, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
||||||
return packsBefore, restic.NewBlobSet()
|
return packsBefore, restic.NewBlobSet()
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"broken pack",
|
"broken pack",
|
||||||
func(t *testing.T, repo *repository.Repository, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
||||||
wrongBlob := createRandomWrongBlob(t, repo)
|
wrongBlob := createRandomWrongBlob(t, repo)
|
||||||
damagedPacks := findPacksForBlobs(t, repo, restic.NewBlobSet(wrongBlob))
|
damagedPacks := findPacksForBlobs(t, repo, restic.NewBlobSet(wrongBlob))
|
||||||
return damagedPacks, restic.NewBlobSet(wrongBlob)
|
return damagedPacks, restic.NewBlobSet(wrongBlob)
|
||||||
|
@ -57,10 +57,10 @@ func testRepairBrokenPack(t *testing.T, version uint) {
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"partially broken pack",
|
"partially broken pack",
|
||||||
func(t *testing.T, repo *repository.Repository, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
||||||
// damage one of the pack files
|
// damage one of the pack files
|
||||||
damagedID := packsBefore.List()[0]
|
damagedID := packsBefore.List()[0]
|
||||||
replaceFile(t, repo, backend.Handle{Type: backend.PackFile, Name: damagedID.String()},
|
replaceFile(t, be, backend.Handle{Type: backend.PackFile, Name: damagedID.String()},
|
||||||
func(buf []byte) []byte {
|
func(buf []byte) []byte {
|
||||||
buf[0] ^= 0xff
|
buf[0] ^= 0xff
|
||||||
return buf
|
return buf
|
||||||
|
@ -80,10 +80,10 @@ func testRepairBrokenPack(t *testing.T, version uint) {
|
||||||
},
|
},
|
||||||
}, {
|
}, {
|
||||||
"truncated pack",
|
"truncated pack",
|
||||||
func(t *testing.T, repo *repository.Repository, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
func(t *testing.T, repo *repository.Repository, be backend.Backend, packsBefore restic.IDSet) (restic.IDSet, restic.BlobSet) {
|
||||||
// damage one of the pack files
|
// damage one of the pack files
|
||||||
damagedID := packsBefore.List()[0]
|
damagedID := packsBefore.List()[0]
|
||||||
replaceFile(t, repo, backend.Handle{Type: backend.PackFile, Name: damagedID.String()},
|
replaceFile(t, be, backend.Handle{Type: backend.PackFile, Name: damagedID.String()},
|
||||||
func(buf []byte) []byte {
|
func(buf []byte) []byte {
|
||||||
buf = buf[0:10]
|
buf = buf[0:10]
|
||||||
return buf
|
return buf
|
||||||
|
@ -104,7 +104,7 @@ func testRepairBrokenPack(t *testing.T, version uint) {
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
t.Run(test.name, func(t *testing.T) {
|
t.Run(test.name, func(t *testing.T) {
|
||||||
// disable verification to allow adding corrupted blobs to the repository
|
// disable verification to allow adding corrupted blobs to the repository
|
||||||
repo := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
repo, be := repository.TestRepositoryWithBackend(t, nil, version, repository.Options{NoExtraVerify: true})
|
||||||
|
|
||||||
seed := time.Now().UnixNano()
|
seed := time.Now().UnixNano()
|
||||||
rand.Seed(seed)
|
rand.Seed(seed)
|
||||||
|
@ -114,7 +114,7 @@ func testRepairBrokenPack(t *testing.T, version uint) {
|
||||||
packsBefore := listPacks(t, repo)
|
packsBefore := listPacks(t, repo)
|
||||||
blobsBefore := listBlobs(repo)
|
blobsBefore := listBlobs(repo)
|
||||||
|
|
||||||
toRepair, damagedBlobs := test.damage(t, repo, packsBefore)
|
toRepair, damagedBlobs := test.damage(t, repo, be, packsBefore)
|
||||||
|
|
||||||
rtest.OK(t, repository.RepairPacks(context.TODO(), repo, toRepair, &progress.NoopPrinter{}))
|
rtest.OK(t, repository.RepairPacks(context.TODO(), repo, toRepair, &progress.NoopPrinter{}))
|
||||||
// reload index
|
// reload index
|
||||||
|
|
|
@ -45,7 +45,7 @@ func testSaveCalculateID(t *testing.T, version uint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testSave(t *testing.T, version uint, calculateID bool) {
|
func testSave(t *testing.T, version uint, calculateID bool) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
for _, size := range testSizes {
|
for _, size := range testSizes {
|
||||||
data := make([]byte, size)
|
data := make([]byte, size)
|
||||||
|
@ -88,7 +88,7 @@ func BenchmarkSaveAndEncrypt(t *testing.B) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func benchmarkSaveAndEncrypt(t *testing.B, version uint) {
|
func benchmarkSaveAndEncrypt(t *testing.B, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
size := 4 << 20 // 4MiB
|
size := 4 << 20 // 4MiB
|
||||||
|
|
||||||
data := make([]byte, size)
|
data := make([]byte, size)
|
||||||
|
@ -114,7 +114,7 @@ func TestLoadBlob(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testLoadBlob(t *testing.T, version uint) {
|
func testLoadBlob(t *testing.T, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
length := 1000000
|
length := 1000000
|
||||||
buf := crypto.NewBlobBuffer(length)
|
buf := crypto.NewBlobBuffer(length)
|
||||||
_, err := io.ReadFull(rnd, buf)
|
_, err := io.ReadFull(rnd, buf)
|
||||||
|
@ -145,7 +145,7 @@ func testLoadBlob(t *testing.T, version uint) {
|
||||||
|
|
||||||
func TestLoadBlobBroken(t *testing.T) {
|
func TestLoadBlobBroken(t *testing.T) {
|
||||||
be := mem.New()
|
be := mem.New()
|
||||||
repo := repository.TestRepositoryWithBackend(t, &damageOnceBackend{Backend: be}, restic.StableRepoVersion, repository.Options{})
|
repo, _ := repository.TestRepositoryWithBackend(t, &damageOnceBackend{Backend: be}, restic.StableRepoVersion, repository.Options{})
|
||||||
buf := test.Random(42, 1000)
|
buf := test.Random(42, 1000)
|
||||||
|
|
||||||
var wg errgroup.Group
|
var wg errgroup.Group
|
||||||
|
@ -170,7 +170,7 @@ func BenchmarkLoadBlob(b *testing.B) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func benchmarkLoadBlob(b *testing.B, version uint) {
|
func benchmarkLoadBlob(b *testing.B, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(b, version)
|
repo, _ := repository.TestRepositoryWithVersion(b, version)
|
||||||
length := 1000000
|
length := 1000000
|
||||||
buf := crypto.NewBlobBuffer(length)
|
buf := crypto.NewBlobBuffer(length)
|
||||||
_, err := io.ReadFull(rnd, buf)
|
_, err := io.ReadFull(rnd, buf)
|
||||||
|
@ -211,7 +211,7 @@ func BenchmarkLoadUnpacked(b *testing.B) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func benchmarkLoadUnpacked(b *testing.B, version uint) {
|
func benchmarkLoadUnpacked(b *testing.B, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(b, version)
|
repo, _ := repository.TestRepositoryWithVersion(b, version)
|
||||||
length := 1000000
|
length := 1000000
|
||||||
buf := crypto.NewBlobBuffer(length)
|
buf := crypto.NewBlobBuffer(length)
|
||||||
_, err := io.ReadFull(rnd, buf)
|
_, err := io.ReadFull(rnd, buf)
|
||||||
|
@ -247,7 +247,7 @@ func benchmarkLoadUnpacked(b *testing.B, version uint) {
|
||||||
var repoFixture = filepath.Join("testdata", "test-repo.tar.gz")
|
var repoFixture = filepath.Join("testdata", "test-repo.tar.gz")
|
||||||
|
|
||||||
func TestRepositoryLoadIndex(t *testing.T) {
|
func TestRepositoryLoadIndex(t *testing.T) {
|
||||||
repo, cleanup := repository.TestFromFixture(t, repoFixture)
|
repo, _, cleanup := repository.TestFromFixture(t, repoFixture)
|
||||||
defer cleanup()
|
defer cleanup()
|
||||||
|
|
||||||
rtest.OK(t, repo.LoadIndex(context.TODO(), nil))
|
rtest.OK(t, repo.LoadIndex(context.TODO(), nil))
|
||||||
|
@ -268,7 +268,7 @@ func loadIndex(ctx context.Context, repo restic.LoaderUnpacked, id restic.ID) (*
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRepositoryLoadUnpackedBroken(t *testing.T) {
|
func TestRepositoryLoadUnpackedBroken(t *testing.T) {
|
||||||
repo := repository.TestRepository(t)
|
repo, be := repository.TestRepositoryWithVersion(t, 0)
|
||||||
|
|
||||||
data := rtest.Random(23, 12345)
|
data := rtest.Random(23, 12345)
|
||||||
id := restic.Hash(data)
|
id := restic.Hash(data)
|
||||||
|
@ -277,7 +277,7 @@ func TestRepositoryLoadUnpackedBroken(t *testing.T) {
|
||||||
data[0] ^= 0xff
|
data[0] ^= 0xff
|
||||||
|
|
||||||
// store broken file
|
// store broken file
|
||||||
err := repo.Backend().Save(context.TODO(), h, backend.NewByteReader(data, repo.Backend().Hasher()))
|
err := be.Save(context.TODO(), h, backend.NewByteReader(data, be.Hasher()))
|
||||||
rtest.OK(t, err)
|
rtest.OK(t, err)
|
||||||
|
|
||||||
_, err = repo.LoadUnpacked(context.TODO(), restic.IndexFile, id)
|
_, err = repo.LoadUnpacked(context.TODO(), restic.IndexFile, id)
|
||||||
|
@ -322,7 +322,7 @@ func BenchmarkLoadIndex(b *testing.B) {
|
||||||
func benchmarkLoadIndex(b *testing.B, version uint) {
|
func benchmarkLoadIndex(b *testing.B, version uint) {
|
||||||
repository.TestUseLowSecurityKDFParameters(b)
|
repository.TestUseLowSecurityKDFParameters(b)
|
||||||
|
|
||||||
repo := repository.TestRepositoryWithVersion(b, version)
|
repo, be := repository.TestRepositoryWithVersion(b, version)
|
||||||
idx := index.NewIndex()
|
idx := index.NewIndex()
|
||||||
|
|
||||||
for i := 0; i < 5000; i++ {
|
for i := 0; i < 5000; i++ {
|
||||||
|
@ -340,7 +340,7 @@ func benchmarkLoadIndex(b *testing.B, version uint) {
|
||||||
rtest.OK(b, err)
|
rtest.OK(b, err)
|
||||||
|
|
||||||
b.Logf("index saved as %v", id.Str())
|
b.Logf("index saved as %v", id.Str())
|
||||||
fi, err := repo.Backend().Stat(context.TODO(), backend.Handle{Type: restic.IndexFile, Name: id.String()})
|
fi, err := be.Stat(context.TODO(), backend.Handle{Type: restic.IndexFile, Name: id.String()})
|
||||||
rtest.OK(b, err)
|
rtest.OK(b, err)
|
||||||
b.Logf("filesize is %v", fi.Size)
|
b.Logf("filesize is %v", fi.Size)
|
||||||
|
|
||||||
|
@ -374,7 +374,7 @@ func TestRepositoryIncrementalIndex(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testRepositoryIncrementalIndex(t *testing.T, version uint) {
|
func testRepositoryIncrementalIndex(t *testing.T, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
index.IndexFull = func(*index.Index, bool) bool { return true }
|
index.IndexFull = func(*index.Index, bool) bool { return true }
|
||||||
|
|
||||||
|
@ -425,7 +425,7 @@ func TestInvalidCompression(t *testing.T) {
|
||||||
|
|
||||||
func TestListPack(t *testing.T) {
|
func TestListPack(t *testing.T) {
|
||||||
be := mem.New()
|
be := mem.New()
|
||||||
repo := repository.TestRepositoryWithBackend(t, &damageOnceBackend{Backend: be}, restic.StableRepoVersion, repository.Options{})
|
repo, _ := repository.TestRepositoryWithBackend(t, &damageOnceBackend{Backend: be}, restic.StableRepoVersion, repository.Options{})
|
||||||
buf := test.Random(42, 1000)
|
buf := test.Random(42, 1000)
|
||||||
|
|
||||||
var wg errgroup.Group
|
var wg errgroup.Group
|
||||||
|
@ -440,7 +440,7 @@ func TestListPack(t *testing.T) {
|
||||||
|
|
||||||
// Forcibly cache pack file
|
// Forcibly cache pack file
|
||||||
packID := repo.Index().Lookup(restic.BlobHandle{Type: restic.TreeBlob, ID: id})[0].PackID
|
packID := repo.Index().Lookup(restic.BlobHandle{Type: restic.TreeBlob, ID: id})[0].PackID
|
||||||
rtest.OK(t, repo.Backend().Load(context.TODO(), backend.Handle{Type: restic.PackFile, IsMetadata: true, Name: packID.String()}, 0, 0, func(rd io.Reader) error { return nil }))
|
rtest.OK(t, be.Load(context.TODO(), backend.Handle{Type: restic.PackFile, IsMetadata: true, Name: packID.String()}, 0, 0, func(rd io.Reader) error { return nil }))
|
||||||
|
|
||||||
// Get size to list pack
|
// Get size to list pack
|
||||||
var size int64
|
var size int64
|
||||||
|
|
|
@ -46,7 +46,7 @@ const testChunkerPol = chunker.Pol(0x3DA3358B4DC173)
|
||||||
// TestRepositoryWithBackend returns a repository initialized with a test
|
// TestRepositoryWithBackend returns a repository initialized with a test
|
||||||
// password. If be is nil, an in-memory backend is used. A constant polynomial
|
// password. If be is nil, an in-memory backend is used. A constant polynomial
|
||||||
// is used for the chunker and low-security test parameters.
|
// is used for the chunker and low-security test parameters.
|
||||||
func TestRepositoryWithBackend(t testing.TB, be backend.Backend, version uint, opts Options) *Repository {
|
func TestRepositoryWithBackend(t testing.TB, be backend.Backend, version uint, opts Options) (*Repository, backend.Backend) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
TestUseLowSecurityKDFParameters(t)
|
TestUseLowSecurityKDFParameters(t)
|
||||||
restic.TestDisableCheckPolynomial(t)
|
restic.TestDisableCheckPolynomial(t)
|
||||||
|
@ -69,7 +69,7 @@ func TestRepositoryWithBackend(t testing.TB, be backend.Backend, version uint, o
|
||||||
t.Fatalf("TestRepository(): initialize repo failed: %v", err)
|
t.Fatalf("TestRepository(): initialize repo failed: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
return repo
|
return repo, be
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestRepository returns a repository initialized with a test password on an
|
// TestRepository returns a repository initialized with a test password on an
|
||||||
|
@ -78,10 +78,11 @@ func TestRepositoryWithBackend(t testing.TB, be backend.Backend, version uint, o
|
||||||
// instead. The directory is not removed, but left there for inspection.
|
// instead. The directory is not removed, but left there for inspection.
|
||||||
func TestRepository(t testing.TB) *Repository {
|
func TestRepository(t testing.TB) *Repository {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
return TestRepositoryWithVersion(t, 0)
|
repo, _ := TestRepositoryWithVersion(t, 0)
|
||||||
|
return repo
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRepositoryWithVersion(t testing.TB, version uint) *Repository {
|
func TestRepositoryWithVersion(t testing.TB, version uint) (*Repository, backend.Backend) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
dir := os.Getenv("RESTIC_TEST_REPO")
|
dir := os.Getenv("RESTIC_TEST_REPO")
|
||||||
opts := Options{}
|
opts := Options{}
|
||||||
|
@ -103,15 +104,15 @@ func TestRepositoryWithVersion(t testing.TB, version uint) *Repository {
|
||||||
return TestRepositoryWithBackend(t, nil, version, opts)
|
return TestRepositoryWithBackend(t, nil, version, opts)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromFixture(t testing.TB, repoFixture string) (*Repository, func()) {
|
func TestFromFixture(t testing.TB, repoFixture string) (*Repository, backend.Backend, func()) {
|
||||||
repodir, cleanup := test.Env(t, repoFixture)
|
repodir, cleanup := test.Env(t, repoFixture)
|
||||||
repo := TestOpenLocal(t, repodir)
|
repo, be := TestOpenLocal(t, repodir)
|
||||||
|
|
||||||
return repo, cleanup
|
return repo, be, cleanup
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestOpenLocal opens a local repository.
|
// TestOpenLocal opens a local repository.
|
||||||
func TestOpenLocal(t testing.TB, dir string) *Repository {
|
func TestOpenLocal(t testing.TB, dir string) (*Repository, backend.Backend) {
|
||||||
var be backend.Backend
|
var be backend.Backend
|
||||||
be, err := local.Open(context.TODO(), local.Config{Path: dir, Connections: 2})
|
be, err := local.Open(context.TODO(), local.Config{Path: dir, Connections: 2})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -120,7 +121,7 @@ func TestOpenLocal(t testing.TB, dir string) *Repository {
|
||||||
|
|
||||||
be = retry.New(be, 3, nil, nil)
|
be = retry.New(be, 3, nil, nil)
|
||||||
|
|
||||||
return TestOpenBackend(t, be)
|
return TestOpenBackend(t, be), be
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOpenBackend(t testing.TB, be backend.Backend) *Repository {
|
func TestOpenBackend(t testing.TB, be backend.Backend) *Repository {
|
||||||
|
|
|
@ -88,8 +88,8 @@ func UpgradeRepo(ctx context.Context, repo *Repository) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// try contingency methods, reupload the original file
|
// try contingency methods, reupload the original file
|
||||||
_ = repo.Backend().Remove(ctx, h)
|
_ = repo.be.Remove(ctx, h)
|
||||||
err = repo.Backend().Save(ctx, h, backend.NewByteReader(rawConfigFile, nil))
|
err = repo.be.Save(ctx, h, backend.NewByteReader(rawConfigFile, nil))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
repoError.ReuploadOldConfigError = err
|
repoError.ReuploadOldConfigError = err
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestUpgradeRepoV2(t *testing.T) {
|
func TestUpgradeRepoV2(t *testing.T) {
|
||||||
repo := TestRepositoryWithVersion(t, 1)
|
repo, _ := TestRepositoryWithVersion(t, 1)
|
||||||
if repo.Config().Version != 1 {
|
if repo.Config().Version != 1 {
|
||||||
t.Fatal("test repo has wrong version")
|
t.Fatal("test repo has wrong version")
|
||||||
}
|
}
|
||||||
|
@ -55,7 +55,7 @@ func TestUpgradeRepoV2Failure(t *testing.T) {
|
||||||
Backend: be,
|
Backend: be,
|
||||||
}
|
}
|
||||||
|
|
||||||
repo := TestRepositoryWithBackend(t, be, 1, Options{})
|
repo, _ := TestRepositoryWithBackend(t, be, 1, Options{})
|
||||||
if repo.Config().Version != 1 {
|
if repo.Config().Version != 1 {
|
||||||
t.Fatal("test repo has wrong version")
|
t.Fatal("test repo has wrong version")
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,7 +66,7 @@ func (be *failLockLoadingBackend) Load(ctx context.Context, h backend.Handle, le
|
||||||
|
|
||||||
func TestMultipleLockFailure(t *testing.T) {
|
func TestMultipleLockFailure(t *testing.T) {
|
||||||
be := &failLockLoadingBackend{Backend: mem.New()}
|
be := &failLockLoadingBackend{Backend: mem.New()}
|
||||||
repo := repository.TestRepositoryWithBackend(t, be, 0, repository.Options{})
|
repo, _ := repository.TestRepositoryWithBackend(t, be, 0, repository.Options{})
|
||||||
restic.TestSetLockTimeout(t, 5*time.Millisecond)
|
restic.TestSetLockTimeout(t, 5*time.Millisecond)
|
||||||
|
|
||||||
lock1, err := restic.NewLock(context.TODO(), repo)
|
lock1, err := restic.NewLock(context.TODO(), repo)
|
||||||
|
|
|
@ -32,7 +32,7 @@ func TestLoadJSONUnpacked(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func testLoadJSONUnpacked(t *testing.T, version uint) {
|
func testLoadJSONUnpacked(t *testing.T, version uint) {
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
|
|
||||||
// archive a snapshot
|
// archive a snapshot
|
||||||
sn := restic.Snapshot{}
|
sn := restic.Snapshot{}
|
||||||
|
|
|
@ -181,7 +181,7 @@ func testLoadTree(t *testing.T, version uint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// archive a few files
|
// archive a few files
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
sn := archiver.TestSnapshot(t, repo, rtest.BenchArchiveDirectory, nil)
|
sn := archiver.TestSnapshot(t, repo, rtest.BenchArchiveDirectory, nil)
|
||||||
rtest.OK(t, repo.Flush(context.Background()))
|
rtest.OK(t, repo.Flush(context.Background()))
|
||||||
|
|
||||||
|
@ -199,7 +199,7 @@ func benchmarkLoadTree(t *testing.B, version uint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// archive a few files
|
// archive a few files
|
||||||
repo := repository.TestRepositoryWithVersion(t, version)
|
repo, _ := repository.TestRepositoryWithVersion(t, version)
|
||||||
sn := archiver.TestSnapshot(t, repo, rtest.BenchArchiveDirectory, nil)
|
sn := archiver.TestSnapshot(t, repo, rtest.BenchArchiveDirectory, nil)
|
||||||
rtest.OK(t, repo.Flush(context.Background()))
|
rtest.OK(t, repo.Flush(context.Background()))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue