couples_test.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. package hercules
  2. import (
  3. "strings"
  4. "testing"
  5. "github.com/stretchr/testify/assert"
  6. "gopkg.in/src-d/go-git.v4/plumbing/object"
  7. )
  8. func fixtureCouples() *Couples {
  9. c := Couples{PeopleNumber: 3}
  10. c.Initialize(testRepository)
  11. return &c
  12. }
  13. func TestCouplesMeta(t *testing.T) {
  14. c := fixtureCouples()
  15. assert.Equal(t, c.Name(), "Couples")
  16. assert.Equal(t, len(c.Provides()), 0)
  17. assert.Equal(t, len(c.Requires()), 2)
  18. assert.Equal(t, c.Requires()[0], "author")
  19. assert.Equal(t, c.Requires()[1], "renamed_changes")
  20. }
  21. func generateChanges(names ...string) object.Changes {
  22. changes := make(object.Changes, 0, len(names))
  23. for _, name := range names {
  24. action := name[:1]
  25. name = name[1:]
  26. var change object.Change
  27. if action == "+" {
  28. change = object.Change{
  29. From: object.ChangeEntry{},
  30. To: object.ChangeEntry{Name: name},
  31. }
  32. } else if action == "-" {
  33. change = object.Change{
  34. From: object.ChangeEntry{Name: name},
  35. To: object.ChangeEntry{},
  36. }
  37. } else if action == "=" {
  38. change = object.Change{
  39. From: object.ChangeEntry{Name: name},
  40. To: object.ChangeEntry{Name: name},
  41. }
  42. } else {
  43. if action != ">" {
  44. panic("Invalid action.")
  45. }
  46. parts := strings.Split(name, ">")
  47. change = object.Change{
  48. From: object.ChangeEntry{Name: parts[0]},
  49. To: object.ChangeEntry{Name: parts[1]},
  50. }
  51. }
  52. changes = append(changes, &change)
  53. }
  54. return changes
  55. }
  56. func TestCouplesConsumeFinalize(t *testing.T) {
  57. c := fixtureCouples()
  58. deps := map[string]interface{}{}
  59. deps["author"] = 0
  60. deps["renamed_changes"] = generateChanges("+two", "+four", "+six")
  61. c.Consume(deps)
  62. deps["renamed_changes"] = generateChanges("+one", "-two", "=three", ">four>five")
  63. c.Consume(deps)
  64. deps["author"] = 1
  65. deps["renamed_changes"] = generateChanges("=one", "=three", "-six")
  66. c.Consume(deps)
  67. deps["author"] = 2
  68. deps["renamed_changes"] = generateChanges("=five")
  69. c.Consume(deps)
  70. assert.Equal(t, len(c.people[0]), 5)
  71. assert.Equal(t, c.people[0]["one"], 1)
  72. assert.Equal(t, c.people[0]["two"], 2)
  73. assert.Equal(t, c.people[0]["three"], 1)
  74. assert.Equal(t, c.people[0]["five"], 2)
  75. assert.Equal(t, c.people[0]["six"], 1)
  76. assert.Equal(t, len(c.people[1]), 3)
  77. assert.Equal(t, c.people[1]["one"], 1)
  78. assert.Equal(t, c.people[1]["three"], 1)
  79. assert.Equal(t, c.people[1]["six"], 1)
  80. assert.Equal(t, len(c.people[2]), 1)
  81. assert.Equal(t, c.people[2]["five"], 1)
  82. assert.Equal(t, len(c.files["one"]), 3)
  83. assert.Equal(t, c.files["one"]["one"], 2)
  84. assert.Equal(t, c.files["one"]["three"], 2)
  85. assert.Equal(t, c.files["one"]["five"], 1)
  86. assert.NotContains(t, c.files, "two")
  87. assert.NotContains(t, c.files, "four")
  88. assert.NotContains(t, c.files, "six")
  89. assert.Equal(t, len(c.files["three"]), 3)
  90. assert.Equal(t, c.files["three"]["three"], 2)
  91. assert.Equal(t, c.files["three"]["one"], 2)
  92. assert.Equal(t, c.files["three"]["five"], 1)
  93. assert.Equal(t, len(c.files["five"]), 3)
  94. assert.Equal(t, c.files["five"]["five"], 3)
  95. assert.Equal(t, c.files["five"]["one"], 1)
  96. assert.Equal(t, c.files["five"]["three"], 1)
  97. assert.Equal(t, c.people_commits[0], 2)
  98. assert.Equal(t, c.people_commits[1], 1)
  99. assert.Equal(t, c.people_commits[2], 1)
  100. cr := c.Finalize().(CouplesResult)
  101. assert.Equal(t, len(cr.Files), 3)
  102. assert.Equal(t, cr.Files[0], "five")
  103. assert.Equal(t, cr.Files[1], "one")
  104. assert.Equal(t, cr.Files[2], "three")
  105. assert.Equal(t, len(cr.PeopleFiles[0]), 3)
  106. assert.Equal(t, cr.PeopleFiles[0][0], 0)
  107. assert.Equal(t, cr.PeopleFiles[0][1], 1)
  108. assert.Equal(t, cr.PeopleFiles[0][2], 2)
  109. assert.Equal(t, len(cr.PeopleFiles[1]), 2)
  110. assert.Equal(t, cr.PeopleFiles[1][0], 1)
  111. assert.Equal(t, cr.PeopleFiles[1][1], 2)
  112. assert.Equal(t, len(cr.PeopleFiles[2]), 1)
  113. assert.Equal(t, cr.PeopleFiles[2][0], 0)
  114. assert.Equal(t, len(cr.PeopleMatrix[0]), 3)
  115. assert.Equal(t, cr.PeopleMatrix[0][0], int64(7))
  116. assert.Equal(t, cr.PeopleMatrix[0][1], int64(3))
  117. assert.Equal(t, cr.PeopleMatrix[0][2], int64(1))
  118. assert.Equal(t, len(cr.PeopleMatrix[1]), 2)
  119. assert.Equal(t, cr.PeopleMatrix[1][0], int64(3))
  120. assert.Equal(t, cr.PeopleMatrix[1][1], int64(3))
  121. assert.Equal(t, len(cr.PeopleMatrix[2]), 2)
  122. assert.Equal(t, cr.PeopleMatrix[2][0], int64(1))
  123. assert.Equal(t, cr.PeopleMatrix[2][2], int64(1))
  124. assert.Equal(t, len(cr.FilesMatrix), 3)
  125. assert.Equal(t, len(cr.FilesMatrix[0]), 3)
  126. assert.Equal(t, cr.FilesMatrix[0][0], int64(3))
  127. assert.Equal(t, cr.FilesMatrix[0][1], int64(1))
  128. assert.Equal(t, cr.FilesMatrix[0][2], int64(1))
  129. assert.Equal(t, len(cr.FilesMatrix[1]), 3)
  130. assert.Equal(t, cr.FilesMatrix[1][0], int64(1))
  131. assert.Equal(t, cr.FilesMatrix[1][1], int64(2))
  132. assert.Equal(t, cr.FilesMatrix[1][2], int64(2))
  133. assert.Equal(t, len(cr.FilesMatrix[2]), 3)
  134. assert.Equal(t, cr.FilesMatrix[2][0], int64(1))
  135. assert.Equal(t, cr.FilesMatrix[2][1], int64(2))
  136. assert.Equal(t, cr.FilesMatrix[2][2], int64(2))
  137. }