package object
import (
"path"
. "gopkg.in/check.v1"
fixtures "gopkg.in/src-d/go-git-fixtures.v3"
"gopkg.in/src-d/go-git.v4/plumbing"
"gopkg.in/src-d/go-git.v4/plumbing/cache"
"gopkg.in/src-d/go-git.v4/plumbing/format/commitgraph"
"gopkg.in/src-d/go-git.v4/plumbing/format/packfile"
"gopkg.in/src-d/go-git.v4/storage/filesystem"
)
type CommitNodeSuite struct {
fixtures.Suite
}
var _ = Suite(&CommitNodeSuite{})
func unpackRepositry(f *fixtures.Fixture) *filesystem.Storage {
storer := filesystem.NewStorage(f.DotGit(), cache.NewObjectLRUDefault())
p := f.Packfile()
defer p.Close()
packfile.UpdateObjectStorage(storer, p)
return storer
}
func testWalker(c *C, nodeIndex CommitNodeIndex) {
head, err := nodeIndex.Get(plumbing.NewHash("b9d69064b190e7aedccf84731ca1d917871f8a1c"))
c.Assert(err, IsNil)
iter := NewCommitNodeIterCTime(
head,
nil,
nil,
)
var commits []CommitNode
iter.ForEach(func(c CommitNode) error {
commits = append(commits, c)
return nil
})
c.Assert(commits, HasLen, 9)
expected := []string{
"b9d69064b190e7aedccf84731ca1d917871f8a1c",
"6f6c5d2be7852c782be1dd13e36496dd7ad39560",
"a45273fe2d63300e1962a9e26a6b15c276cd7082",
"c0edf780dd0da6a65a7a49a86032fcf8a0c2d467",
"bb13916df33ed23004c3ce9ed3b8487528e655c1",
"03d2c021ff68954cf3ef0a36825e194a4b98f981",
"ce275064ad67d51e99f026084e20827901a8361c",
"e713b52d7e13807e87a002e812041f248db3f643",
"347c91919944a68e9413581a1bc15519550a3afe",
}
for i, commit := range commits {
c.Assert(commit.ID().String(), Equals, expected[i])
}
}
func testParents(c *C, nodeIndex CommitNodeIndex) {
merge3, err := nodeIndex.Get(plumbing.NewHash("6f6c5d2be7852c782be1dd13e36496dd7ad39560"))
c.Assert(err, IsNil)
var parents []CommitNode
merge3.ParentNodes().ForEach(func(c CommitNode) error {
parents = append(parents, c)
return nil
})
c.Assert(parents, HasLen, 3)
expected := []string{
"ce275064ad67d51e99f026084e20827901a8361c",
"bb13916df33ed23004c3ce9ed3b8487528e655c1",
"a45273fe2d63300e1962a9e26a6b15c276cd7082",
}
for i, parent := range parents {
c.Assert(parent.ID().String(), Equals, expected[i])
}
}
func testCommitAndTree(c *C, nodeIndex CommitNodeIndex) {
merge3node, err := nodeIndex.Get(plumbing.NewHash("6f6c5d2be7852c782be1dd13e36496dd7ad39560"))
c.Assert(err, IsNil)
merge3commit, err := merge3node.Commit()
c.Assert(err, IsNil)
c.Assert(merge3node.ID().String(), Equals, merge3commit.ID().String())
tree, err := merge3node.Tree()
c.Assert(err, IsNil)
c.Assert(tree.ID().String(), Equals, merge3commit.TreeHash.String())
}
func (s *CommitNodeSuite) TestObjectGraph(c *C) {
f := fixtures.ByTag("commit-graph").One()
storer := unpackRepositry(f)
nodeIndex := NewObjectCommitNodeIndex(storer)
testWalker(c, nodeIndex)
testParents(c, nodeIndex)
testCommitAndTree(c, nodeIndex)
}
func (s *CommitNodeSuite) TestCommitGraph(c *C) {
f := fixtures.ByTag("commit-graph").One()
storer := unpackRepositry(f)
reader, err := storer.Filesystem().Open(path.Join("objects", "info", "commit-graph"))
c.Assert(err, IsNil)
defer reader.Close()
index, err := commitgraph.OpenFileIndex(reader)
c.Assert(err, IsNil)
nodeIndex := NewGraphCommitNodeIndex(index, storer)
testWalker(c, nodeIndex)
testParents(c, nodeIndex)
testCommitAndTree(c, nodeIndex)
}
func (s *CommitNodeSuite) TestMixedGraph(c *C) {
f := fixtures.ByTag("commit-graph").One()
storer := unpackRepositry(f)
// Take the commit-graph file and copy it to memory index without the last commit
reader, err := storer.Filesystem().Open(path.Join("objects", "info", "commit-graph"))
c.Assert(err, IsNil)
defer reader.Close()
fileIndex, err := commitgraph.OpenFileIndex(reader)
c.Assert(err, IsNil)
memoryIndex := commitgraph.NewMemoryIndex()
for i, hash := range fileIndex.Hashes() {
if hash.String() != "b9d69064b190e7aedccf84731ca1d917871f8a1c" {
node, err := fileIndex.GetCommitDataByIndex(i)
c.Assert(err, IsNil)
memoryIndex.Add(hash, node)
}
}
nodeIndex := NewGraphCommitNodeIndex(memoryIndex, storer)
testWalker(c, nodeIndex)
testParents(c, nodeIndex)
testCommitAndTree(c, nodeIndex)
}