| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353 | 
							- package leaves
 
- import (
 
- 	"bytes"
 
- 	"io/ioutil"
 
- 	"path"
 
- 	"strings"
 
- 	"testing"
 
- 	"github.com/gogo/protobuf/proto"
 
- 	"github.com/stretchr/testify/assert"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing/object"
 
- 	"gopkg.in/src-d/hercules.v4/internal/core"
 
- 	"gopkg.in/src-d/hercules.v4/internal/pb"
 
- 	"gopkg.in/src-d/hercules.v4/internal/plumbing"
 
- 	"gopkg.in/src-d/hercules.v4/internal/plumbing/identity"
 
- 	"gopkg.in/src-d/hercules.v4/internal/test"
 
- )
 
- func fixtureCouples() *CouplesAnalysis {
 
- 	c := CouplesAnalysis{PeopleNumber: 3}
 
- 	c.Initialize(test.Repository)
 
- 	return &c
 
- }
 
- func TestCouplesMeta(t *testing.T) {
 
- 	c := fixtureCouples()
 
- 	assert.Equal(t, c.Name(), "Couples")
 
- 	assert.Equal(t, len(c.Provides()), 0)
 
- 	assert.Equal(t, len(c.Requires()), 2)
 
- 	assert.Equal(t, c.Requires()[0], identity.DependencyAuthor)
 
- 	assert.Equal(t, c.Requires()[1], plumbing.DependencyTreeChanges)
 
- 	assert.Equal(t, c.Flag(), "couples")
 
- 	assert.Len(t, c.ListConfigurationOptions(), 0)
 
- }
 
- func TestCouplesRegistration(t *testing.T) {
 
- 	summoned := core.Registry.Summon((&CouplesAnalysis{}).Name())
 
- 	assert.Len(t, summoned, 1)
 
- 	assert.Equal(t, summoned[0].Name(), "Couples")
 
- 	leaves := core.Registry.GetLeaves()
 
- 	matched := false
 
- 	for _, tp := range leaves {
 
- 		if tp.Flag() == (&CouplesAnalysis{}).Flag() {
 
- 			matched = true
 
- 			break
 
- 		}
 
- 	}
 
- 	assert.True(t, matched)
 
- }
 
- func generateChanges(names ...string) object.Changes {
 
- 	changes := make(object.Changes, 0, len(names))
 
- 	for _, name := range names {
 
- 		action := name[:1]
 
- 		name = name[1:]
 
- 		var change object.Change
 
- 		if action == "+" {
 
- 			change = object.Change{
 
- 				From: object.ChangeEntry{},
 
- 				To:   object.ChangeEntry{Name: name},
 
- 			}
 
- 		} else if action == "-" {
 
- 			change = object.Change{
 
- 				From: object.ChangeEntry{Name: name},
 
- 				To:   object.ChangeEntry{},
 
- 			}
 
- 		} else if action == "=" {
 
- 			change = object.Change{
 
- 				From: object.ChangeEntry{Name: name},
 
- 				To:   object.ChangeEntry{Name: name},
 
- 			}
 
- 		} else {
 
- 			if action != ">" {
 
- 				panic("Invalid action.")
 
- 			}
 
- 			parts := strings.Split(name, ">")
 
- 			change = object.Change{
 
- 				From: object.ChangeEntry{Name: parts[0]},
 
- 				To:   object.ChangeEntry{Name: parts[1]},
 
- 			}
 
- 		}
 
- 		changes = append(changes, &change)
 
- 	}
 
- 	return changes
 
- }
 
