| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 | 
							- // +build !disable_babelfish
 
- package research
 
- import (
 
- 	"bytes"
 
- 	"testing"
 
- 	"github.com/gogo/protobuf/proto"
 
- 	"github.com/stretchr/testify/assert"
 
- 	"gopkg.in/bblfsh/client-go.v3/tools"
 
- 	"gopkg.in/bblfsh/sdk.v2/uast"
 
- 	"gopkg.in/bblfsh/sdk.v2/uast/nodes"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing/object"
 
- 	"gopkg.in/src-d/hercules.v10/internal/core"
 
- 	"gopkg.in/src-d/hercules.v10/internal/pb"
 
- 	items "gopkg.in/src-d/hercules.v10/internal/plumbing"
 
- 	uast_items "gopkg.in/src-d/hercules.v10/internal/plumbing/uast"
 
- 	"gopkg.in/src-d/hercules.v10/internal/test"
 
- )
 
- func TestTyposDatasetMeta(t *testing.T) {
 
- 	tdb := TyposDatasetBuilder{}
 
- 	assert.Equal(t, tdb.Name(), "TyposDataset")
 
- 	assert.Len(t, tdb.Provides(), 0)
 
- 	required := [...]string{
 
- 		uast_items.DependencyUastChanges, items.DependencyFileDiff, items.DependencyBlobCache}
 
- 	for _, name := range required {
 
- 		assert.Contains(t, tdb.Requires(), name)
 
- 	}
 
- 	opts := tdb.ListConfigurationOptions()
 
- 	assert.Len(t, opts, 1)
 
- 	assert.Equal(t, opts[0].Name, ConfigTyposDatasetMaximumAllowedDistance)
 
- 	assert.Equal(t, opts[0].Type, core.IntConfigurationOption)
 
- 	assert.Equal(t, tdb.Flag(), "typos-dataset")
 
- }
 
- func TestTyposDatasetRegistration(t *testing.T) {
 
- 	summoned := core.Registry.Summon((&TyposDatasetBuilder{}).Name())
 
- 	assert.Len(t, summoned, 1)
 
- 	assert.Equal(t, summoned[0].Name(), "TyposDataset")
 
- 	leaves := core.Registry.GetLeaves()
 
- 	matched := false
 
- 	for _, tp := range leaves {
 
- 		if tp.Flag() == (&TyposDatasetBuilder{}).Flag() {
 
- 			matched = true
 
- 			break
 
- 		}
 
- 	}
 
- 	assert.True(t, matched)
 
- }
 
- func TestTyposDatasetConfigure(t *testing.T) {
 
- 	tdb := TyposDatasetBuilder{}
 
- 	facts := map[string]interface{}{}
 
- 	facts[ConfigTyposDatasetMaximumAllowedDistance] = 5
 
- 	assert.Nil(t, tdb.Configure(facts))
 
- 	assert.Equal(t, tdb.MaximumAllowedDistance, 5)
 
- 	facts = map[string]interface{}{}
 
- 	assert.Nil(t, tdb.Configure(facts))
 
- 	assert.Equal(t, tdb.MaximumAllowedDistance, 5)
 
- }
 
- func AddHash(t *testing.T, cache map[plumbing.Hash]*items.CachedBlob, hash string) {
 
- 	objhash := plumbing.NewHash(hash)
 
- 	blob, err := test.Repository.BlobObject(objhash)
 
- 	assert.Nil(t, err)
 
- 	cb := &items.CachedBlob{Blob: *blob}
 
- 	err = cb.Cache()
 
- 	assert.Nil(t, err)
 
- 	cache[objhash] = cb
 
- }
 
- func bakeTyposDeps(t *testing.T) map[string]interface{} {
 
- 	deps := map[string]interface{}{}
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	AddHash(t, cache, "b9a12fd144274c99c7c9a0a32a0268f8b36d2f2c")
 
- 	AddHash(t, cache, "d5f8e61069136f3578457a3131800ede353527b8")
 
- 	AddHash(t, cache, "75bb0a09fc01db55d7322f0fae523453edba7846")
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	changes := make(object.Changes, 2)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"eac25f9126db00e38fa72a59d49773a84580d4ce"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"828467b465864b1f757dcec9a034be49030fc8b9"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "file_test.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "file_test.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("75bb0a09fc01db55d7322f0fae523453edba7846"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "file_test.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "file_test.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("75bb0a09fc01db55d7322f0fae523453edba7846"),
 
- 		},
 
- 	}}
 
- 	changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
 
- 		Name: "blob_cache_test.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "blob_cache_test.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("b9a12fd144274c99c7c9a0a32a0268f8b36d2f2c"),
 
- 		},
 
- 	},
 
- 	}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	deps[core.DependencyCommit], _ = test.Repository.CommitObject(plumbing.NewHash(
 
- 		"84165d3b02647fae12cc026c7a580045246e8c98"))
 
- 	deps[core.DependencyIsMerge] = false
 
- 	uastItem := &uast_items.Extractor{}
 
- 	assert.Nil(t, uastItem.Initialize(test.Repository))
 
- 	uastResult, err := uastItem.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[uast_items.DependencyUasts] = uastResult[uast_items.DependencyUasts]
 
- 	uastChanges := &uast_items.Changes{}
 
- 	assert.Nil(t, uastChanges.Initialize(test.Repository))
 
- 	_, err = uastChanges.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	changes[0].To.TreeEntry.Hash = plumbing.NewHash("d5f8e61069136f3578457a3131800ede353527b8")
 
- 	uastResult, err = uastItem.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[uast_items.DependencyUasts] = uastResult[uast_items.DependencyUasts]
 
