renames_test.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package hercules
  2. import (
  3. "github.com/stretchr/testify/assert"
  4. "gopkg.in/src-d/go-git.v4/plumbing"
  5. "gopkg.in/src-d/go-git.v4/plumbing/object"
  6. "testing"
  7. )
  8. func fixtureRenameAnalysis() *RenameAnalysis {
  9. ra := RenameAnalysis{SimilarityThreshold: 80}
  10. ra.Initialize(testRepository)
  11. return &ra
  12. }
  13. func TestRenameAnalysisMeta(t *testing.T) {
  14. ra := fixtureRenameAnalysis()
  15. assert.Equal(t, ra.Name(), "RenameAnalysis")
  16. assert.Equal(t, len(ra.Provides()), 1)
  17. assert.Equal(t, ra.Provides()[0], "changes")
  18. assert.Equal(t, len(ra.Requires()), 2)
  19. assert.Equal(t, ra.Requires()[0], "blob_cache")
  20. assert.Equal(t, ra.Requires()[1], "changes")
  21. }
  22. func TestRenameAnalysisInitializeInvalidThreshold(t *testing.T) {
  23. ra := RenameAnalysis{SimilarityThreshold: -10}
  24. assert.Panics(t, func() { ra.Initialize(testRepository) })
  25. ra = RenameAnalysis{SimilarityThreshold: 110}
  26. assert.Panics(t, func() { ra.Initialize(testRepository) })
  27. ra = RenameAnalysis{SimilarityThreshold: 0}
  28. ra.Initialize(testRepository)
  29. ra = RenameAnalysis{SimilarityThreshold: 100}
  30. ra.Initialize(testRepository)
  31. }
  32. func TestRenameAnalysisConsume(t *testing.T) {
  33. ra := fixtureRenameAnalysis()
  34. changes := make(object.Changes, 3)
  35. // 2b1ed978194a94edeabbca6de7ff3b5771d4d665
  36. treeFrom, _ := testRepository.TreeObject(plumbing.NewHash(
  37. "96c6ece9b2f3c7c51b83516400d278dea5605100"))
  38. treeTo, _ := testRepository.TreeObject(plumbing.NewHash(
  39. "251f2094d7b523d5bcc60e663b6cf38151bf8844"))
  40. changes[0] = &object.Change{From: object.ChangeEntry{
  41. Name: "analyser.go",
  42. Tree: treeFrom,
  43. TreeEntry: object.TreeEntry{
  44. Name: "analyser.go",
  45. Mode: 0100644,
  46. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  47. },
  48. }, To: object.ChangeEntry{},
  49. }
  50. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  51. Name: "burndown.go",
  52. Tree: treeTo,
  53. TreeEntry: object.TreeEntry{
  54. Name: "burndown.go",
  55. Mode: 0100644,
  56. Hash: plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2"),
  57. },
  58. },
  59. }
  60. changes[2] = &object.Change{From: object.ChangeEntry{
  61. Name: "cmd/hercules/main.go",
  62. Tree: treeFrom,
  63. TreeEntry: object.TreeEntry{
  64. Name: "cmd/hercules/main.go",
  65. Mode: 0100644,
  66. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  67. },
  68. }, To: object.ChangeEntry{
  69. Name: "cmd/hercules/main.go",
  70. Tree: treeTo,
  71. TreeEntry: object.TreeEntry{
  72. Name: "cmd/hercules/main.go",
  73. Mode: 0100644,
  74. Hash: plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72"),
  75. },
  76. },
  77. }
  78. cache := map[plumbing.Hash]*object.Blob{}
  79. hash := plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1")
  80. cache[hash], _ = testRepository.BlobObject(hash)
  81. hash = plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2")
  82. cache[hash], _ = testRepository.BlobObject(hash)
  83. hash = plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9")
  84. cache[hash], _ = testRepository.BlobObject(hash)
  85. hash = plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72")
  86. cache[hash], _ = testRepository.BlobObject(hash)
  87. deps := map[string]interface{}{}
  88. deps["blob_cache"] = cache
  89. deps["changes"] = changes
  90. ra.SimilarityThreshold = 33
  91. res, err := ra.Consume(deps)
  92. assert.Nil(t, err)
  93. renamed := res["changes"].(object.Changes)
  94. assert.Equal(t, len(renamed), 2)
  95. ra.SimilarityThreshold = 35
  96. res, err = ra.Consume(deps)
  97. assert.Nil(t, err)
  98. renamed = res["changes"].(object.Changes)
  99. assert.Equal(t, len(renamed), 3)
  100. }
  101. func TestSortableChanges(t *testing.T) {
  102. changes := sortableChanges{
  103. sortableChange{
  104. nil, plumbing.NewHash("0000000000000000000000000000000000000000"),
  105. }, sortableChange{
  106. nil, plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
  107. },
  108. }
  109. assert.True(t, changes.Less(0, 1))
  110. assert.False(t, changes.Less(1, 0))
  111. assert.False(t, changes.Less(0, 0))
  112. changes.Swap(0, 1)
  113. assert.Equal(t, changes[0].hash.String(), "ffffffffffffffffffffffffffffffffffffffff")
  114. assert.Equal(t, changes[1].hash.String(), "0000000000000000000000000000000000000000")
  115. }
  116. func TestSortableBlobs(t *testing.T) {
  117. blobs := sortableBlobs{
  118. sortableBlob{
  119. nil, int64(0),
  120. }, sortableBlob{
  121. nil, int64(1),
  122. },
  123. }
  124. assert.True(t, blobs.Less(0, 1))
  125. assert.False(t, blobs.Less(1, 0))
  126. assert.False(t, blobs.Less(0, 0))
  127. blobs.Swap(0, 1)
  128. assert.Equal(t, blobs[0].size, int64(1))
  129. assert.Equal(t, blobs[1].size, int64(0))
  130. }