| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 | 
							- package leaves
 
- import (
 
- 	"bytes"
 
- 	"sort"
 
- 	"testing"
 
- 	"github.com/gogo/protobuf/proto"
 
- 	"github.com/stretchr/testify/assert"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing/object"
 
- 	"gopkg.in/src-d/hercules.v9/internal/core"
 
- 	"gopkg.in/src-d/hercules.v9/internal/pb"
 
- 	items "gopkg.in/src-d/hercules.v9/internal/plumbing"
 
- 	"gopkg.in/src-d/hercules.v9/internal/plumbing/identity"
 
- 	"gopkg.in/src-d/hercules.v9/internal/test"
 
- 	"gopkg.in/src-d/hercules.v9/internal/test/fixtures"
 
- )
 
- func TestCommitsMeta(t *testing.T) {
 
- 	ca := CommitsAnalysis{}
 
- 	assert.Equal(t, ca.Name(), "CommitsStat")
 
- 	assert.Len(t, ca.Provides(), 0)
 
- 	required := [...]string{identity.DependencyAuthor, items.DependencyLanguages, items.DependencyLineStats}
 
- 	for _, name := range required {
 
- 		assert.Contains(t, ca.Requires(), name)
 
- 	}
 
- 	opts := ca.ListConfigurationOptions()
 
- 	assert.Len(t, opts, 0)
 
- 	assert.Equal(t, ca.Flag(), "commits-stat")
 
- }
 
- func TestCommitsRegistration(t *testing.T) {
 
- 	summoned := core.Registry.Summon((&CommitsAnalysis{}).Name())
 
- 	assert.Len(t, summoned, 1)
 
- 	assert.Equal(t, summoned[0].Name(), "CommitsStat")
 
- 	leaves := core.Registry.GetLeaves()
 
- 	matched := false
 
- 	for _, tp := range leaves {
 
- 		if tp.Flag() == (&CommitsAnalysis{}).Flag() {
 
- 			matched = true
 
- 			break
 
- 		}
 
- 	}
 
- 	assert.True(t, matched)
 
- }
 
- func TestCommitsConfigure(t *testing.T) {
 
- 	ca := CommitsAnalysis{}
 
- 	facts := map[string]interface{}{}
 
- 	facts[identity.FactIdentityDetectorReversedPeopleDict] = ca.Requires()
 
- 	assert.Nil(t, ca.Configure(facts))
 
- 	assert.Equal(t, ca.reversedPeopleDict, ca.Requires())
 
- }
 
- func TestCommitsConsume(t *testing.T) {
 
- 	ca := CommitsAnalysis{}
 
- 	assert.Nil(t, ca.Initialize(test.Repository))
 
- 	deps := map[string]interface{}{}
 
- 	// stage 1
 
- 	deps[identity.DependencyAuthor] = 0
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	AddHash(t, cache, "291286b4ac41952cbd1389fda66420ec03c1a9fe")
 
- 	AddHash(t, cache, "c29112dbd697ad9b401333b80c18a63951bc18d9")
 
- 	AddHash(t, cache, "baa64828831d174f40140e4b3cfa77d1e917a2c1")
 
- 	AddHash(t, cache, "dc248ba2b22048cc730c571a748e8ffcf7085ab9")
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	deps[items.DependencyLanguages] = map[plumbing.Hash]string{
 
- 		plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"): "Go",
 
- 		plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"): "Go",
 
- 		plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"): "Go",
 
- 		plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"): "Go",
 
- 	}
 
- 	changes := make(object.Changes, 3)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"994eac1cd07235bb9815e547a75c84265dea00f5"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
 
- 		},
 
- 	}}
 
- 	changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
 
- 		Name: "cmd/hercules/main.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "cmd/hercules/main.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
 
- 		},
 
- 	},
 
- 	}
 
- 	changes[2] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
 
- 		Name: ".travis.yml",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: ".travis.yml",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"),
 
- 		},
 
- 	},
 
- 	}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	fd := fixtures.FileDiff()
 
- 	result, err := fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyFileDiff] = result[items.DependencyFileDiff]
 
- 	deps[core.DependencyCommit], _ = test.Repository.CommitObject(plumbing.NewHash(
 
- 		"cce947b98a050c6d356bc6ba95030254914027b1"))
 
- 	deps[core.DependencyIsMerge] = false
 
- 	lsc := &items.LinesStatsCalculator{}
 
