diff options
| author | 2026-03-04 13:59:28 +0800 | |
|---|---|---|
| committer | 2026-03-04 14:07:45 +0800 | |
| commit | 95d8ceb9b612c776b3f6dce3c7a2236c17bd5313 (patch) | |
| tree | 584f99f27ea0d33cc358cdcb13246d7e156c3311 /refstore/reftable/reftable_test.go | |
| parent | objectstore/packed: Split (diff) | |
refstore/reftable: Delete reftable support for now
Diffstat (limited to 'refstore/reftable/reftable_test.go')
| -rw-r--r-- | refstore/reftable/reftable_test.go | 206 |
1 files changed, 0 insertions, 206 deletions
diff --git a/refstore/reftable/reftable_test.go b/refstore/reftable/reftable_test.go deleted file mode 100644 index 26aa7584..00000000 --- a/refstore/reftable/reftable_test.go +++ /dev/null @@ -1,206 +0,0 @@ -package reftable_test - -import ( - "errors" - "os" - "path/filepath" - "slices" - "testing" - - "codeberg.org/lindenii/furgit/internal/testgit" - "codeberg.org/lindenii/furgit/objectid" - "codeberg.org/lindenii/furgit/ref" - "codeberg.org/lindenii/furgit/refstore" - "codeberg.org/lindenii/furgit/refstore/reftable" -) - -// newBareReftableRepo creates a bare repository that uses reftable ref storage. -func newBareReftableRepo(tb testing.TB, algo objectid.Algorithm) *testgit.TestRepo { - tb.Helper() - - return testgit.NewRepo(tb, testgit.RepoOptions{ - ObjectFormat: algo, - Bare: true, - RefFormat: "reftable", - }) -} - -// openStore opens a reftable store against repoDir/reftable. -func openStore(tb testing.TB, repoDir string, algo objectid.Algorithm) *reftable.Store { - tb.Helper() - - root, err := os.OpenRoot(filepath.Join(repoDir, "reftable")) - if err != nil { - tb.Fatalf("OpenRoot(reftable): %v", err) - } - - tb.Cleanup(func() { _ = root.Close() }) - - store, err := reftable.New(root, algo) - if err != nil { - tb.Fatalf("reftable.New: %v", err) - } - - return store -} - -func TestResolveAndResolveFully(t *testing.T) { - t.Parallel() - testgit.ForEachAlgorithm(t, func(t *testing.T, algo objectid.Algorithm) { //nolint:thelper - repo := newBareReftableRepo(t, algo) - _, _, id := repo.MakeCommit(t, "resolve") - repo.UpdateRef(t, "refs/heads/main", id) - repo.SymbolicRef(t, "HEAD", "refs/heads/main") - - store := openStore(t, repo.Dir(), algo) - - head, err := store.Resolve("HEAD") - if err != nil { - t.Fatalf("Resolve(HEAD): %v", err) - } - - sym, ok := head.(ref.Symbolic) - if !ok { - t.Fatalf("Resolve(HEAD) type = %T, want ref.Symbolic", head) - } - - if sym.Target != "refs/heads/main" { - t.Fatalf("Resolve(HEAD) target = %q, want refs/heads/main", sym.Target) - } - - main, err := store.ResolveFully("HEAD") - if err != nil { - t.Fatalf("ResolveFully(HEAD): %v", err) - } - - if main.ID != id { - t.Fatalf("ResolveFully(HEAD) id = %s, want %s", main.ID, id) - } - - _, err = store.Resolve("refs/heads/missing") - if !errors.Is(err, refstore.ErrReferenceNotFound) { - t.Fatalf("Resolve(missing) error = %v", err) - } - }) -} - -func TestResolveFullyCycle(t *testing.T) { - t.Parallel() - testgit.ForEachAlgorithm(t, func(t *testing.T, algo objectid.Algorithm) { //nolint:thelper - repo := newBareReftableRepo(t, algo) - repo.SymbolicRef(t, "refs/heads/a", "refs/heads/b") - repo.SymbolicRef(t, "refs/heads/b", "refs/heads/a") - - store := openStore(t, repo.Dir(), algo) - - _, err := store.ResolveFully("refs/heads/a") - if err == nil { - t.Fatalf("ResolveFully(cycle) expected error") - } - }) -} - -func TestListAndShorten(t *testing.T) { - t.Parallel() - testgit.ForEachAlgorithm(t, func(t *testing.T, algo objectid.Algorithm) { //nolint:thelper - repo := newBareReftableRepo(t, algo) - _, _, id := repo.MakeCommit(t, "list") - repo.UpdateRef(t, "refs/heads/main", id) - repo.UpdateRef(t, "refs/heads/feature", id) - repo.UpdateRef(t, "refs/tags/main", id) - repo.UpdateRef(t, "refs/remotes/origin/main", id) - - store := openStore(t, repo.Dir(), algo) - - all, err := store.List("") - if err != nil { - t.Fatalf("List(all): %v", err) - } - - names := make([]string, 0, len(all)) - for _, entry := range all { - names = append(names, entry.Name()) - } - - want := []string{"HEAD", "refs/heads/feature", "refs/heads/main", "refs/remotes/origin/main", "refs/tags/main"} - if !slices.Equal(names, want) { - t.Fatalf("List(all) = %v, want %v", names, want) - } - - heads, err := store.List("refs/heads/*") - if err != nil { - t.Fatalf("List(heads): %v", err) - } - - headNames := make([]string, 0, len(heads)) - for _, entry := range heads { - headNames = append(headNames, entry.Name()) - } - - wantHeads := []string{"refs/heads/feature", "refs/heads/main"} - if !slices.Equal(headNames, wantHeads) { - t.Fatalf("List(heads) = %v, want %v", headNames, wantHeads) - } - - short, err := store.Shorten("refs/remotes/origin/main") - if err != nil { - t.Fatalf("Shorten(remote): %v", err) - } - - if short != "origin/main" { - t.Fatalf("Shorten(remote) = %q, want origin/main", short) - } - }) -} - -func TestTombstoneNewestWins(t *testing.T) { - t.Parallel() - testgit.ForEachAlgorithm(t, func(t *testing.T, algo objectid.Algorithm) { //nolint:thelper - repo := newBareReftableRepo(t, algo) - _, _, oldID := repo.MakeCommit(t, "old") - repo.UpdateRef(t, "refs/heads/main", oldID) - _, _, newID := repo.MakeCommit(t, "new") - repo.UpdateRef(t, "refs/heads/main", newID) - repo.DeleteRef(t, "refs/heads/main") - - store := openStore(t, repo.Dir(), algo) - - _, err := store.Resolve("refs/heads/main") - if !errors.Is(err, refstore.ErrReferenceNotFound) { - t.Fatalf("Resolve(main) after delete error = %v", err) - } - }) -} - -func TestAnnotatedTagPeeled(t *testing.T) { - t.Parallel() - testgit.ForEachAlgorithm(t, func(t *testing.T, algo objectid.Algorithm) { //nolint:thelper - repo := newBareReftableRepo(t, algo) - _, _, commitID := repo.MakeCommit(t, "tagged") - tagID := repo.TagAnnotated(t, "v1.0.0", commitID, "annotated") - - store := openStore(t, repo.Dir(), algo) - - resolved, err := store.Resolve("refs/tags/v1.0.0") - if err != nil { - t.Fatalf("Resolve(tag): %v", err) - } - - detached, ok := resolved.(ref.Detached) - if !ok { - t.Fatalf("Resolve(tag) type = %T, want ref.Detached", resolved) - } - - if detached.ID != tagID { - t.Fatalf("Resolve(tag) id = %s, want %s", detached.ID, tagID) - } - - if detached.Peeled == nil { - t.Fatalf("Resolve(tag) peeled = nil") - } - - if *detached.Peeled != commitID { - t.Fatalf("Resolve(tag) peeled = %s, want %s", *detached.Peeled, commitID) - } - }) -} |
