diff options
| author | 2026-06-07 12:12:39 +0000 | |
|---|---|---|
| committer | 2026-06-07 12:17:59 +0000 | |
| commit | 58698a0e70c61c7447ec9a7b938fc63a94151db1 (patch) | |
| tree | 808873c6e9ea3a38bcd054ac34eca09bec34703f /object/tree/parse_test.go | |
| parent | object/tree: Reject duplicates (diff) | |
| signature | No signature | |
object/tree: Add tests
Diffstat (limited to 'object/tree/parse_test.go')
| -rw-r--r-- | object/tree/parse_test.go | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/object/tree/parse_test.go b/object/tree/parse_test.go new file mode 100644 index 00000000..8d32b136 --- /dev/null +++ b/object/tree/parse_test.go @@ -0,0 +1,44 @@ +package tree_test + +import ( + "testing" + + "lindenii.org/go/furgit/internal/testgit" + "lindenii.org/go/furgit/object/id" + "lindenii.org/go/furgit/object/tree" + "lindenii.org/go/furgit/object/typ" +) + +func TestParse(t *testing.T) { + t.Parallel() + + for _, objectFormat := range id.SupportedObjectFormats() { + t.Run(objectFormat.String(), func(t *testing.T) { + t.Parallel() + + repo, err := testgit.NewRepo(t, testgit.RepoOptions{ObjectFormat: objectFormat}) + if err != nil { + t.Fatalf("NewRepo: %v", err) + } + + entries := mixedEntries(t, repo) + + treeID, err := repo.MkTree(t, mkTreeEntries(entries)) + if err != nil { + t.Fatalf("MkTree: %v", err) + } + + rawBody, err := repo.CatFile(t, typ.TypeTree, treeID) + if err != nil { + t.Fatalf("CatFile: %v", err) + } + + parsed, err := tree.Parse(rawBody, objectFormat) + if err != nil { + t.Fatalf("Parse: %v", err) + } + + assertGitDecode(t, repo, treeID, parsed.Entries()) + }) + } +} |
