mirror of
https://github.com/kopia/kopia.git
synced 2026-03-27 10:32:08 -04:00
* storage api put-blob retention options Co-authored-by: Shikhar Mall <shikhar@kasten.io>
87 lines
2.9 KiB
Go
87 lines
2.9 KiB
Go
package repo
|
|
|
|
import (
|
|
"crypto/sha256"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kopia/kopia/internal/blobtesting"
|
|
"github.com/kopia/kopia/internal/gather"
|
|
"github.com/kopia/kopia/internal/testlogging"
|
|
"github.com/kopia/kopia/repo/blob"
|
|
)
|
|
|
|
func TestFormatBlobRecovery(t *testing.T) {
|
|
data := blobtesting.DataMap{}
|
|
st := blobtesting.NewMapStorage(data, nil, nil)
|
|
ctx := testlogging.Context(t)
|
|
|
|
someDataBlock := []byte("aadsdasdas")
|
|
|
|
checksummed, err := addFormatBlobChecksumAndLength(someDataBlock)
|
|
if err != nil {
|
|
t.Errorf("error appending checksum: %v", err)
|
|
}
|
|
|
|
if got, want := len(checksummed), 2+2+sha256.Size+len(someDataBlock); got != want {
|
|
t.Errorf("unexpected checksummed length: %v, want %v", got, want)
|
|
}
|
|
|
|
assertNoError(t, st.PutBlob(ctx, "some-blob-by-itself", gather.FromSlice(checksummed), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "some-blob-suffix", gather.FromSlice(append(append([]byte(nil), 1, 2, 3), checksummed...)), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "some-blob-prefix", gather.FromSlice(append(append([]byte(nil), checksummed...), 1, 2, 3)), blob.PutOptions{}))
|
|
|
|
// mess up checksum
|
|
checksummed[len(checksummed)-3] ^= 1
|
|
assertNoError(t, st.PutBlob(ctx, "bad-checksum", gather.FromSlice(checksummed), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "zero-len", gather.FromSlice([]byte{}), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "one-len", gather.FromSlice([]byte{1}), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "two-len", gather.FromSlice([]byte{1, 2}), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "three-len", gather.FromSlice([]byte{1, 2, 3}), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "four-len", gather.FromSlice([]byte{1, 2, 3, 4}), blob.PutOptions{}))
|
|
assertNoError(t, st.PutBlob(ctx, "five-len", gather.FromSlice([]byte{1, 2, 3, 4, 5}), blob.PutOptions{}))
|
|
|
|
cases := []struct {
|
|
blobID blob.ID
|
|
err error
|
|
}{
|
|
{"some-blob-by-itself", nil},
|
|
{"some-blob-suffix", nil},
|
|
{"some-blob-prefix", nil},
|
|
{"bad-checksum", errFormatBlobNotFound},
|
|
{"no-such-blob", blob.ErrBlobNotFound},
|
|
{"zero-len", errFormatBlobNotFound},
|
|
{"one-len", errFormatBlobNotFound},
|
|
{"two-len", errFormatBlobNotFound},
|
|
{"three-len", errFormatBlobNotFound},
|
|
{"four-len", errFormatBlobNotFound},
|
|
{"five-len", errFormatBlobNotFound},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
tc := tc
|
|
t.Run(string(tc.blobID), func(t *testing.T) {
|
|
v, err := RecoverFormatBlob(ctx, st, tc.blobID, -1)
|
|
if tc.err == nil {
|
|
if !reflect.DeepEqual(v, someDataBlock) || err != nil {
|
|
t.Errorf("unexpected result or error: v=%v err=%v, expected success", v, err)
|
|
}
|
|
} else {
|
|
if v != nil || !errors.Is(err, tc.err) {
|
|
t.Errorf("unexpected result or error: v=%v err=%v, expected %v", v, err, tc.err)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func assertNoError(t *testing.T, err error) {
|
|
t.Helper()
|
|
|
|
if err != nil {
|
|
t.Errorf("err: %v", err)
|
|
}
|
|
}
|