| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407 | 
							- package leaves
 
- import (
 
- 	"bytes"
 
- 	"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 fixtureDevs() *DevsAnalysis {
 
- 	d := DevsAnalysis{}
 
- 	d.Initialize(test.Repository)
 
- 	people := [...]string{"one@srcd", "two@srcd"}
 
- 	d.reversedPeopleDict = people[:]
 
- 	return &d
 
- }
 
- func TestDevsMeta(t *testing.T) {
 
- 	d := fixtureDevs()
 
- 	assert.Equal(t, d.Name(), "Devs")
 
- 	assert.Equal(t, len(d.Provides()), 0)
 
- 	assert.Equal(t, len(d.Requires()), 5)
 
- 	assert.Equal(t, d.Requires()[0], identity.DependencyAuthor)
 
- 	assert.Equal(t, d.Requires()[1], items.DependencyTreeChanges)
 
- 	assert.Equal(t, d.Requires()[2], items.DependencyTick)
 
- 	assert.Equal(t, d.Requires()[3], items.DependencyLanguages)
 
- 	assert.Equal(t, d.Requires()[4], items.DependencyLineStats)
 
- 	assert.Equal(t, d.Flag(), "devs")
 
- 	assert.Len(t, d.ListConfigurationOptions(), 1)
 
- 	assert.Equal(t, d.ListConfigurationOptions()[0].Name, ConfigDevsConsiderEmptyCommits)
 
- 	assert.Equal(t, d.ListConfigurationOptions()[0].Flag, "empty-commits")
 
- 	assert.Equal(t, d.ListConfigurationOptions()[0].Type, core.BoolConfigurationOption)
 
- 	assert.Equal(t, d.ListConfigurationOptions()[0].Default, false)
 
- 	assert.True(t, len(d.Description()) > 0)
 
- }
 
- func TestDevsRegistration(t *testing.T) {
 
- 	summoned := core.Registry.Summon((&DevsAnalysis{}).Name())
 
- 	assert.Len(t, summoned, 1)
 
- 	assert.Equal(t, summoned[0].Name(), "Devs")
 
- 	leaves := core.Registry.GetLeaves()
 
- 	matched := false
 
- 	for _, tp := range leaves {
 
- 		if tp.Flag() == (&DevsAnalysis{}).Flag() {
 
- 			matched = true
 
- 			break
 
- 		}
 
- 	}
 
- 	assert.True(t, matched)
 
- }
 
- func TestDevsConfigure(t *testing.T) {
 
- 	devs := DevsAnalysis{}
 
- 	facts := map[string]interface{}{}
 
- 	facts[ConfigDevsConsiderEmptyCommits] = true
 
- 	devs.Configure(facts)
 
- 	assert.Equal(t, devs.ConsiderEmptyCommits, true)
 
- }
 
- func TestDevsInitialize(t *testing.T) {
 
- 	d := fixtureDevs()
 
- 	assert.NotNil(t, d.ticks)
 
- }
 
- func TestDevsConsumeFinalize(t *testing.T) {
 
- 	devs := fixtureDevs()
 
- 	deps := map[string]interface{}{}
 
- 	// stage 1
 
- 	deps[identity.DependencyAuthor] = 0
 
- 	deps[items.DependencyTick] = 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 = devs.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, devs.ticks, 1)
 
- 	day := devs.ticks[0]
 
- 	assert.Len(t, day, 1)
 
- 	dev := day[0]
 
- 	assert.Equal(t, dev.Commits, 1)
 
- 	assert.Equal(t, dev.Added, 847)
 
- 	assert.Equal(t, dev.Removed, 9)
 
- 	assert.Equal(t, dev.Changed, 67)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- 	deps[core.DependencyIsMerge] = true
 
- 	lscres, err = lsc.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
 
- 	result, err = devs.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, devs.ticks, 1)
 
- 	day = devs.ticks[0]
 
