diff options
| author | Vicent Marti <[email protected]> | 2013-04-16 23:18:35 +0200 |
|---|---|---|
| committer | Vicent Marti <[email protected]> | 2013-04-16 23:18:35 +0200 |
| commit | 7292cafac2d2c4462f3bc0b850e702d6d87f629e (patch) | |
| tree | 9179ef3ed0028099cf11d4a1dc008355a8f92bcf /object_test.go | |
| parent | d190d8a6b3717402744902d060be57195f27d604 (diff) | |
Add @carlosmn's tests
Diffstat (limited to 'object_test.go')
| -rw-r--r-- | object_test.go | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/object_test.go b/object_test.go new file mode 100644 index 0000000..82dce98 --- /dev/null +++ b/object_test.go @@ -0,0 +1,68 @@ +package git + +import ( + "os" + "testing" +) + +func TestObjectPoymorphism(t *testing.T) { + repo := createTestRepo(t) + defer os.RemoveAll(repo.Workdir()) + commitId, treeId := seedTestRepo(t, repo) + + var obj Object + + commit, err := repo.LookupCommit(commitId) + checkFatal(t, err) + + obj = commit + if obj.Type() != OBJ_COMMIT { + t.Fatalf("Wrong object type, expected commit, have %v", obj.Type()) + } + + tree, err := repo.LookupTree(treeId) + checkFatal(t, err) + + obj = tree + if obj.Type() != OBJ_TREE { + t.Fatalf("Wrong object type, expected tree, have %v", obj.Type()) + } + + tree2, ok := obj.(*Tree) + if !ok { + t.Fatalf("Converting back to *Tree is not ok") + } + + if tree2.EntryByName("README") == nil { + t.Fatalf("Tree did not have expected \"README\" entry") + } + + _, ok = obj.(*Commit) + if ok { + t.Fatalf("*Tree is somehow the same as *Commit") + } + + obj, err = repo.Lookup(tree.Id()) + checkFatal(t, err) + + _, ok = obj.(*Tree) + if !ok { + t.Fatalf("Lookup creates the wrong type") + } + + if obj.Type() != OBJ_TREE { + t.Fatalf("Type() doesn't agree with dynamic type") + } + + obj, err = repo.RevparseSingle("HEAD") + checkFatal(t, err) + if obj.Type() != OBJ_COMMIT || obj.Id().String() != commit.Id().String() { + t.Fatalf("Failed to parse the right revision") + } + + obj, err = repo.RevparseSingle("HEAD^{tree}") + checkFatal(t, err) + if obj.Type() != OBJ_TREE || obj.Id().String() != tree.Id().String() { + t.Fatalf("Failed to parse the right revision") + } +} |
