From 777db8470909b16411cb54a6c0bbf927be778952 Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Sat, 21 Feb 2026 22:55:15 +0800 Subject: objectstore/*, repository: Add ReadSize For cases where knowing the type is unnecessary and incurs extra overhead. --- objectstore/packed/read_test.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'objectstore/packed/read_test.go') diff --git a/objectstore/packed/read_test.go b/objectstore/packed/read_test.go index 8cee3b62..9bfa6610 100644 --- a/objectstore/packed/read_test.go +++ b/objectstore/packed/read_test.go @@ -36,6 +36,13 @@ func TestPackedStoreReadAgainstGit(t *testing.T) { if gotHeaderSize != int64(len(wantBody)) { t.Fatalf("ReadHeader size = %d, want %d", gotHeaderSize, len(wantBody)) } + gotSize, err := store.ReadSize(id) + if err != nil { + t.Fatalf("ReadSize: %v", err) + } + if gotSize != int64(len(wantBody)) { + t.Fatalf("ReadSize = %d, want %d", gotSize, len(wantBody)) + } gotRaw, err := store.ReadBytesFull(id) if err != nil { @@ -108,6 +115,9 @@ func TestPackedStoreErrors(t *testing.T) { if _, _, err := store.ReadHeader(notFoundID); !errors.Is(err, objectstore.ErrObjectNotFound) { t.Fatalf("ReadHeader not-found error = %v", err) } + if _, err := store.ReadSize(notFoundID); !errors.Is(err, objectstore.ErrObjectNotFound) { + t.Fatalf("ReadSize not-found error = %v", err) + } var otherAlgo objectid.Algorithm for _, candidate := range objectid.SupportedAlgorithms() { @@ -182,6 +192,13 @@ func TestPackedStoreReadHeaderUsesResolvedObjectSizeForDelta(t *testing.T) { if gotSize != wantResolvedSize { t.Fatalf("ReadHeader(%s) size = %d, want resolved size %d", deltaID, gotSize, wantResolvedSize) } + gotReadSize, err := store.ReadSize(deltaID) + if err != nil { + t.Fatalf("ReadSize(%s): %v", deltaID, err) + } + if gotReadSize != wantResolvedSize { + t.Fatalf("ReadSize(%s) = %d, want resolved size %d", deltaID, gotReadSize, wantResolvedSize) + } }) } -- cgit v1.3.1-10-gc9f91