summaryrefslogtreecommitdiff
path: root/object_test.go
diff options
context:
space:
mode:
authorVicent Marti <[email protected]>2013-04-16 23:18:35 +0200
committerVicent Marti <[email protected]>2013-04-16 23:18:35 +0200
commit7292cafac2d2c4462f3bc0b850e702d6d87f629e (patch)
tree9179ef3ed0028099cf11d4a1dc008355a8f92bcf /object_test.go
parentd190d8a6b3717402744902d060be57195f27d604 (diff)
Add @carlosmn's tests
Diffstat (limited to 'object_test.go')
-rw-r--r--object_test.go68
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")
+ }
+}