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)) }