forked from TrueCloudLab/restic
5ac9c1157a
This includes tests as well as other tests for the backend_find.Find function. Issue #2104.
117 lines
3 KiB
Go
117 lines
3 KiB
Go
package restic
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
)
|
|
|
|
type mockBackend struct {
|
|
list func(context.Context, FileType, func(FileInfo) error) error
|
|
}
|
|
|
|
func (m mockBackend) List(ctx context.Context, t FileType, fn func(FileInfo) error) error {
|
|
return m.list(ctx, t, fn)
|
|
}
|
|
|
|
var samples = IDs{
|
|
TestParseID("20bdc1402a6fc9b633aaffffffffffffffffffffffffffffffffffffffffffff"),
|
|
TestParseID("20bdc1402a6fc9b633ccd578c4a92d0f4ef1a457fa2e16c596bc73fb409d6cc0"),
|
|
TestParseID("20bdc1402a6fc9b633ffffffffffffffffffffffffffffffffffffffffffffff"),
|
|
TestParseID("20ff988befa5fc40350f00d531a767606efefe242c837aaccb80673f286be53d"),
|
|
TestParseID("326cb59dfe802304f96ee9b5b9af93bdee73a30f53981e5ec579aedb6f1d0f07"),
|
|
TestParseID("86b60b9594d1d429c4aa98fa9562082cabf53b98c7dc083abe5dae31074dd15a"),
|
|
TestParseID("96c8dbe225079e624b5ce509f5bd817d1453cd0a85d30d536d01b64a8669aeae"),
|
|
TestParseID("fa31d65b87affcd167b119e9d3d2a27b8236ca4836cb077ed3e96fcbe209b792"),
|
|
}
|
|
|
|
func TestFind(t *testing.T) {
|
|
list := samples
|
|
|
|
m := mockBackend{}
|
|
m.list = func(ctx context.Context, t FileType, fn func(FileInfo) error) error {
|
|
for _, id := range list {
|
|
err := fn(FileInfo{Name: id.String()})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
f, err := Find(m, SnapshotFile, "20bdc1402a6fc9b633aa")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
expected_match := "20bdc1402a6fc9b633aaffffffffffffffffffffffffffffffffffffffffffff"
|
|
if f != expected_match {
|
|
t.Errorf("Wrong match returned want %s, got %s", expected_match, f)
|
|
}
|
|
|
|
f, err = Find(m, SnapshotFile, "NotAPrefix")
|
|
if err != ErrNoIDPrefixFound {
|
|
t.Error("Expected no snapshots to be found.")
|
|
}
|
|
if f != "" {
|
|
t.Errorf("Find should not return a match on error.")
|
|
}
|
|
|
|
// Try to match with a prefix longer than any ID.
|
|
extra_length_id := samples[0].String() + "f"
|
|
f, err = Find(m, SnapshotFile, extra_length_id)
|
|
if err != ErrNoIDPrefixFound {
|
|
t.Error("Expected no snapshots to be matched.")
|
|
}
|
|
if f != "" {
|
|
t.Errorf("Find should not return a match on error.")
|
|
}
|
|
|
|
// Use a prefix that will match the prefix of multiple Ids in `samples`.
|
|
f, err = Find(m, SnapshotFile, "20bdc140")
|
|
if err != ErrMultipleIDMatches {
|
|
t.Error("Expected multiple snapshots to be matched.")
|
|
}
|
|
if f != "" {
|
|
t.Errorf("Find should not return a match on error.")
|
|
}
|
|
}
|
|
|
|
func TestPrefixLength(t *testing.T) {
|
|
list := samples
|
|
|
|
m := mockBackend{}
|
|
m.list = func(ctx context.Context, t FileType, fn func(FileInfo) error) error {
|
|
for _, id := range list {
|
|
err := fn(FileInfo{Name: id.String()})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
l, err := PrefixLength(m, SnapshotFile)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if l != 19 {
|
|
t.Errorf("wrong prefix length returned, want %d, got %d", 19, l)
|
|
}
|
|
|
|
list = samples[:3]
|
|
l, err = PrefixLength(m, SnapshotFile)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if l != 19 {
|
|
t.Errorf("wrong prefix length returned, want %d, got %d", 19, l)
|
|
}
|
|
|
|
list = samples[3:]
|
|
l, err = PrefixLength(m, SnapshotFile)
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if l != 8 {
|
|
t.Errorf("wrong prefix length returned, want %d, got %d", 8, l)
|
|
}
|
|
}
|