- 	changesResult, err := uastChanges.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[uast_items.DependencyUastChanges] = changesResult[uast_items.DependencyUastChanges]
 
- 	fd := &items.FileDiff{}
 
- 	assert.Nil(t, fd.Initialize(test.Repository))
 
- 	diffResult, err := fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	deps[items.DependencyFileDiff] = diffResult[items.DependencyFileDiff]
 
- 	return deps
 
- }
 
- func TestTyposDatasetConsume(t *testing.T) {
 
- 	deps := bakeTyposDeps(t)
 
- 	tbd := &TyposDatasetBuilder{}
 
- 	assert.Nil(t, tbd.Initialize(test.Repository))
 
- 	res, err := tbd.Consume(deps)
 
- 	assert.Nil(t, res)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, tbd.typos, 26)
 
- 	assert.Equal(t, tbd.typos[0].Wrong, "TestInitialize")
 
- 	assert.Equal(t, tbd.typos[0].Correct, "TestInitializeFile")
 
- 	assert.Equal(t, tbd.typos[0].Commit, plumbing.NewHash(
 
- 		"84165d3b02647fae12cc026c7a580045246e8c98"))
 
- 	assert.Equal(t, tbd.typos[0].File, "file_test.go")
 
- 	assert.Equal(t, tbd.typos[0].Line, 19)
 
- 	deps[core.DependencyIsMerge] = true
 
- 	res, err = tbd.Consume(deps)
 
- 	assert.Nil(t, res)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, tbd.typos, 26)
 
- }
 
- func dropPositions(root nodes.Node, target string) {
 
- 	for element := range tools.Iterate(tools.NewIterator(root, tools.PreOrder)) {
 
- 		obj, isobj := element.(nodes.Object)
 
- 		if !isobj {
 
- 			continue
 
- 		}
 
- 		nameval, exists := obj["Name"]
 
- 		if !exists {
 
- 			continue
 
- 		}
 
- 		if name, isstr := nameval.(nodes.String); !isstr || string(name) != target {
 
- 			continue
 
- 		}
 
- 		posval, exists := obj[uast.KeyPos]
 
- 		if !exists {
 
- 			continue
 
- 		}
 
- 		posobj, isobj := posval.(nodes.Object)
 
- 		if !isobj {
 
- 			continue
 
- 		}
 
- 		for k, v := range posobj {
 
- 			po, _ := v.(nodes.Object)
 
- 			if uast.AsPosition(po) != nil {
 
- 				posobj[k] = nil
 
- 			}
 
- 		}
 
- 	}
 
- }
 
- func TestTyposDatasetConsumeMissingPosition(t *testing.T) {
 
- 	deps := bakeTyposDeps(t)
 
- 	uastChanges := deps[uast_items.DependencyUastChanges].([]uast_items.Change)
 
- 	dropPositions(uastChanges[0].Before, "TestZeroInitialize")
 
- 	dropPositions(uastChanges[0].After, "TestZeroInitializeFile")
 
- 	tbd := &TyposDatasetBuilder{}
 
- 	assert.Nil(t, tbd.Initialize(test.Repository))
 
- 	res, err := tbd.Consume(deps)
 
- 	assert.Nil(t, res)
 
- 	assert.Nil(t, err)
 
- 	assert.Len(t, tbd.typos, 25)
 
- }
 
- func fixtureTyposDataset() *TyposDatasetBuilder {
 
- 	tdb := TyposDatasetBuilder{}
 
- 	tdb.Initialize(test.Repository)
 
- 	tdb.typos = append(tdb.typos, Typo{
 
- 		Wrong:   "Fo",
 
- 		Correct: "Foo",
 
- 		Commit:  plumbing.ZeroHash,
 
- 		File:    "bar.go",
 
- 		Line:    7,
 
- 	})
 
- 	return &tdb
 
- }
 
- func TestTyposDatasetFinalize(t *testing.T) {
 
- 	tdb := fixtureTyposDataset()
 
- 	tdb.typos = append(tdb.typos, tdb.typos[0])
 
- 	x := tdb.Finalize().(TyposResult)
 
- 	assert.Len(t, x.Typos, 1)
 
- 	assert.Equal(t, x.Typos[0], Typo{
 
- 		Wrong:   "Fo",
 
- 		Correct: "Foo",
 
- 		Commit:  plumbing.ZeroHash,
 
- 		File:    "bar.go",
 
- 		Line:    7,
 
- 	})
 
- }
 
- func TestTyposDatasetSerialize(t *testing.T) {
 
- 	ca := fixtureTyposDataset()
 
- 	res := ca.Finalize().(TyposResult)
 
- 	buffer := &bytes.Buffer{}
 
- 	err := ca.Serialize(res, false, buffer)
 
- 	assert.Nil(t, err)
 
- 	assert.Equal(t, `  - wrong: "Fo"
 
-     correct: "Foo"
 
-     commit: 0000000000000000000000000000000000000000
 
-     file: "bar.go"
 
-     line: 7
 
- `, buffer.String())
 
- 	buffer = &bytes.Buffer{}
 
- 	err = ca.Serialize(res, true, buffer)
 
- 	assert.Nil(t, err)
 
- 	msg := pb.TyposDataset{}
 
- 	assert.Nil(t, proto.Unmarshal(buffer.Bytes(), &msg))
 
- 	assert.Len(t, msg.Typos, 1)
 
- 	assert.Equal(t, *msg.Typos[0], pb.Typo{
 
- 		Wrong:   "Fo",
 
- 		Correct: "Foo",
 
- 		Commit:  "0000000000000000000000000000000000000000",
 
- 		File:    "bar.go",
 
- 		Line:    7,
 
- 	})
 
- }
 
 
  |