- 	assert.Len(t, day, 1)
 
- 	dev = day[0]
 
- 	assert.Equal(t, dev.Commits, 2)
 
- 	assert.Equal(t, dev.Added, 847)
 
- 	assert.Equal(t, dev.Removed, 9)
 
- 	assert.Equal(t, dev.Changed, 67)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- 	deps[core.DependencyIsMerge] = false
 
- 	deps[identity.DependencyAuthor] = 1
 
- 	lscres, err = lsc.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
 
- 	result, err = devs.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, devs.ticks, 1)
 
- 	day = devs.ticks[0]
 
- 	assert.Len(t, day, 2)
 
- 	for i := 0; i < 2; i++ {
 
- 		dev = day[i]
 
- 		if i == 0 {
 
- 			assert.Equal(t, dev.Commits, 2)
 
- 		} else {
 
- 			assert.Equal(t, dev.Commits, 1)
 
- 		}
 
- 		assert.Equal(t, dev.Added, 847)
 
- 		assert.Equal(t, dev.Removed, 9)
 
- 		assert.Equal(t, dev.Changed, 67)
 
- 		assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 		assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 		assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- 	}
 
- 	result, err = devs.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, devs.ticks, 1)
 
- 	day = devs.ticks[0]
 
- 	assert.Len(t, day, 2)
 
- 	dev = day[0]
 
- 	assert.Equal(t, dev.Commits, 2)
 
- 	assert.Equal(t, dev.Added, 847)
 
- 	assert.Equal(t, dev.Removed, 9)
 
- 	assert.Equal(t, dev.Changed, 67)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- 	dev = day[1]
 
- 	assert.Equal(t, dev.Commits, 2)
 
- 	assert.Equal(t, dev.Added, 847*2)
 
- 	assert.Equal(t, dev.Removed, 9*2)
 
- 	assert.Equal(t, dev.Changed, 67*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67*2)
 
- 	deps[items.DependencyTick] = 1
 
- 	result, err = devs.Consume(deps)
 
- 	assert.Nil(t, result)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, devs.ticks, 2)
 
- 	day = devs.ticks[0]
 
- 	assert.Len(t, day, 2)
 
- 	dev = day[0]
 
- 	assert.Equal(t, dev.Commits, 2)
 
- 	assert.Equal(t, dev.Added, 847)
 
- 	assert.Equal(t, dev.Removed, 9)
 
- 	assert.Equal(t, dev.Changed, 67)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- 	dev = day[1]
 
- 	assert.Equal(t, dev.Commits, 2)
 
- 	assert.Equal(t, dev.Added, 847*2)
 
- 	assert.Equal(t, dev.Removed, 9*2)
 
- 	assert.Equal(t, dev.Changed, 67*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9*2)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67*2)
 
- 	day = devs.ticks[1]
 
- 	assert.Len(t, day, 1)
 
- 	dev = day[1]
 
- 	assert.Equal(t, dev.Commits, 1)
 
- 	assert.Equal(t, dev.Added, 847)
 
- 	assert.Equal(t, dev.Removed, 9)
 
- 	assert.Equal(t, dev.Changed, 67)
 
- 	assert.Equal(t, dev.Languages["Go"].Added, 847)
 
- 	assert.Equal(t, dev.Languages["Go"].Removed, 9)
 
- 	assert.Equal(t, dev.Languages["Go"].Changed, 67)
 
- }
 
- func ls(added, removed, changed int) items.LineStats {
 
- 	return items.LineStats{Added: added, Removed: removed, Changed: changed}
 
- }
 
- func TestDevsFinalize(t *testing.T) {
 
- 	devs := fixtureDevs()
 
- 	devs.ticks[1] = map[int]*DevTick{}
 
- 	devs.ticks[1][1] = &DevTick{10, ls(20, 30, 40), nil}
 
- 	x := devs.Finalize().(DevsResult)
 
- 	assert.Equal(t, x.Ticks, devs.ticks)
 
- 	assert.Equal(t, x.reversedPeopleDict, devs.reversedPeopleDict)
 
- }
 