- func TestCouplesConsumeFinalize(t *testing.T) {
 
- 	c := fixtureCouples()
 
- 	deps := map[string]interface{}{}
 
- 	deps[identity.DependencyAuthor] = 0
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("+two", "+four", "+six")
 
- 	c.Consume(deps)
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("+one", "-two", "=three", ">four>five")
 
- 	c.Consume(deps)
 
- 	deps[identity.DependencyAuthor] = 1
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("=one", "=three", "-six")
 
- 	c.Consume(deps)
 
- 	deps[identity.DependencyAuthor] = 2
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("=five")
 
- 	c.Consume(deps)
 
- 	assert.Equal(t, len(c.people[0]), 5)
 
- 	assert.Equal(t, c.people[0]["one"], 1)
 
- 	assert.Equal(t, c.people[0]["two"], 2)
 
- 	assert.Equal(t, c.people[0]["three"], 1)
 
- 	assert.Equal(t, c.people[0]["five"], 2)
 
- 	assert.Equal(t, c.people[0]["six"], 1)
 
- 	assert.Equal(t, len(c.people[1]), 3)
 
- 	assert.Equal(t, c.people[1]["one"], 1)
 
- 	assert.Equal(t, c.people[1]["three"], 1)
 
- 	assert.Equal(t, c.people[1]["six"], 1)
 
- 	assert.Equal(t, len(c.people[2]), 1)
 
- 	assert.Equal(t, c.people[2]["five"], 1)
 
- 	assert.Equal(t, len(c.files["one"]), 3)
 
- 	assert.Equal(t, c.files["one"]["one"], 2)
 
- 	assert.Equal(t, c.files["one"]["three"], 2)
 
- 	assert.Equal(t, c.files["one"]["five"], 1)
 
- 	assert.NotContains(t, c.files, "two")
 
- 	assert.NotContains(t, c.files, "four")
 
- 	assert.NotContains(t, c.files, "six")
 
- 	assert.Equal(t, len(c.files["three"]), 3)
 
- 	assert.Equal(t, c.files["three"]["three"], 2)
 
- 	assert.Equal(t, c.files["three"]["one"], 2)
 
- 	assert.Equal(t, c.files["three"]["five"], 1)
 
- 	assert.Equal(t, len(c.files["five"]), 3)
 
- 	assert.Equal(t, c.files["five"]["five"], 3)
 
- 	assert.Equal(t, c.files["five"]["one"], 1)
 
- 	assert.Equal(t, c.files["five"]["three"], 1)
 
- 	assert.Equal(t, c.peopleCommits[0], 2)
 
- 	assert.Equal(t, c.peopleCommits[1], 1)
 
- 	assert.Equal(t, c.peopleCommits[2], 1)
 
- 	cr := c.Finalize().(CouplesResult)
 
- 	assert.Equal(t, len(cr.Files), 3)
 
- 	assert.Equal(t, cr.Files[0], "five")
 
- 	assert.Equal(t, cr.Files[1], "one")
 
- 	assert.Equal(t, cr.Files[2], "three")
 
- 	assert.Equal(t, len(cr.PeopleFiles[0]), 3)
 
- 	assert.Equal(t, cr.PeopleFiles[0][0], 0)
 
- 	assert.Equal(t, cr.PeopleFiles[0][1], 1)
 
- 	assert.Equal(t, cr.PeopleFiles[0][2], 2)
 
- 	assert.Equal(t, len(cr.PeopleFiles[1]), 2)
 
- 	assert.Equal(t, cr.PeopleFiles[1][0], 1)
 
- 	assert.Equal(t, cr.PeopleFiles[1][1], 2)
 
- 	assert.Equal(t, len(cr.PeopleFiles[2]), 1)
 
- 	assert.Equal(t, cr.PeopleFiles[2][0], 0)
 
- 	assert.Equal(t, len(cr.PeopleMatrix[0]), 3)
 
- 	assert.Equal(t, cr.PeopleMatrix[0][0], int64(7))
 
- 	assert.Equal(t, cr.PeopleMatrix[0][1], int64(3))
 
- 	assert.Equal(t, cr.PeopleMatrix[0][2], int64(1))
 
- 	assert.Equal(t, len(cr.PeopleMatrix[1]), 2)
 
- 	assert.Equal(t, cr.PeopleMatrix[1][0], int64(3))
 
- 	assert.Equal(t, cr.PeopleMatrix[1][1], int64(3))
 
- 	assert.Equal(t, len(cr.PeopleMatrix[2]), 2)
 
- 	assert.Equal(t, cr.PeopleMatrix[2][0], int64(1))
 
- 	assert.Equal(t, cr.PeopleMatrix[2][2], int64(1))
 
- 	assert.Equal(t, len(cr.FilesMatrix), 3)
 
- 	assert.Equal(t, len(cr.FilesMatrix[0]), 3)
 
- 	assert.Equal(t, cr.FilesMatrix[0][0], int64(3))
 
- 	assert.Equal(t, cr.FilesMatrix[0][1], int64(1))
 
- 	assert.Equal(t, cr.FilesMatrix[0][2], int64(1))
 
- 	assert.Equal(t, len(cr.FilesMatrix[1]), 3)
 
- 	assert.Equal(t, cr.FilesMatrix[1][0], int64(1))
 
- 	assert.Equal(t, cr.FilesMatrix[1][1], int64(2))
 
- 	assert.Equal(t, cr.FilesMatrix[1][2], int64(2))
 
- 	assert.Equal(t, len(cr.FilesMatrix[2]), 3)
 
- 	assert.Equal(t, cr.FilesMatrix[2][0], int64(1))
 
- 	assert.Equal(t, cr.FilesMatrix[2][1], int64(2))
 
- 	assert.Equal(t, cr.FilesMatrix[2][2], int64(2))
 
- }
 
