couples_test.go 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package hercules
  2. import (
  3. "bytes"
  4. "strings"
  5. "testing"
  6. "github.com/gogo/protobuf/proto"
  7. "github.com/stretchr/testify/assert"
  8. "gopkg.in/src-d/go-git.v4/plumbing/object"
  9. "gopkg.in/src-d/hercules.v3/pb"
  10. )
  11. func fixtureCouples() *CouplesAnalysis {
  12. c := CouplesAnalysis{PeopleNumber: 3}
  13. c.Initialize(testRepository)
  14. return &c
  15. }
  16. func TestCouplesMeta(t *testing.T) {
  17. c := fixtureCouples()
  18. assert.Equal(t, c.Name(), "Couples")
  19. assert.Equal(t, len(c.Provides()), 0)
  20. assert.Equal(t, len(c.Requires()), 2)
  21. assert.Equal(t, c.Requires()[0], "author")
  22. assert.Equal(t, c.Requires()[1], "changes")
  23. assert.Equal(t, c.Flag(), "couples")
  24. assert.Len(t, c.ListConfigurationOptions(), 0)
  25. }
  26. func TestCouplesRegistration(t *testing.T) {
  27. tp, exists := Registry.registered[(&CouplesAnalysis{}).Name()]
  28. assert.True(t, exists)
  29. assert.Equal(t, tp.Elem().Name(), "CouplesAnalysis")
  30. tp, exists = Registry.flags[(&CouplesAnalysis{}).Flag()]
  31. assert.True(t, exists)
  32. assert.Equal(t, tp.Elem().Name(), "CouplesAnalysis")
  33. }
  34. func generateChanges(names ...string) object.Changes {
  35. changes := make(object.Changes, 0, len(names))
  36. for _, name := range names {
  37. action := name[:1]
  38. name = name[1:]
  39. var change object.Change
  40. if action == "+" {
  41. change = object.Change{
  42. From: object.ChangeEntry{},
  43. To: object.ChangeEntry{Name: name},
  44. }
  45. } else if action == "-" {
  46. change = object.Change{
  47. From: object.ChangeEntry{Name: name},
  48. To: object.ChangeEntry{},
  49. }
  50. } else if action == "=" {
  51. change = object.Change{
  52. From: object.ChangeEntry{Name: name},
  53. To: object.ChangeEntry{Name: name},
  54. }
  55. } else {
  56. if action != ">" {
  57. panic("Invalid action.")
  58. }
  59. parts := strings.Split(name, ">")
  60. change = object.Change{
  61. From: object.ChangeEntry{Name: parts[0]},
  62. To: object.ChangeEntry{Name: parts[1]},
  63. }
  64. }
  65. changes = append(changes, &change)
  66. }
  67. return changes
  68. }
  69. func TestCouplesConsumeFinalize(t *testing.T) {
  70. c := fixtureCouples()
  71. deps := map[string]interface{}{}
  72. deps["author"] = 0
  73. deps["changes"] = generateChanges("+two", "+four", "+six")
  74. c.Consume(deps)
  75. deps["changes"] = generateChanges("+one", "-two", "=three", ">four>five")
  76. c.Consume(deps)
  77. deps["author"] = 1
  78. deps["changes"] = generateChanges("=one", "=three", "-six")
  79. c.Consume(deps)
  80. deps["author"] = 2
  81. deps["changes"] = generateChanges("=five")
  82. c.Consume(deps)
  83. assert.Equal(t, len(c.people[0]), 5)
  84. assert.Equal(t, c.people[0]["one"], 1)
  85. assert.Equal(t, c.people[0]["two"], 2)
  86. assert.Equal(t, c.people[0]["three"], 1)
  87. assert.Equal(t, c.people[0]["five"], 2)
  88. assert.Equal(t, c.people[0]["six"], 1)
  89. assert.Equal(t, len(c.people[1]), 3)
  90. assert.Equal(t, c.people[1]["one"], 1)
  91. assert.Equal(t, c.people[1]["three"], 1)
  92. assert.Equal(t, c.people[1]["six"], 1)
  93. assert.Equal(t, len(c.people[2]), 1)
  94. assert.Equal(t, c.people[2]["five"], 1)
  95. assert.Equal(t, len(c.files["one"]), 3)
  96. assert.Equal(t, c.files["one"]["one"], 2)
  97. assert.Equal(t, c.files["one"]["three"], 2)
  98. assert.Equal(t, c.files["one"]["five"], 1)
  99. assert.NotContains(t, c.files, "two")
  100. assert.NotContains(t, c.files, "four")
  101. assert.NotContains(t, c.files, "six")
  102. assert.Equal(t, len(c.files["three"]), 3)
  103. assert.Equal(t, c.files["three"]["three"], 2)
  104. assert.Equal(t, c.files["three"]["one"], 2)
  105. assert.Equal(t, c.files["three"]["five"], 1)
  106. assert.Equal(t, len(c.files["five"]), 3)
  107. assert.Equal(t, c.files["five"]["five"], 3)
  108. assert.Equal(t, c.files["five"]["one"], 1)
  109. assert.Equal(t, c.files["five"]["three"], 1)
  110. assert.Equal(t, c.people_commits[0], 2)
  111. assert.Equal(t, c.people_commits[1], 1)
  112. assert.Equal(t, c.people_commits[2], 1)
  113. cr := c.Finalize().(CouplesResult)
  114. assert.Equal(t, len(cr.Files), 3)
  115. assert.Equal(t, cr.Files[0], "five")
  116. assert.Equal(t, cr.Files[1], "one")
  117. assert.Equal(t, cr.Files[2], "three")
  118. assert.Equal(t, len(cr.PeopleFiles[0]), 3)
  119. assert.Equal(t, cr.PeopleFiles[0][0], 0)
  120. assert.Equal(t, cr.PeopleFiles[0][1], 1)
  121. assert.Equal(t, cr.PeopleFiles[0][2], 2)
  122. assert.Equal(t, len(cr.PeopleFiles[1]), 2)
  123. assert.Equal(t, cr.PeopleFiles[1][0], 1)
  124. assert.Equal(t, cr.PeopleFiles[1][1], 2)
  125. assert.Equal(t, len(cr.PeopleFiles[2]), 1)
  126. assert.Equal(t, cr.PeopleFiles[2][0], 0)
  127. assert.Equal(t, len(cr.PeopleMatrix[0]), 3)
  128. assert.Equal(t, cr.PeopleMatrix[0][0], int64(7))
  129. assert.Equal(t, cr.PeopleMatrix[0][1], int64(3))
  130. assert.Equal(t, cr.PeopleMatrix[0][2], int64(1))
  131. assert.Equal(t, len(cr.PeopleMatrix[1]), 2)
  132. assert.Equal(t, cr.PeopleMatrix[1][0], int64(3))
  133. assert.Equal(t, cr.PeopleMatrix[1][1], int64(3))
  134. assert.Equal(t, len(cr.PeopleMatrix[2]), 2)
  135. assert.Equal(t, cr.PeopleMatrix[2][0], int64(1))
  136. assert.Equal(t, cr.PeopleMatrix[2][2], int64(1))
  137. assert.Equal(t, len(cr.FilesMatrix), 3)
  138. assert.Equal(t, len(cr.FilesMatrix[0]), 3)
  139. assert.Equal(t, cr.FilesMatrix[0][0], int64(3))
  140. assert.Equal(t, cr.FilesMatrix[0][1], int64(1))
  141. assert.Equal(t, cr.FilesMatrix[0][2], int64(1))
  142. assert.Equal(t, len(cr.FilesMatrix[1]), 3)
  143. assert.Equal(t, cr.FilesMatrix[1][0], int64(1))
  144. assert.Equal(t, cr.FilesMatrix[1][1], int64(2))
  145. assert.Equal(t, cr.FilesMatrix[1][2], int64(2))
  146. assert.Equal(t, len(cr.FilesMatrix[2]), 3)
  147. assert.Equal(t, cr.FilesMatrix[2][0], int64(1))
  148. assert.Equal(t, cr.FilesMatrix[2][1], int64(2))
  149. assert.Equal(t, cr.FilesMatrix[2][2], int64(2))
  150. }
  151. func TestCouplesSerialize(t *testing.T) {
  152. c := fixtureCouples()
  153. c.PeopleNumber = 1
  154. people := [...]string{"p1", "p2", "p3"}
  155. facts := map[string]interface{}{}
  156. c.Configure(facts)
  157. assert.Equal(t, c.PeopleNumber, 1)
  158. facts[FactIdentityDetectorPeopleCount] = 3
  159. facts[FactIdentityDetectorReversedPeopleDict] = people[:]
  160. c.Configure(facts)
  161. assert.Equal(t, c.PeopleNumber, 3)
  162. deps := map[string]interface{}{}
  163. deps["author"] = 0
  164. deps["changes"] = generateChanges("+two", "+four", "+six")
  165. c.Consume(deps)
  166. deps["changes"] = generateChanges("+one", "-two", "=three", ">four>five")
  167. c.Consume(deps)
  168. deps["author"] = 1
  169. deps["changes"] = generateChanges("=one", "=three", "-six")
  170. c.Consume(deps)
  171. deps["author"] = 2
  172. deps["changes"] = generateChanges("=five")
  173. c.Consume(deps)
  174. result := c.Finalize().(CouplesResult)
  175. buffer := &bytes.Buffer{}
  176. c.Serialize(result, false, buffer)
  177. assert.Equal(t, buffer.String(), ` files_coocc:
  178. index:
  179. - "five"
  180. - "one"
  181. - "three"
  182. matrix:
  183. - {0: 3, 1: 1, 2: 1}
  184. - {0: 1, 1: 2, 2: 2}
  185. - {0: 1, 1: 2, 2: 2}
  186. people_coocc:
  187. index:
  188. - "p1"
  189. - "p2"
  190. - "p3"
  191. matrix:
  192. - {0: 7, 1: 3, 2: 1}
  193. - {0: 3, 1: 3}
  194. - {0: 1, 2: 1}
  195. - {}
  196. author_files:
  197. - "p3":
  198. - "five"
  199. - "p2":
  200. - "one"
  201. - "three"
  202. - "p1":
  203. - "five"
  204. - "one"
  205. - "three"
  206. `)
  207. buffer = &bytes.Buffer{}
  208. c.Serialize(result, true, buffer)
  209. msg := pb.CouplesAnalysisResults{}
  210. proto.Unmarshal(buffer.Bytes(), &msg)
  211. assert.Len(t, msg.TouchedFiles.Developers, 3)
  212. tmp1 := [...]int32{0, 1, 2}
  213. assert.Equal(t, msg.TouchedFiles.Developers[0].Files, tmp1[:])
  214. tmp2 := [...]int32{1, 2}
  215. assert.Equal(t, msg.TouchedFiles.Developers[1].Files, tmp2[:])
  216. tmp3 := [...]int32{0}
  217. assert.Equal(t, msg.TouchedFiles.Developers[2].Files, tmp3[:])
  218. assert.Equal(t, msg.DeveloperCouples.Index, people[:])
  219. assert.Equal(t, msg.DeveloperCouples.Matrix.NumberOfRows, int32(4))
  220. assert.Equal(t, msg.DeveloperCouples.Matrix.NumberOfColumns, int32(4))
  221. data := [...]int64{7, 3, 1, 3, 3, 1, 1}
  222. assert.Equal(t, msg.DeveloperCouples.Matrix.Data, data[:])
  223. indices := [...]int32{0, 1, 2, 0, 1, 0, 2}
  224. assert.Equal(t, msg.DeveloperCouples.Matrix.Indices, indices[:])
  225. indptr := [...]int64{0, 3, 5, 7, 7}
  226. assert.Equal(t, msg.DeveloperCouples.Matrix.Indptr, indptr[:])
  227. files := [...]string{"five", "one", "three"}
  228. assert.Equal(t, msg.FileCouples.Index, files[:])
  229. assert.Equal(t, msg.FileCouples.Matrix.NumberOfRows, int32(3))
  230. assert.Equal(t, msg.FileCouples.Matrix.NumberOfColumns, int32(3))
  231. data2 := [...]int64{3, 1, 1, 1, 2, 2, 1, 2, 2}
  232. assert.Equal(t, msg.FileCouples.Matrix.Data, data2[:])
  233. indices2 := [...]int32{0, 1, 2, 0, 1, 2, 0, 1, 2}
  234. assert.Equal(t, msg.FileCouples.Matrix.Indices, indices2[:])
  235. indptr2 := [...]int64{0, 3, 6, 9}
  236. assert.Equal(t, msg.FileCouples.Matrix.Indptr, indptr2[:])
  237. }