- func TestDevsFork(t *testing.T) {
 
- 	devs := fixtureDevs()
 
- 	clone := devs.Fork(1)[0].(*DevsAnalysis)
 
- 	assert.True(t, devs == clone)
 
- }
 
- func TestDevsSerialize(t *testing.T) {
 
- 	devs := fixtureDevs()
 
- 	devs.ticks[1] = map[int]*DevTick{}
 
- 	devs.ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(2, 3, 4)}}
 
- 	devs.ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(25, 35, 45)}}
 
- 	devs.ticks[10] = map[int]*DevTick{}
 
- 	devs.ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"": ls(12, 13, 14)}}
 
- 	devs.ticks[10][identity.AuthorMissing] = &DevTick{
 
- 		100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
 
- 	res := devs.Finalize().(DevsResult)
 
- 	buffer := &bytes.Buffer{}
 
- 	err := devs.Serialize(res, false, buffer)
 
- 	assert.Nil(t, err)
 
- 	assert.Equal(t, `  ticks:
 
-     1:
 
-       0: [10, 20, 30, 40, {Go: [2, 3, 4]}]
 
-       1: [1, 2, 3, 4, {Go: [25, 35, 45]}]
 
-     10:
 
-       0: [11, 21, 31, 41, {none: [12, 13, 14]}]
 
-       -1: [100, 200, 300, 400, {Go: [32, 33, 34]}]
 
-   people:
 
-   - "one@srcd"
 
-   - "two@srcd"
 
- `, buffer.String())
 
- 	buffer = &bytes.Buffer{}
 
- 	err = devs.Serialize(res, true, buffer)
 
- 	assert.Nil(t, err)
 
- 	msg := pb.DevsAnalysisResults{}
 
- 	assert.Nil(t, proto.Unmarshal(buffer.Bytes(), &msg))
 
- 	assert.Equal(t, msg.DevIndex, devs.reversedPeopleDict)
 
- 	assert.Len(t, msg.Ticks, 2)
 
- 	assert.Len(t, msg.Ticks[1].Devs, 2)
 
- 	assert.Equal(t, msg.Ticks[1].Devs[0], &pb.DevTick{
 
- 		Commits: 10, Stats: &pb.LineStats{Added: 20, Removed: 30, Changed: 40},
 
- 		Languages: map[string]*pb.LineStats{"Go": {Added: 2, Removed: 3, Changed: 4}}})
 
- 	assert.Equal(t, msg.Ticks[1].Devs[1], &pb.DevTick{
 
- 		Commits: 1, Stats: &pb.LineStats{Added: 2, Removed: 3, Changed: 4},
 
- 		Languages: map[string]*pb.LineStats{"Go": {Added: 25, Removed: 35, Changed: 45}}})
 
- 	assert.Len(t, msg.Ticks[10].Devs, 2)
 
- 	assert.Equal(t, msg.Ticks[10].Devs[0], &pb.DevTick{
 
- 		Commits: 11, Stats: &pb.LineStats{Added: 21, Removed: 31, Changed: 41},
 
- 		Languages: map[string]*pb.LineStats{"": {Added: 12, Removed: 13, Changed: 14}}})
 
- 	assert.Equal(t, msg.Ticks[10].Devs[-1], &pb.DevTick{
 
- 		Commits: 100, Stats: &pb.LineStats{Added: 200, Removed: 300, Changed: 400},
 
- 		Languages: map[string]*pb.LineStats{"Go": {Added: 32, Removed: 33, Changed: 34}}})
 
- }
 
