devs_test.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457
  1. package leaves
  2. import (
  3. "bytes"
  4. "testing"
  5. "time"
  6. "github.com/gogo/protobuf/proto"
  7. "github.com/stretchr/testify/assert"
  8. "gopkg.in/src-d/go-git.v4/plumbing"
  9. "gopkg.in/src-d/go-git.v4/plumbing/object"
  10. "gopkg.in/src-d/hercules.v10/internal/core"
  11. "gopkg.in/src-d/hercules.v10/internal/pb"
  12. items "gopkg.in/src-d/hercules.v10/internal/plumbing"
  13. "gopkg.in/src-d/hercules.v10/internal/plumbing/identity"
  14. "gopkg.in/src-d/hercules.v10/internal/test"
  15. "gopkg.in/src-d/hercules.v10/internal/test/fixtures"
  16. )
  17. func fixtureDevs() *DevsAnalysis {
  18. d := DevsAnalysis{}
  19. d.tickSize = 24 * time.Hour
  20. d.Initialize(test.Repository)
  21. people := [...]string{"one@srcd", "two@srcd"}
  22. d.reversedPeopleDict = people[:]
  23. return &d
  24. }
  25. func TestDevsMeta(t *testing.T) {
  26. d := fixtureDevs()
  27. assert.Equal(t, d.Name(), "Devs")
  28. assert.Equal(t, len(d.Provides()), 0)
  29. assert.Equal(t, len(d.Requires()), 5)
  30. assert.Equal(t, d.Requires()[0], identity.DependencyAuthor)
  31. assert.Equal(t, d.Requires()[1], items.DependencyTreeChanges)
  32. assert.Equal(t, d.Requires()[2], items.DependencyTick)
  33. assert.Equal(t, d.Requires()[3], items.DependencyLanguages)
  34. assert.Equal(t, d.Requires()[4], items.DependencyLineStats)
  35. assert.Equal(t, d.Flag(), "devs")
  36. assert.Len(t, d.ListConfigurationOptions(), 1)
  37. assert.Equal(t, d.ListConfigurationOptions()[0].Name, ConfigDevsConsiderEmptyCommits)
  38. assert.Equal(t, d.ListConfigurationOptions()[0].Flag, "empty-commits")
  39. assert.Equal(t, d.ListConfigurationOptions()[0].Type, core.BoolConfigurationOption)
  40. assert.Equal(t, d.ListConfigurationOptions()[0].Default, false)
  41. assert.True(t, len(d.Description()) > 0)
  42. logger := core.NewLogger()
  43. assert.NoError(t, d.Configure(map[string]interface{}{
  44. core.ConfigLogger: logger,
  45. }))
  46. assert.Equal(t, logger, d.l)
  47. }
  48. func TestDevsRegistration(t *testing.T) {
  49. summoned := core.Registry.Summon((&DevsAnalysis{}).Name())
  50. assert.Len(t, summoned, 1)
  51. assert.Equal(t, summoned[0].Name(), "Devs")
  52. leaves := core.Registry.GetLeaves()
  53. matched := false
  54. for _, tp := range leaves {
  55. if tp.Flag() == (&DevsAnalysis{}).Flag() {
  56. matched = true
  57. break
  58. }
  59. }
  60. assert.True(t, matched)
  61. }
  62. func TestDevsConfigure(t *testing.T) {
  63. devs := DevsAnalysis{}
  64. facts := map[string]interface{}{}
  65. facts[ConfigDevsConsiderEmptyCommits] = true
  66. facts[items.FactTickSize] = 3 * time.Hour
  67. assert.NoError(t, devs.Configure(facts))
  68. assert.True(t, devs.ConsiderEmptyCommits)
  69. assert.Equal(t, 3*time.Hour, devs.tickSize)
  70. }
  71. func TestDevsInitialize(t *testing.T) {
  72. d := fixtureDevs()
  73. assert.NotNil(t, d.ticks)
  74. d = &DevsAnalysis{}
  75. assert.Error(t, d.Initialize(test.Repository))
  76. }
  77. func TestDevsConsumeFinalize(t *testing.T) {
  78. devs := fixtureDevs()
  79. deps := map[string]interface{}{}
  80. // stage 1
  81. deps[identity.DependencyAuthor] = 0
  82. deps[items.DependencyTick] = 0
  83. cache := map[plumbing.Hash]*items.CachedBlob{}
  84. AddHash(t, cache, "291286b4ac41952cbd1389fda66420ec03c1a9fe")
  85. AddHash(t, cache, "c29112dbd697ad9b401333b80c18a63951bc18d9")
  86. AddHash(t, cache, "baa64828831d174f40140e4b3cfa77d1e917a2c1")
  87. AddHash(t, cache, "dc248ba2b22048cc730c571a748e8ffcf7085ab9")
  88. deps[items.DependencyBlobCache] = cache
  89. deps[items.DependencyLanguages] = map[plumbing.Hash]string{
  90. plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"): "Go",
  91. plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"): "Go",
  92. plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"): "Go",
  93. plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"): "Go",
  94. }
  95. changes := make(object.Changes, 3)
  96. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  97. "a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
  98. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  99. "994eac1cd07235bb9815e547a75c84265dea00f5"))
  100. changes[0] = &object.Change{From: object.ChangeEntry{
  101. Name: "analyser.go",
  102. Tree: treeFrom,
  103. TreeEntry: object.TreeEntry{
  104. Name: "analyser.go",
  105. Mode: 0100644,
  106. Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
  107. },
  108. }, To: object.ChangeEntry{
  109. Name: "analyser.go",
  110. Tree: treeTo,
  111. TreeEntry: object.TreeEntry{
  112. Name: "analyser.go",
  113. Mode: 0100644,
  114. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  115. },
  116. }}
  117. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  118. Name: "cmd/hercules/main.go",
  119. Tree: treeTo,
  120. TreeEntry: object.TreeEntry{
  121. Name: "cmd/hercules/main.go",
  122. Mode: 0100644,
  123. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  124. },
  125. },
  126. }
  127. changes[2] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  128. Name: ".travis.yml",
  129. Tree: treeTo,
  130. TreeEntry: object.TreeEntry{
  131. Name: ".travis.yml",
  132. Mode: 0100644,
  133. Hash: plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"),
  134. },
  135. },
  136. }
  137. deps[items.DependencyTreeChanges] = changes
  138. fd := fixtures.FileDiff()
  139. result, err := fd.Consume(deps)
  140. assert.Nil(t, err)
  141. deps[items.DependencyFileDiff] = result[items.DependencyFileDiff]
  142. deps[core.DependencyCommit], _ = test.Repository.CommitObject(plumbing.NewHash(
  143. "cce947b98a050c6d356bc6ba95030254914027b1"))
  144. deps[core.DependencyIsMerge] = false
  145. lsc := &items.LinesStatsCalculator{}
  146. lscres, err := lsc.Consume(deps)
  147. assert.Nil(t, err)
  148. deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
  149. result, err = devs.Consume(deps)
  150. assert.Nil(t, result)
  151. assert.Nil(t, err)
  152. assert.Len(t, devs.ticks, 1)
  153. day := devs.ticks[0]
  154. assert.Len(t, day, 1)
  155. dev := day[0]
  156. assert.Equal(t, dev.Commits, 1)
  157. assert.Equal(t, dev.Added, 847)
  158. assert.Equal(t, dev.Removed, 9)
  159. assert.Equal(t, dev.Changed, 67)
  160. assert.Equal(t, dev.Languages["Go"].Added, 847)
  161. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  162. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  163. deps[core.DependencyIsMerge] = true
  164. lscres, err = lsc.Consume(deps)
  165. assert.Nil(t, err)
  166. deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
  167. result, err = devs.Consume(deps)
  168. assert.Nil(t, result)
  169. assert.Nil(t, err)
  170. assert.Len(t, devs.ticks, 1)
  171. day = devs.ticks[0]
  172. assert.Len(t, day, 1)
  173. dev = day[0]
  174. assert.Equal(t, dev.Commits, 2)
  175. assert.Equal(t, dev.Added, 847)
  176. assert.Equal(t, dev.Removed, 9)
  177. assert.Equal(t, dev.Changed, 67)
  178. assert.Equal(t, dev.Languages["Go"].Added, 847)
  179. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  180. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  181. deps[core.DependencyIsMerge] = false
  182. deps[identity.DependencyAuthor] = 1
  183. lscres, err = lsc.Consume(deps)
  184. assert.Nil(t, err)
  185. deps[items.DependencyLineStats] = lscres[items.DependencyLineStats]
  186. result, err = devs.Consume(deps)
  187. assert.Nil(t, result)
  188. assert.Nil(t, err)
  189. assert.Len(t, devs.ticks, 1)
  190. day = devs.ticks[0]
  191. assert.Len(t, day, 2)
  192. for i := 0; i < 2; i++ {
  193. dev = day[i]
  194. if i == 0 {
  195. assert.Equal(t, dev.Commits, 2)
  196. } else {
  197. assert.Equal(t, dev.Commits, 1)
  198. }
  199. assert.Equal(t, dev.Added, 847)
  200. assert.Equal(t, dev.Removed, 9)
  201. assert.Equal(t, dev.Changed, 67)
  202. assert.Equal(t, dev.Languages["Go"].Added, 847)
  203. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  204. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  205. }
  206. result, err = devs.Consume(deps)
  207. assert.Nil(t, result)
  208. assert.Nil(t, err)
  209. assert.Len(t, devs.ticks, 1)
  210. day = devs.ticks[0]
  211. assert.Len(t, day, 2)
  212. dev = day[0]
  213. assert.Equal(t, dev.Commits, 2)
  214. assert.Equal(t, dev.Added, 847)
  215. assert.Equal(t, dev.Removed, 9)
  216. assert.Equal(t, dev.Changed, 67)
  217. assert.Equal(t, dev.Languages["Go"].Added, 847)
  218. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  219. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  220. dev = day[1]
  221. assert.Equal(t, dev.Commits, 2)
  222. assert.Equal(t, dev.Added, 847*2)
  223. assert.Equal(t, dev.Removed, 9*2)
  224. assert.Equal(t, dev.Changed, 67*2)
  225. assert.Equal(t, dev.Languages["Go"].Added, 847*2)
  226. assert.Equal(t, dev.Languages["Go"].Removed, 9*2)
  227. assert.Equal(t, dev.Languages["Go"].Changed, 67*2)
  228. deps[items.DependencyTick] = 1
  229. result, err = devs.Consume(deps)
  230. assert.Nil(t, result)
  231. assert.Nil(t, err)
  232. assert.Len(t, devs.ticks, 2)
  233. day = devs.ticks[0]
  234. assert.Len(t, day, 2)
  235. dev = day[0]
  236. assert.Equal(t, dev.Commits, 2)
  237. assert.Equal(t, dev.Added, 847)
  238. assert.Equal(t, dev.Removed, 9)
  239. assert.Equal(t, dev.Changed, 67)
  240. assert.Equal(t, dev.Languages["Go"].Added, 847)
  241. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  242. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  243. dev = day[1]
  244. assert.Equal(t, dev.Commits, 2)
  245. assert.Equal(t, dev.Added, 847*2)
  246. assert.Equal(t, dev.Removed, 9*2)
  247. assert.Equal(t, dev.Changed, 67*2)
  248. assert.Equal(t, dev.Languages["Go"].Added, 847*2)
  249. assert.Equal(t, dev.Languages["Go"].Removed, 9*2)
  250. assert.Equal(t, dev.Languages["Go"].Changed, 67*2)
  251. day = devs.ticks[1]
  252. assert.Len(t, day, 1)
  253. dev = day[1]
  254. assert.Equal(t, dev.Commits, 1)
  255. assert.Equal(t, dev.Added, 847)
  256. assert.Equal(t, dev.Removed, 9)
  257. assert.Equal(t, dev.Changed, 67)
  258. assert.Equal(t, dev.Languages["Go"].Added, 847)
  259. assert.Equal(t, dev.Languages["Go"].Removed, 9)
  260. assert.Equal(t, dev.Languages["Go"].Changed, 67)
  261. }
  262. func ls(added, removed, changed int) items.LineStats {
  263. return items.LineStats{Added: added, Removed: removed, Changed: changed}
  264. }
  265. func TestDevsFinalize(t *testing.T) {
  266. devs := fixtureDevs()
  267. devs.ticks[1] = map[int]*DevTick{}
  268. devs.ticks[1][1] = &DevTick{10, ls(20, 30, 40), nil}
  269. x := devs.Finalize().(DevsResult)
  270. assert.Equal(t, x.Ticks, devs.ticks)
  271. assert.Equal(t, x.reversedPeopleDict, devs.reversedPeopleDict)
  272. assert.Equal(t, 24*time.Hour, devs.tickSize)
  273. }
  274. func TestDevsFork(t *testing.T) {
  275. devs := fixtureDevs()
  276. clone := devs.Fork(1)[0].(*DevsAnalysis)
  277. assert.True(t, devs == clone)
  278. }
  279. func TestDevsSerialize(t *testing.T) {
  280. devs := fixtureDevs()
  281. devs.ticks[1] = map[int]*DevTick{}
  282. devs.ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(2, 3, 4)}}
  283. devs.ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(25, 35, 45)}}
  284. devs.ticks[10] = map[int]*DevTick{}
  285. devs.ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"": ls(12, 13, 14)}}
  286. devs.ticks[10][identity.AuthorMissing] = &DevTick{
  287. 100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
  288. res := devs.Finalize().(DevsResult)
  289. buffer := &bytes.Buffer{}
  290. err := devs.Serialize(res, false, buffer)
  291. assert.Nil(t, err)
  292. assert.Equal(t, ` ticks:
  293. 1:
  294. 0: [10, 20, 30, 40, {Go: [2, 3, 4]}]
  295. 1: [1, 2, 3, 4, {Go: [25, 35, 45]}]
  296. 10:
  297. 0: [11, 21, 31, 41, {none: [12, 13, 14]}]
  298. -1: [100, 200, 300, 400, {Go: [32, 33, 34]}]
  299. people:
  300. - "one@srcd"
  301. - "two@srcd"
  302. tick_size: 86400
  303. `, buffer.String())
  304. buffer = &bytes.Buffer{}
  305. err = devs.Serialize(res, true, buffer)
  306. assert.Nil(t, err)
  307. msg := pb.DevsAnalysisResults{}
  308. assert.Nil(t, proto.Unmarshal(buffer.Bytes(), &msg))
  309. assert.Equal(t, msg.DevIndex, devs.reversedPeopleDict)
  310. assert.Equal(t, int64(24*time.Hour), msg.TickSize)
  311. assert.Len(t, msg.Ticks, 2)
  312. assert.Len(t, msg.Ticks[1].Devs, 2)
  313. assert.Equal(t, msg.Ticks[1].Devs[0], &pb.DevTick{
  314. Commits: 10, Stats: &pb.LineStats{Added: 20, Removed: 30, Changed: 40},
  315. Languages: map[string]*pb.LineStats{"Go": {Added: 2, Removed: 3, Changed: 4}}})
  316. assert.Equal(t, msg.Ticks[1].Devs[1], &pb.DevTick{
  317. Commits: 1, Stats: &pb.LineStats{Added: 2, Removed: 3, Changed: 4},
  318. Languages: map[string]*pb.LineStats{"Go": {Added: 25, Removed: 35, Changed: 45}}})
  319. assert.Len(t, msg.Ticks[10].Devs, 2)
  320. assert.Equal(t, msg.Ticks[10].Devs[0], &pb.DevTick{
  321. Commits: 11, Stats: &pb.LineStats{Added: 21, Removed: 31, Changed: 41},
  322. Languages: map[string]*pb.LineStats{"": {Added: 12, Removed: 13, Changed: 14}}})
  323. assert.Equal(t, msg.Ticks[10].Devs[-1], &pb.DevTick{
  324. Commits: 100, Stats: &pb.LineStats{Added: 200, Removed: 300, Changed: 400},
  325. Languages: map[string]*pb.LineStats{"Go": {Added: 32, Removed: 33, Changed: 34}}})
  326. }
  327. func TestDevsDeserialize(t *testing.T) {
  328. devs := fixtureDevs()
  329. devs.ticks[1] = map[int]*DevTick{}
  330. devs.ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
  331. devs.ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
  332. devs.ticks[10] = map[int]*DevTick{}
  333. devs.ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
  334. devs.ticks[10][identity.AuthorMissing] = &DevTick{
  335. 100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
  336. res := devs.Finalize().(DevsResult)
  337. buffer := &bytes.Buffer{}
  338. err := devs.Serialize(res, true, buffer)
  339. assert.Nil(t, err)
  340. rawres2, err := devs.Deserialize(buffer.Bytes())
  341. assert.Nil(t, err)
  342. res2 := rawres2.(DevsResult)
  343. assert.Equal(t, res, res2)
  344. }
  345. func TestDevsMergeResults(t *testing.T) {
  346. people1 := [...]string{"1@srcd", "2@srcd"}
  347. people2 := [...]string{"3@srcd", "1@srcd"}
  348. r1 := DevsResult{
  349. Ticks: map[int]map[int]*DevTick{},
  350. reversedPeopleDict: people1[:],
  351. tickSize: 24 * time.Hour,
  352. }
  353. r1.Ticks[1] = map[int]*DevTick{}
  354. r1.Ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
  355. r1.Ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
  356. r1.Ticks[10] = map[int]*DevTick{}
  357. r1.Ticks[10][0] = &DevTick{11, ls(21, 31, 41), nil}
  358. r1.Ticks[10][identity.AuthorMissing] = &DevTick{
  359. 100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
  360. r1.Ticks[11] = map[int]*DevTick{}
  361. r1.Ticks[11][1] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
  362. r2 := DevsResult{
  363. Ticks: map[int]map[int]*DevTick{},
  364. reversedPeopleDict: people2[:],
  365. tickSize: 22 * time.Hour,
  366. }
  367. r2.Ticks[1] = map[int]*DevTick{}
  368. r2.Ticks[1][0] = &DevTick{10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}}
  369. r2.Ticks[1][1] = &DevTick{1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}}
  370. r2.Ticks[2] = map[int]*DevTick{}
  371. r2.Ticks[2][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}}
  372. r2.Ticks[2][identity.AuthorMissing] = &DevTick{
  373. 100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}}
  374. r2.Ticks[10] = map[int]*DevTick{}
  375. r2.Ticks[10][0] = &DevTick{11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(52, 53, 54)}}
  376. r2.Ticks[10][identity.AuthorMissing] = &DevTick{
  377. 100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(62, 63, 64)}}
  378. devs := fixtureDevs()
  379. c1 := core.CommonAnalysisResult{BeginTime: 1556224895}
  380. assert.IsType(t, assert.AnError, devs.MergeResults(r1, r2, &c1, &c1))
  381. r2.tickSize = r1.tickSize
  382. rm := devs.MergeResults(r1, r2, &c1, &c1).(DevsResult)
  383. peoplerm := [...]string{"1@srcd", "2@srcd", "3@srcd"}
  384. assert.Equal(t, rm.reversedPeopleDict, peoplerm[:])
  385. assert.Len(t, rm.Ticks, 4)
  386. assert.Equal(t, rm.Ticks[11], map[int]*DevTick{
  387. 1: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(42, 43, 44)}}})
  388. assert.Equal(t, rm.Ticks[2], map[int]*DevTick{
  389. identity.AuthorMissing: {100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}},
  390. 2: {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}},
  391. })
  392. assert.Equal(t, rm.Ticks[1], map[int]*DevTick{
  393. 0: {11, ls(22, 33, 44), map[string]items.LineStats{"Go": ls(34, 36, 38)}},
  394. 1: {1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}},
  395. 2: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}},
  396. })
  397. assert.Equal(t, rm.Ticks[10], map[int]*DevTick{
  398. 0: {11, ls(21, 31, 41), map[string]items.LineStats{}},
  399. 2: {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(52, 53, 54)}},
  400. identity.AuthorMissing: {
  401. 100 * 2, ls(200*2, 300*2, 400*2), map[string]items.LineStats{"Go": ls(94, 96, 98)}},
  402. })
  403. c2 := core.CommonAnalysisResult{BeginTime: 1556224895 + 24*3600}
  404. rm = devs.MergeResults(r1, r2, &c1, &c2).(DevsResult)
  405. assert.Len(t, rm.Ticks, 5)
  406. assert.Equal(t, rm.Ticks[1], map[int]*DevTick{
  407. 0: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}},
  408. 1: {1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}},
  409. })
  410. assert.Equal(t, rm.Ticks[2], map[int]*DevTick{
  411. 2: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(12, 13, 14)}},
  412. 0: {1, ls(2, 3, 4), map[string]items.LineStats{"Go": ls(22, 23, 24)}},
  413. })
  414. assert.Equal(t, rm.Ticks[3], map[int]*DevTick{
  415. 2: {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(32, 33, 34)}},
  416. identity.AuthorMissing: {100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(42, 43, 44)}},
  417. })
  418. assert.Equal(t, rm.Ticks[10], map[int]*DevTick{
  419. 0: {11, ls(21, 31, 41), map[string]items.LineStats{}},
  420. identity.AuthorMissing: {100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(32, 33, 34)}},
  421. })
  422. assert.Equal(t, rm.Ticks[11], map[int]*DevTick{
  423. 1: {10, ls(20, 30, 40), map[string]items.LineStats{"Go": ls(42, 43, 44)}},
  424. 2: {11, ls(21, 31, 41), map[string]items.LineStats{"Go": ls(52, 53, 54)}},
  425. identity.AuthorMissing: {100, ls(200, 300, 400), map[string]items.LineStats{"Go": ls(62, 63, 64)}},
  426. })
  427. }
  428. func TestDevsResultGetters(t *testing.T) {
  429. dr := DevsResult{tickSize: time.Hour, reversedPeopleDict: []string{"one", "two"}}
  430. assert.Equal(t, dr.tickSize, dr.GetTickSize())
  431. assert.Equal(t, dr.GetIdentities(), dr.reversedPeopleDict)
  432. }