- 	lscres, err := lsc.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
 
- 	result, err = ca.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, ca.commits, 1)
 
- 	c := ca.commits[0]
 
- 	assert.Equal(t, "cce947b98a050c6d356bc6ba95030254914027b1", c.Hash)
 
- 	assert.Equal(t, int64(1481563829), c.When)
 
- 	assert.Equal(t, 0, c.Author)
 
- 	assert.Len(t, c.Files, 3)
 
- 	sort.Slice(c.Files, func(i, j int) bool { return c.Files[i].Name < c.Files[j].Name })
 
- 	assert.Equal(t, ".travis.yml", c.Files[0].Name)
 
- 	assert.Equal(t, "Go", c.Files[0].Language)
 
- 	assert.Equal(t, 12, c.Files[0].Added)
 
- 	assert.Equal(t, 0, c.Files[0].Removed)
 
- 	assert.Equal(t, 0, c.Files[0].Changed)
 
- 	assert.Equal(t, "analyser.go", c.Files[1].Name)
 
- 	assert.Equal(t, "Go", c.Files[1].Language)
 
- 	assert.Equal(t, 628, c.Files[1].Added)
 
- 	assert.Equal(t, 9, c.Files[1].Removed)
 
- 	assert.Equal(t, 67, c.Files[1].Changed)
 
- 	assert.Equal(t, "cmd/hercules/main.go", c.Files[2].Name)
 
- 	assert.Equal(t, "Go", c.Files[2].Language)
 
- 	assert.Equal(t, 207, c.Files[2].Added)
 
- 	assert.Equal(t, 0, c.Files[2].Removed)
 
- 	assert.Equal(t, 0, c.Files[2].Changed)
 
- 	deps[core.DependencyIsMerge] = true
 
- 	lscres, err = lsc.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
 
- 	result, err = ca.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, ca.commits, 1)
 
- 	c = ca.commits[0]
 
- 	assert.Equal(t, "cce947b98a050c6d356bc6ba95030254914027b1", c.Hash)
 
- 	assert.Equal(t, int64(1481563829), c.When)
 
- 	assert.Equal(t, 0, c.Author)
 
- 	assert.Len(t, c.Files, 3)
 
- 	sort.Slice(c.Files, func(i, j int) bool { return c.Files[i].Name < c.Files[j].Name })
 
- 	assert.Equal(t, ".travis.yml", c.Files[0].Name)
 
- 	assert.Equal(t, "Go", c.Files[0].Language)
 
- 	assert.Equal(t, 12, c.Files[0].Added)
 
- 	assert.Equal(t, 0, c.Files[0].Removed)
 
- 	assert.Equal(t, 0, c.Files[0].Changed)
 
- 	assert.Equal(t, "analyser.go", c.Files[1].Name)
 
- 	assert.Equal(t, "Go", c.Files[1].Language)
 
- 	assert.Equal(t, 628, c.Files[1].Added)
 
- 	assert.Equal(t, 9, c.Files[1].Removed)
 
- 	assert.Equal(t, 67, c.Files[1].Changed)
 
- 	assert.Equal(t, "cmd/hercules/main.go", c.Files[2].Name)
 
- 	assert.Equal(t, "Go", c.Files[2].Language)
 
- 	assert.Equal(t, 207, c.Files[2].Added)
 
- 	assert.Equal(t, 0, c.Files[2].Removed)
 
- 	assert.Equal(t, 0, c.Files[2].Changed)
 
- }
 
- func fixtureCommits() *CommitsAnalysis {
 
- 	ca := CommitsAnalysis{}
 
- 	ca.Initialize(test.Repository)
 
- 	ca.commits = []*CommitStat{
 
- 		{
 
- 			Hash:   "cce947b98a050c6d356bc6ba95030254914027b1",
 
- 			When:   1481563829,
 
- 			Author: 0,
 
- 			Files: []FileStat{
 
- 				{
 
- 					Name:     ".travis.yml",
 
- 					Language: "Yaml",
 
- 					LineStats: items.LineStats{
 
- 						Added:   12,
 
- 						Removed: 0,
 
- 						Changed: 0,
 
- 					},
 
- 				},
 
- 				{
 
- 					Name:     "analyser.go",
 
- 					Language: "Go",
 
- 					LineStats: items.LineStats{
 
- 						Added:   628,
 
- 						Removed: 9,
 
- 						Changed: 67,
 
- 					},
 
- 				},
 
- 			},
 
- 		},
 
- 		{
 
- 			Hash:   "c29112dbd697ad9b401333b80c18a63951bc18d9",
 
- 			When:   1481563999,
 
- 			Author: 1,
 
- 			Files: []FileStat{
 
- 				{
 
- 					Name:     "cmd/hercules/main.go",
 
- 					Language: "Go",
 
- 					LineStats: items.LineStats{
 
- 						Added:   1,
 
- 						Removed: 0,
 
- 						Changed: 0,
 
- 					},
 
- 				},
 
- 			},
 
- 		},
 
- 	}
 
- 	people := [...]string{"one@srcd", "two@srcd"}
 
- 	ca.reversedPeopleDict = people[:]
 
- 	return &ca
 
- }
 