- func TestCouplesSerialize(t *testing.T) {
 
- 	c := fixtureCouples()
 
- 	c.PeopleNumber = 1
 
- 	people := [...]string{"p1", "p2", "p3"}
 
- 	facts := map[string]interface{}{}
 
- 	c.Configure(facts)
 
- 	assert.Equal(t, c.PeopleNumber, 1)
 
- 	facts[identity.FactIdentityDetectorPeopleCount] = 3
 
- 	facts[identity.FactIdentityDetectorReversedPeopleDict] = people[:]
 
- 	c.Configure(facts)
 
- 	assert.Equal(t, c.PeopleNumber, 3)
 
- 	deps := map[string]interface{}{}
 
- 	deps[identity.DependencyAuthor] = 0
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("+two", "+four", "+six")
 
- 	c.Consume(deps)
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("+one", "-two", "=three", ">four>five")
 
- 	c.Consume(deps)
 
- 	deps[identity.DependencyAuthor] = 1
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("=one", "=three", "-six")
 
- 	c.Consume(deps)
 
- 	deps[identity.DependencyAuthor] = 2
 
- 	deps[plumbing.DependencyTreeChanges] = generateChanges("=five")
 
- 	c.Consume(deps)
 
- 	result := c.Finalize().(CouplesResult)
 
- 	buffer := &bytes.Buffer{}
 
- 	c.Serialize(result, false, buffer)
 
- 	assert.Equal(t, buffer.String(), `  files_coocc:
 
-     index:
 
-       - "five"
 
-       - "one"
 
-       - "three"
 
-     matrix:
 
-       - {0: 3, 1: 1, 2: 1}
 
-       - {0: 1, 1: 2, 2: 2}
 
-       - {0: 1, 1: 2, 2: 2}
 
-   people_coocc:
 
-     index:
 
-       - "p1"
 
-       - "p2"
 
-       - "p3"
 
-     matrix:
 
-       - {0: 7, 1: 3, 2: 1}
 
-       - {0: 3, 1: 3}
 
-       - {0: 1, 2: 1}
 
-       - {}
 
-     author_files:
 
-       - "p3":
 
-         - "five"
 
-       - "p2":
 
-         - "one"
 
-         - "three"
 
-       - "p1":
 
-         - "five"
 
-         - "one"
 
-         - "three"
 
- `)
 
- 	buffer = &bytes.Buffer{}
 
- 	c.Serialize(result, true, buffer)
 
- 	msg := pb.CouplesAnalysisResults{}
 
- 	proto.Unmarshal(buffer.Bytes(), &msg)
 
- 	assert.Len(t, msg.PeopleFiles, 3)
 
- 	tmp1 := [...]int32{0, 1, 2}
 
- 	assert.Equal(t, msg.PeopleFiles[0].Files, tmp1[:])
 
- 	tmp2 := [...]int32{1, 2}
 
- 	assert.Equal(t, msg.PeopleFiles[1].Files, tmp2[:])
 
- 	tmp3 := [...]int32{0}
 
- 	assert.Equal(t, msg.PeopleFiles[2].Files, tmp3[:])
 
- 	assert.Equal(t, msg.PeopleCouples.Index, people[:])
 
- 	assert.Equal(t, msg.PeopleCouples.Matrix.NumberOfRows, int32(4))
 
- 	assert.Equal(t, msg.PeopleCouples.Matrix.NumberOfColumns, int32(4))
 
- 	data := [...]int64{7, 3, 1, 3, 3, 1, 1}
 
- 	assert.Equal(t, msg.PeopleCouples.Matrix.Data, data[:])
 
- 	indices := [...]int32{0, 1, 2, 0, 1, 0, 2}
 
- 	assert.Equal(t, msg.PeopleCouples.Matrix.Indices, indices[:])
 
- 	indptr := [...]int64{0, 3, 5, 7, 7}
 
- 	assert.Equal(t, msg.PeopleCouples.Matrix.Indptr, indptr[:])
 
- 	files := [...]string{"five", "one", "three"}
 
- 	assert.Equal(t, msg.FileCouples.Index, files[:])
 
- 	assert.Equal(t, msg.FileCouples.Matrix.NumberOfRows, int32(3))
 
- 	assert.Equal(t, msg.FileCouples.Matrix.NumberOfColumns, int32(3))
 
- 	data2 := [...]int64{3, 1, 1, 1, 2, 2, 1, 2, 2}
 
- 	assert.Equal(t, msg.FileCouples.Matrix.Data, data2[:])
 
- 	indices2 := [...]int32{0, 1, 2, 0, 1, 2, 0, 1, 2}
 
- 	assert.Equal(t, msg.FileCouples.Matrix.Indices, indices2[:])
 
- 	indptr2 := [...]int64{0, 3, 6, 9}
 
- 	assert.Equal(t, msg.FileCouples.Matrix.Indptr, indptr2[:])
 
- }
 