- func TestDevsDeserialize(t *testing.T) {
 
- 	devs := fixtureDevs()
 
- 	devs.ticks[1] = map[int]*DevTick{}
 
- 	devs.ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
 
- 	devs.ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
 
- 	devs.ticks[10] = map[int]*DevTick{}
 
- 	devs.ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
 
- 	devs.ticks[10][identity.AuthorMissing] = &DevTick{
 
- 		100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
 
- 	res := devs.Finalize().(DevsResult)
 
- 	buffer := &bytes.Buffer{}
 
- 	err := devs.Serialize(res, true, buffer)
 
- 	assert.Nil(t, err)
 
- 	rawres2, err := devs.Deserialize(buffer.Bytes())
 
- 	assert.Nil(t, err)
 
- 	res2 := rawres2.(DevsResult)
 
- 	assert.Equal(t, res, res2)
 
- }
 
- func TestDevsMergeResults(t *testing.T) {
 
- 	people1 := [...]string{"1@srcd", "2@srcd"}
 
- 	people2 := [...]string{"3@srcd", "1@srcd"}
 
- 	r1 := DevsResult{
 
- 		Ticks:              map[int]map[int]*DevTick{},
 
- 		reversedPeopleDict: people1[:],
 
- 	}
 
- 	r1.Ticks[1] = map[int]*DevTick{}
 
- 	r1.Ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
 
- 	r1.Ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
 
- 	r1.Ticks[10] = map[int]*DevTick{}
 
- 	r1.Ticks[10][0] = &DevTick{11, ls(21, 31, 41), nil}
 
- 	r1.Ticks[10][identity.AuthorMissing] = &DevTick{
 
- 		100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
 
- 	r1.Ticks[11] = map[int]*DevTick{}
 
- 	r1.Ticks[11][1] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
 
- 	r2 := DevsResult{
 
- 		Ticks:              map[int]map[int]*DevTick{},
 
- 		reversedPeopleDict: people2[:],
 
- 	}
 
- 	r2.Ticks[1] = map[int]*DevTick{}
 
- 	r2.Ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
 
- 	r2.Ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
 
- 	r2.Ticks[2] = map[int]*DevTick{}
 
- 	r2.Ticks[2][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
 
- 	r2.Ticks[2][identity.AuthorMissing] = &DevTick{
 
- 		100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
 
- 	r2.Ticks[10] = map[int]*DevTick{}
 
- 	r2.Ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(52, 53, 54)}}
 
- 	r2.Ticks[10][identity.AuthorMissing] = &DevTick{
 
- 		100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(62, 63, 64)}}
 
- 	devs := fixtureDevs()
 
- 	rm := devs.MergeResults(r1, r2, nil, nil).(DevsResult)
 
- 	peoplerm := [...]string{"1@srcd", "2@srcd", "3@srcd"}
 
- 	assert.Equal(t, rm.reversedPeopleDict, peoplerm[:])
 
- 	assert.Len(t, rm.Ticks, 4)
 
- 	assert.Equal(t, rm.Ticks[11], map[int]*DevTick{
 
- 		1: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(42, 43, 44)}}})
 
- 	assert.Equal(t, rm.Ticks[2], map[int]*DevTick{
 
- 		identity.AuthorMissing: {100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}},
 
- 		2:                      {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}},
 
- 	})
 
- 	assert.Equal(t, rm.Ticks[1], map[int]*DevTick{
 
- 		0: {11, ls(22, 33, 44), map[string]items.LineStats{"Go": ls(34, 36, 38)}},
 
- 		1: {1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}},
 
- 		2: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}},
 
- 	})
 
- 	assert.Equal(t, rm.Ticks[10], map[int]*DevTick{
 
- 		0: {11, ls(21, 31, 41), map[string]items.LineStats{}},
 
- 		2: {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(52, 53, 54)}},
 
- 		identity.AuthorMissing: {
 
- 			100 * 2, ls(200*2, 300*2, 400*2), map[string]items.LineStats{"Go": ls(94, 96, 98)}},
 
- 	})
 
- }
 
 
  |