- func TestCommitsFinalize(t *testing.T) {
 
- 	ca := fixtureCommits()
 
- 	x := ca.Finalize().(CommitsResult)
 
- 	assert.Equal(t, x.Commits, ca.commits)
 
- 	assert.Equal(t, x.reversedPeopleDict, ca.reversedPeopleDict)
 
- }
 
- func TestCommitsSerialize(t *testing.T) {
 
- 	ca := fixtureCommits()
 
- 	res := ca.Finalize().(CommitsResult)
 
- 	buffer := &bytes.Buffer{}
 
- 	err := ca.Serialize(res, false, buffer)
 
- 	assert.Nil(t, err)
 
- 	assert.Equal(t, `  commits:
 
-     - hash: cce947b98a050c6d356bc6ba95030254914027b1
 
-       when: 1481563829
 
-       author: 0
 
-       files:
 
-        - name: .travis.yml
 
-          language: Yaml
 
-          stat: [12, 0, 0]
 
-        - name: analyser.go
 
-          language: Go
 
-          stat: [628, 67, 9]
 
-     - hash: c29112dbd697ad9b401333b80c18a63951bc18d9
 
-       when: 1481563999
 
-       author: 1
 
-       files:
 
-        - name: cmd/hercules/main.go
 
-          language: Go
 
-          stat: [1, 0, 0]
 
-   people:
 
-   - "one@srcd"
 
-   - "two@srcd"
 
- `, buffer.String())
 
- 	buffer = &bytes.Buffer{}
 
- 	err = ca.Serialize(res, true, buffer)
 
- 	assert.Nil(t, err)
 
- 	msg := pb.CommitsAnalysisResults{}
 
- 	assert.Nil(t, proto.Unmarshal(buffer.Bytes(), &msg))
 
- 	assert.Equal(t, msg.AuthorIndex, ca.reversedPeopleDict)
 
- 	assert.Len(t, msg.Commits, 2)
 
- 	assert.Equal(t, msg.Commits[0].Hash, "cce947b98a050c6d356bc6ba95030254914027b1")
 
- 	assert.Equal(t, msg.Commits[0].WhenUnixTime, int64(1481563829))
 
- 	assert.Equal(t, msg.Commits[0].Author, int32(0))
 
- 	assert.Len(t, msg.Commits[0].Files, 2)
 
- 	assert.Equal(t, msg.Commits[0].Files[0], &pb.CommitFile{
 
- 		Name:     ".travis.yml",
 
- 		Stats:    &pb.LineStats{Added: 12, Removed: 0, Changed: 0},
 
- 		Language: "Yaml"})
 
- 	assert.Equal(t, msg.Commits[0].Files[1], &pb.CommitFile{
 
- 		Name:     "analyser.go",
 
- 		Stats:    &pb.LineStats{Added: 628, Removed: 9, Changed: 67},
 
- 		Language: "Go"})
 
- 	assert.Equal(t, msg.Commits[1].Hash, "c29112dbd697ad9b401333b80c18a63951bc18d9")
 
- 	assert.Equal(t, msg.Commits[1].WhenUnixTime, int64(1481563999))
 
- 	assert.Equal(t, msg.Commits[1].Author, int32(1))
 
- 	assert.Len(t, msg.Commits[1].Files, 1)
 
- 	assert.Equal(t, msg.Commits[1].Files[0], &pb.CommitFile{
 
- 		Name:     "cmd/hercules/main.go",
 
- 		Stats:    &pb.LineStats{Added: 1, Removed: 0, Changed: 0},
 
- 		Language: "Go"})
 
- }
 
 
  |