forked from TrueCloudLab/restic
archiver: Refuse to save an empty snapshot
This commit is contained in:
parent
9a02f17cc2
commit
1e9744c9a4
2 changed files with 18 additions and 1 deletions
|
@ -762,6 +762,10 @@ func (arch *Archiver) Snapshot(ctx context.Context, targets []string, opts Snaps
|
||||||
return restic.ID{}, ItemStats{}, err
|
return restic.ID{}, ItemStats{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(tree.Nodes) == 0 {
|
||||||
|
return restic.ID{}, ItemStats{}, errors.New("snapshot is empty")
|
||||||
|
}
|
||||||
|
|
||||||
return arch.saveTree(wctx, tree)
|
return arch.saveTree(wctx, tree)
|
||||||
}()
|
}()
|
||||||
debug.Log("saved tree, error: %v", err)
|
debug.Log("saved tree, error: %v", err)
|
||||||
|
|
|
@ -1343,6 +1343,7 @@ func TestArchiverSnapshotSelect(t *testing.T) {
|
||||||
src TestDir
|
src TestDir
|
||||||
want TestDir
|
want TestDir
|
||||||
selFn SelectFunc
|
selFn SelectFunc
|
||||||
|
err string
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "include-all",
|
name: "include-all",
|
||||||
|
@ -1377,7 +1378,7 @@ func TestArchiverSnapshotSelect(t *testing.T) {
|
||||||
selFn: func(item string, fi os.FileInfo) bool {
|
selFn: func(item string, fi os.FileInfo) bool {
|
||||||
return false
|
return false
|
||||||
},
|
},
|
||||||
want: TestDir{},
|
err: "snapshot is empty",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "exclude-txt-files",
|
name: "exclude-txt-files",
|
||||||
|
@ -1462,6 +1463,18 @@ func TestArchiverSnapshotSelect(t *testing.T) {
|
||||||
|
|
||||||
targets := []string{"."}
|
targets := []string{"."}
|
||||||
_, snapshotID, err := arch.Snapshot(ctx, targets, SnapshotOptions{Time: time.Now()})
|
_, snapshotID, err := arch.Snapshot(ctx, targets, SnapshotOptions{Time: time.Now()})
|
||||||
|
if test.err != "" {
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("expected error not found, got %v, wanted %q", err, test.err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err.Error() != test.err {
|
||||||
|
t.Fatalf("unexpected error, want %q, got %q", test.err, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue