renames_test.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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 TestRenameAnalysisFinalize(t *testing.T) {
  33. ra := fixtureRenameAnalysis()
  34. r := ra.Finalize()
  35. assert.Nil(t, r)
  36. }
  37. func TestRenameAnalysisConsume(t *testing.T) {
  38. ra := fixtureRenameAnalysis()
  39. changes := make(object.Changes, 3)
  40. // 2b1ed978194a94edeabbca6de7ff3b5771d4d665
  41. treeFrom, _ := testRepository.TreeObject(plumbing.NewHash(
  42. "96c6ece9b2f3c7c51b83516400d278dea5605100"))
  43. treeTo, _ := testRepository.TreeObject(plumbing.NewHash(
  44. "251f2094d7b523d5bcc60e663b6cf38151bf8844"))
  45. changes[0] = &object.Change{From: object.ChangeEntry{
  46. Name: "analyser.go",
  47. Tree: treeFrom,
  48. TreeEntry: object.TreeEntry{
  49. Name: "analyser.go",
  50. Mode: 0100644,
  51. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  52. },
  53. }, To: object.ChangeEntry{},
  54. }
  55. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  56. Name: "burndown.go",
  57. Tree: treeTo,
  58. TreeEntry: object.TreeEntry{
  59. Name: "burndown.go",
  60. Mode: 0100644,
  61. Hash: plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2"),
  62. },
  63. },
  64. }
  65. changes[2] = &object.Change{From: object.ChangeEntry{
  66. Name: "cmd/hercules/main.go",
  67. Tree: treeFrom,
  68. TreeEntry: object.TreeEntry{
  69. Name: "cmd/hercules/main.go",
  70. Mode: 0100644,
  71. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  72. },
  73. }, To: object.ChangeEntry{
  74. Name: "cmd/hercules/main.go",
  75. Tree: treeTo,
  76. TreeEntry: object.TreeEntry{
  77. Name: "cmd/hercules/main.go",
  78. Mode: 0100644,
  79. Hash: plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72"),
  80. },
  81. },
  82. }
  83. cache := map[plumbing.Hash]*object.Blob{}
  84. hash := plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1")
  85. cache[hash], _ = testRepository.BlobObject(hash)
  86. hash = plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2")
  87. cache[hash], _ = testRepository.BlobObject(hash)
  88. hash = plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9")
  89. cache[hash], _ = testRepository.BlobObject(hash)
  90. hash = plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72")
  91. cache[hash], _ = testRepository.BlobObject(hash)
  92. deps := map[string]interface{}{}
  93. deps["blob_cache"] = cache
  94. deps["changes"] = changes
  95. ra.SimilarityThreshold = 33
  96. res, err := ra.Consume(deps)
  97. assert.Nil(t, err)
  98. renamed := res["changes"].(object.Changes)
  99. assert.Equal(t, len(renamed), 2)
  100. ra.SimilarityThreshold = 35
  101. res, err = ra.Consume(deps)
  102. assert.Nil(t, err)
  103. renamed = res["changes"].(object.Changes)
  104. assert.Equal(t, len(renamed), 3)
  105. }
  106. func TestSortableChanges(t *testing.T) {
  107. changes := sortableChanges{
  108. sortableChange{
  109. nil, plumbing.NewHash("0000000000000000000000000000000000000000"),
  110. }, sortableChange{
  111. nil, plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
  112. },
  113. }
  114. assert.True(t, changes.Less(0, 1))
  115. assert.False(t, changes.Less(1, 0))
  116. assert.False(t, changes.Less(0, 0))
  117. changes.Swap(0, 1)
  118. assert.Equal(t, changes[0].hash.String(), "ffffffffffffffffffffffffffffffffffffffff")
  119. assert.Equal(t, changes[1].hash.String(), "0000000000000000000000000000000000000000")
  120. }
  121. func TestSortableBlobs(t *testing.T) {
  122. blobs := sortableBlobs{
  123. sortableBlob{
  124. nil, int64(0),
  125. }, sortableBlob{
  126. nil, int64(1),
  127. },
  128. }
  129. assert.True(t, blobs.Less(0, 1))
  130. assert.False(t, blobs.Less(1, 0))
  131. assert.False(t, blobs.Less(0, 0))
  132. blobs.Swap(0, 1)
  133. assert.Equal(t, blobs[0].size, int64(1))
  134. assert.Equal(t, blobs[1].size, int64(0))
  135. }