123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- package hercules
- import (
- "github.com/stretchr/testify/assert"
- "gopkg.in/src-d/go-git.v4/plumbing"
- "gopkg.in/src-d/go-git.v4/plumbing/object"
- "testing"
- )
- func fixtureRenameAnalysis() *RenameAnalysis {
- ra := RenameAnalysis{SimilarityThreshold: 80}
- ra.Initialize(testRepository)
- return &ra
- }
- func TestRenameAnalysisMeta(t *testing.T) {
- ra := fixtureRenameAnalysis()
- assert.Equal(t, ra.Name(), "RenameAnalysis")
- assert.Equal(t, len(ra.Provides()), 1)
- assert.Equal(t, ra.Provides()[0], "changes")
- assert.Equal(t, len(ra.Requires()), 2)
- assert.Equal(t, ra.Requires()[0], "blob_cache")
- assert.Equal(t, ra.Requires()[1], "changes")
- opts := ra.ListConfigurationOptions()
- assert.Len(t, opts, 1)
- assert.Equal(t, opts[0].Name, ConfigRenameAnalysisSimilarityThreshold)
- ra.SimilarityThreshold = 0
- facts := map[string]interface{}{}
- facts[ConfigRenameAnalysisSimilarityThreshold] = 70
- ra.Configure(facts)
- assert.Equal(t, ra.SimilarityThreshold, 70)
- delete(facts, ConfigRenameAnalysisSimilarityThreshold)
- ra.Configure(facts)
- assert.Equal(t, ra.SimilarityThreshold, 70)
- }
- func TestRenameAnalysisRegistration(t *testing.T) {
- tp, exists := Registry.registered[(&RenameAnalysis{}).Name()]
- assert.True(t, exists)
- assert.Equal(t, tp.Elem().Name(), "RenameAnalysis")
- tps, exists := Registry.provided[(&RenameAnalysis{}).Provides()[0]]
- assert.True(t, exists)
- assert.True(t, len(tps) >= 1)
- matched := false
- for _, tp := range tps {
- matched = matched || tp.Elem().Name() == "RenameAnalysis"
- }
- assert.True(t, matched)
- }
- func TestRenameAnalysisInitializeInvalidThreshold(t *testing.T) {
- ra := RenameAnalysis{SimilarityThreshold: -10}
- ra.Initialize(testRepository)
- assert.Equal(t, ra.SimilarityThreshold, RENAME_ANALYSIS_DEFAULT_THRESHOLD)
- ra = RenameAnalysis{SimilarityThreshold: 110}
- ra.Initialize(testRepository)
- assert.Equal(t, ra.SimilarityThreshold, RENAME_ANALYSIS_DEFAULT_THRESHOLD)
- ra = RenameAnalysis{SimilarityThreshold: 0}
- ra.Initialize(testRepository)
- ra = RenameAnalysis{SimilarityThreshold: 100}
- ra.Initialize(testRepository)
- }
- func TestRenameAnalysisConsume(t *testing.T) {
- ra := fixtureRenameAnalysis()
- changes := make(object.Changes, 3)
- // 2b1ed978194a94edeabbca6de7ff3b5771d4d665
- treeFrom, _ := testRepository.TreeObject(plumbing.NewHash(
- "96c6ece9b2f3c7c51b83516400d278dea5605100"))
- treeTo, _ := testRepository.TreeObject(plumbing.NewHash(
- "251f2094d7b523d5bcc60e663b6cf38151bf8844"))
- changes[0] = &object.Change{From: object.ChangeEntry{
- Name: "analyser.go",
- Tree: treeFrom,
- TreeEntry: object.TreeEntry{
- Name: "analyser.go",
- Mode: 0100644,
- Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
- },
- }, To: object.ChangeEntry{},
- }
- changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
- Name: "burndown.go",
- Tree: treeTo,
- TreeEntry: object.TreeEntry{
- Name: "burndown.go",
- Mode: 0100644,
- Hash: plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2"),
- },
- },
- }
- changes[2] = &object.Change{From: object.ChangeEntry{
- Name: "cmd/hercules/main.go",
- Tree: treeFrom,
- TreeEntry: object.TreeEntry{
- Name: "cmd/hercules/main.go",
- Mode: 0100644,
- Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
- },
- }, To: object.ChangeEntry{
- Name: "cmd/hercules/main.go",
- Tree: treeTo,
- TreeEntry: object.TreeEntry{
- Name: "cmd/hercules/main.go",
- Mode: 0100644,
- Hash: plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72"),
- },
- },
- }
- cache := map[plumbing.Hash]*object.Blob{}
- hash := plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1")
- cache[hash], _ = testRepository.BlobObject(hash)
- hash = plumbing.NewHash("29c9fafd6a2fae8cd20298c3f60115bc31a4c0f2")
- cache[hash], _ = testRepository.BlobObject(hash)
- hash = plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9")
- cache[hash], _ = testRepository.BlobObject(hash)
- hash = plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72")
- cache[hash], _ = testRepository.BlobObject(hash)
- deps := map[string]interface{}{}
- deps["blob_cache"] = cache
- deps["changes"] = changes
- ra.SimilarityThreshold = 33
- res, err := ra.Consume(deps)
- assert.Nil(t, err)
- renamed := res["changes"].(object.Changes)
- assert.Equal(t, len(renamed), 2)
- ra.SimilarityThreshold = 35
- res, err = ra.Consume(deps)
- assert.Nil(t, err)
- renamed = res["changes"].(object.Changes)
- assert.Equal(t, len(renamed), 3)
- }
- func TestSortableChanges(t *testing.T) {
- changes := sortableChanges{
- sortableChange{
- nil, plumbing.NewHash("0000000000000000000000000000000000000000"),
- }, sortableChange{
- nil, plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
- },
- }
- assert.True(t, changes.Less(0, 1))
- assert.False(t, changes.Less(1, 0))
- assert.False(t, changes.Less(0, 0))
- changes.Swap(0, 1)
- assert.Equal(t, changes[0].hash.String(), "ffffffffffffffffffffffffffffffffffffffff")
- assert.Equal(t, changes[1].hash.String(), "0000000000000000000000000000000000000000")
- }
- func TestSortableBlobs(t *testing.T) {
- blobs := sortableBlobs{
- sortableBlob{
- nil, int64(0),
- }, sortableBlob{
- nil, int64(1),
- },
- }
- assert.True(t, blobs.Less(0, 1))
- assert.False(t, blobs.Less(1, 0))
- assert.False(t, blobs.Less(0, 0))
- blobs.Swap(0, 1)
- assert.Equal(t, blobs[0].size, int64(1))
- assert.Equal(t, blobs[1].size, int64(0))
- }
|