renames_test.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package plumbing
  2. import (
  3. "testing"
  4. "github.com/stretchr/testify/assert"
  5. "gopkg.in/src-d/go-git.v4/plumbing"
  6. "gopkg.in/src-d/go-git.v4/plumbing/object"
  7. "gopkg.in/src-d/hercules.v6/internal/core"
  8. "gopkg.in/src-d/hercules.v6/internal/test"
  9. )
  10. func fixtureRenameAnalysis() *RenameAnalysis {
  11. ra := RenameAnalysis{SimilarityThreshold: 80}
  12. ra.Initialize(test.Repository)
  13. return &ra
  14. }
  15. func TestRenameAnalysisMeta(t *testing.T) {
  16. ra := fixtureRenameAnalysis()
  17. assert.Equal(t, ra.Name(), "RenameAnalysis")
  18. assert.Equal(t, len(ra.Provides()), 1)
  19. assert.Equal(t, ra.Provides()[0], DependencyTreeChanges)
  20. assert.Equal(t, len(ra.Requires()), 2)
  21. assert.Equal(t, ra.Requires()[0], DependencyBlobCache)
  22. assert.Equal(t, ra.Requires()[1], DependencyTreeChanges)
  23. opts := ra.ListConfigurationOptions()
  24. assert.Len(t, opts, 1)
  25. assert.Equal(t, opts[0].Name, ConfigRenameAnalysisSimilarityThreshold)
  26. ra.SimilarityThreshold = 0
  27. facts := map[string]interface{}{}
  28. facts[ConfigRenameAnalysisSimilarityThreshold] = 70
  29. ra.Configure(facts)
  30. assert.Equal(t, ra.SimilarityThreshold, 70)
  31. delete(facts, ConfigRenameAnalysisSimilarityThreshold)
  32. ra.Configure(facts)
  33. assert.Equal(t, ra.SimilarityThreshold, 70)
  34. }
  35. func TestRenameAnalysisRegistration(t *testing.T) {
  36. summoned := core.Registry.Summon((&RenameAnalysis{}).Name())
  37. assert.Len(t, summoned, 1)
  38. assert.Equal(t, summoned[0].Name(), "RenameAnalysis")
  39. summoned = core.Registry.Summon((&RenameAnalysis{}).Provides()[0])
  40. assert.True(t, len(summoned) >= 1)
  41. matched := false
  42. for _, tp := range summoned {
  43. matched = matched || tp.Name() == "RenameAnalysis"
  44. }
  45. assert.True(t, matched)
  46. }
  47. func TestRenameAnalysisInitializeInvalidThreshold(t *testing.T) {
  48. ra := RenameAnalysis{SimilarityThreshold: -10}
  49. ra.Initialize(test.Repository)
  50. assert.Equal(t, ra.SimilarityThreshold, RenameAnalysisDefaultThreshold)
  51. ra = RenameAnalysis{SimilarityThreshold: 110}
  52. ra.Initialize(test.Repository)
  53. assert.Equal(t, ra.SimilarityThreshold, RenameAnalysisDefaultThreshold)
  54. ra = RenameAnalysis{SimilarityThreshold: 0}
  55. ra.Initialize(test.Repository)
  56. ra = RenameAnalysis{SimilarityThreshold: 100}
  57. ra.Initialize(test.Repository)
  58. }
  59. func TestRenameAnalysisConsume(t *testing.T) {
  60. ra := fixtureRenameAnalysis()
  61. changes := make(object.Changes, 3)
  62. // 2b1ed978194a94edeabbca6de7ff3b5771d4d665
  63. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  64. "96c6ece9b2f3c7c51b83516400d278dea5605100"))
  65. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  66. "251f2094d7b523d5bcc60e663b6cf38151bf8844"))
  67. changes[0] = &object.Change{From: object.ChangeEntry{
  68. Name: "analyser.go",
  69. Tree: treeFrom,
  70. TreeEntry: object.TreeEntry{
  71. Name: "analyser.go",
  72. Mode: 0100644,
  73. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  74. },
  75. }, To: object.ChangeEntry{},
  76. }
  77. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  78. Name: "burndown.go",
  79. Tree: treeTo,
  80. TreeEntry: object.TreeEntry{
  81. Name: "burndown.go",
  82. Mode: 0100644,
  83. Hash: plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2"),
  84. },
  85. },
  86. }
  87. changes[2] = &object.Change{From: object.ChangeEntry{
  88. Name: "cmd/hercules/main.go",
  89. Tree: treeFrom,
  90. TreeEntry: object.TreeEntry{
  91. Name: "cmd/hercules/main.go",
  92. Mode: 0100644,
  93. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  94. },
  95. }, To: object.ChangeEntry{
  96. Name: "cmd/hercules/main.go",
  97. Tree: treeTo,
  98. TreeEntry: object.TreeEntry{
  99. Name: "cmd/hercules/main.go",
  100. Mode: 0100644,
  101. Hash: plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72"),
  102. },
  103. },
  104. }
  105. cache := map[plumbing.Hash]*CachedBlob{}
  106. AddHash(t, cache, "baa64828831d174f40140e4b3cfa77d1e917a2c1")
  107. AddHash(t, cache, "29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2")
  108. AddHash(t, cache, "c29112dbd697ad9b401333b80c18a63951bc18d9")
  109. AddHash(t, cache, "f7d918ec500e2f925ecde79b51cc007bac27de72")
  110. deps := map[string]interface{}{}
  111. deps[DependencyBlobCache] = cache
  112. deps[DependencyTreeChanges] = changes
  113. ra.SimilarityThreshold = 37
  114. res, err := ra.Consume(deps)
  115. assert.Nil(t, err)
  116. renamed := res[DependencyTreeChanges].(object.Changes)
  117. assert.Equal(t, len(renamed), 2)
  118. ra.SimilarityThreshold = 39
  119. res, err = ra.Consume(deps)
  120. assert.Nil(t, err)
  121. renamed = res[DependencyTreeChanges].(object.Changes)
  122. assert.Equal(t, len(renamed), 3)
  123. }
  124. func TestSortableChanges(t *testing.T) {
  125. changes := sortableChanges{
  126. sortableChange{
  127. nil, plumbing.NewHash("0000000000000000000000000000000000000000"),
  128. }, sortableChange{
  129. nil, plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
  130. },
  131. }
  132. assert.True(t, changes.Less(0, 1))
  133. assert.False(t, changes.Less(1, 0))
  134. assert.False(t, changes.Less(0, 0))
  135. changes.Swap(0, 1)
  136. assert.Equal(t, changes[0].hash.String(), "ffffffffffffffffffffffffffffffffffffffff")
  137. assert.Equal(t, changes[1].hash.String(), "0000000000000000000000000000000000000000")
  138. }
  139. func TestSortableBlobs(t *testing.T) {
  140. blobs := sortableBlobs{
  141. sortableBlob{
  142. nil, int64(0),
  143. }, sortableBlob{
  144. nil, int64(1),
  145. },
  146. }
  147. assert.True(t, blobs.Less(0, 1))
  148. assert.False(t, blobs.Less(1, 0))
  149. assert.False(t, blobs.Less(0, 0))
  150. blobs.Swap(0, 1)
  151. assert.Equal(t, blobs[0].size, int64(1))
  152. assert.Equal(t, blobs[1].size, int64(0))
  153. }
  154. func TestRenameAnalysisFork(t *testing.T) {
  155. ra1 := fixtureRenameAnalysis()
  156. clones := ra1.Fork(1)
  157. assert.Len(t, clones, 1)
  158. ra2 := clones[0].(*RenameAnalysis)
  159. assert.True(t, ra1 == ra2)
  160. ra1.Merge([]core.PipelineItem{ra2})
  161. }
  162. func TestRenameAnalysisSizesAreClose(t *testing.T) {
  163. ra := fixtureRenameAnalysis()
  164. assert.True(t, ra.sizesAreClose(941, 963))
  165. assert.True(t, ra.sizesAreClose(941, 1150))
  166. assert.True(t, ra.sizesAreClose(941, 803))
  167. assert.False(t, ra.sizesAreClose(1320, 1668))
  168. }
  169. func TestRenameAnalysisSortRenameCandidates(t *testing.T) {
  170. candidates := []int{0, 1, 2, 3}
  171. sortRenameCandidates(candidates, "test_regression.py", func(i int) string {
  172. return []string{"gather_nd_op.h", "test.py", "test_file_system.cc", "regression.py"}[i]
  173. })
  174. assert.Equal(t, candidates[0], 3)
  175. assert.Equal(t, candidates[1], 1)
  176. }