- func TestCouplesDeserialize(t *testing.T) {
 
- 	allBuffer, err := ioutil.ReadFile(path.Join("..", "internal", "test_data", "couples.pb"))
 
- 	assert.Nil(t, err)
 
- 	message := pb.AnalysisResults{}
 
- 	err = proto.Unmarshal(allBuffer, &message)
 
- 	assert.Nil(t, err)
 
- 	couples := CouplesAnalysis{}
 
- 	iresult, err := couples.Deserialize(message.Contents[couples.Name()])
 
- 	assert.Nil(t, err)
 
- 	result := iresult.(CouplesResult)
 
- 	assert.Len(t, result.reversedPeopleDict, 2)
 
- 	assert.Len(t, result.PeopleFiles, 2)
 
- 	assert.Len(t, result.PeopleMatrix, 3)
 
- 	assert.Len(t, result.Files, 74)
 
- 	assert.Len(t, result.FilesMatrix, 74)
 
- }
 
- func TestCouplesMerge(t *testing.T) {
 
- 	r1, r2 := CouplesResult{}, CouplesResult{}
 
- 	people1 := [...]string{"one", "two"}
 
- 	people2 := [...]string{"two", "three"}
 
- 	r1.reversedPeopleDict = people1[:]
 
- 	r2.reversedPeopleDict = people2[:]
 
- 	r1.Files = people1[:]
 
- 	r2.Files = people2[:]
 
- 	r1.PeopleFiles = make([][]int, 2)
 
- 	r1.PeopleFiles[0] = make([]int, 2)
 
- 	r1.PeopleFiles[0][0] = 0
 
- 	r1.PeopleFiles[0][1] = 1
 
- 	r1.PeopleFiles[1] = make([]int, 1)
 
- 	r1.PeopleFiles[1][0] = 0
 
- 	r2.PeopleFiles = make([][]int, 2)
 
- 	r2.PeopleFiles[0] = make([]int, 1)
 
- 	r2.PeopleFiles[0][0] = 1
 
- 	r2.PeopleFiles[1] = make([]int, 2)
 
- 	r2.PeopleFiles[1][0] = 0
 
- 	r2.PeopleFiles[1][1] = 1
 
- 	r1.FilesMatrix = make([]map[int]int64, 2)
 
- 	r1.FilesMatrix[0] = map[int]int64{}
 
- 	r1.FilesMatrix[1] = map[int]int64{}
 
- 	r1.FilesMatrix[0][1] = 100
 
- 	r1.FilesMatrix[1][0] = 100
 
- 	r2.FilesMatrix = make([]map[int]int64, 2)
 
- 	r2.FilesMatrix[0] = map[int]int64{}
 
- 	r2.FilesMatrix[1] = map[int]int64{}
 
- 	r2.FilesMatrix[0][1] = 200
 
- 	r2.FilesMatrix[1][0] = 200
 
- 	r1.PeopleMatrix = make([]map[int]int64, 3)
 
- 	r1.PeopleMatrix[0] = map[int]int64{}
 
- 	r1.PeopleMatrix[1] = map[int]int64{}
 
- 	r1.PeopleMatrix[2] = map[int]int64{}
 
- 	r1.PeopleMatrix[0][1] = 100
 
- 	r1.PeopleMatrix[1][0] = 100
 
- 	r1.PeopleMatrix[2][0] = 300
 
- 	r1.PeopleMatrix[2][1] = 400
 
- 	r2.PeopleMatrix = make([]map[int]int64, 3)
 
- 	r2.PeopleMatrix[0] = map[int]int64{}
 
- 	r2.PeopleMatrix[1] = map[int]int64{}
 
- 	r2.PeopleMatrix[2] = map[int]int64{}
 
- 	r2.PeopleMatrix[0][1] = 10
 
- 	r2.PeopleMatrix[1][0] = 10
 
- 	r2.PeopleMatrix[2][0] = 30
 
- 	r2.PeopleMatrix[2][1] = 40
 
- 	couples := CouplesAnalysis{}
 
- 	merged := couples.MergeResults(r1, r2, nil, nil).(CouplesResult)
 
- 	mergedPeople := [...]string{"one", "two", "three"}
 
- 	assert.Equal(t, merged.reversedPeopleDict, mergedPeople[:])
 
- 	assert.Equal(t, merged.Files, mergedPeople[:])
 
- 	assert.Len(t, merged.PeopleFiles, 3)
 
- 	assert.Equal(t, merged.PeopleFiles[0], getSlice(0, 1))
 
- 	assert.Equal(t, merged.PeopleFiles[1], getSlice(0, 2))
 
- 	assert.Equal(t, merged.PeopleFiles[2], getSlice(1, 2))
 
- 	assert.Len(t, merged.PeopleMatrix, 4)
 
- 	assert.Equal(t, merged.PeopleMatrix[0], getCouplesMap(1, 100))
 
- 	assert.Equal(t, merged.PeopleMatrix[1], getCouplesMap(0, 100, 2, 10))
 
- 	assert.Equal(t, merged.PeopleMatrix[2], getCouplesMap(1, 10))
 
- 	assert.Equal(t, merged.PeopleMatrix[3], getCouplesMap(0, 300, 1, 430, 2, 40))
 
- 	assert.Len(t, merged.FilesMatrix, 3)
 
- 	assert.Equal(t, merged.FilesMatrix[0], getCouplesMap(1, 100))
 
- 	assert.Equal(t, merged.FilesMatrix[1], getCouplesMap(0, 100, 2, 200))
 
- 	assert.Equal(t, merged.FilesMatrix[2], getCouplesMap(1, 200))
 
- }
 
- func getSlice(vals ...int) []int {
 
- 	return vals
 
- }
 
- func getCouplesMap(vals ...int) map[int]int64 {
 
- 	res := map[int]int64{}
 
- 	for i := 0; i < len(vals); i += 2 {
 
- 		res[vals[i]] = int64(vals[i+1])
 
- 	}
 
- 	return res
 
- }
 
 
  |