| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328 | 
							- package plumbing_test
 
- import (
 
- 	"testing"
 
- 	"unicode/utf8"
 
- 	"github.com/sergi/go-diff/diffmatchpatch"
 
- 	"github.com/stretchr/testify/assert"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing"
 
- 	"gopkg.in/src-d/go-git.v4/plumbing/object"
 
- 	"gopkg.in/src-d/hercules.v6"
 
- 	"gopkg.in/src-d/hercules.v6/internal"
 
- 	"gopkg.in/src-d/hercules.v6/internal/core"
 
- 	items "gopkg.in/src-d/hercules.v6/internal/plumbing"
 
- 	"gopkg.in/src-d/hercules.v6/internal/test"
 
- 	"gopkg.in/src-d/hercules.v6/internal/test/fixtures"
 
- )
 
- func TestFileDiffMeta(t *testing.T) {
 
- 	fd := fixtures.FileDiff()
 
- 	assert.Equal(t, fd.Name(), "FileDiff")
 
- 	assert.Equal(t, len(fd.Provides()), 1)
 
- 	assert.Equal(t, fd.Provides()[0], items.DependencyFileDiff)
 
- 	assert.Equal(t, len(fd.Requires()), 2)
 
- 	assert.Equal(t, fd.Requires()[0], items.DependencyTreeChanges)
 
- 	assert.Equal(t, fd.Requires()[1], items.DependencyBlobCache)
 
- 	assert.Len(t, fd.ListConfigurationOptions(), 2)
 
- 	assert.Equal(t, fd.ListConfigurationOptions()[0].Name, items.ConfigFileDiffDisableCleanup)
 
- 	assert.Equal(t, fd.ListConfigurationOptions()[1].Name, items.ConfigFileWhitespaceIgnore)
 
- 	facts := map[string]interface{}{}
 
- 	facts[items.ConfigFileDiffDisableCleanup] = true
 
- 	facts[items.ConfigFileWhitespaceIgnore] = true
 
- 	fd.Configure(facts)
 
- 	assert.True(t, fd.CleanupDisabled)
 
- 	assert.True(t, fd.WhitespaceIgnore)
 
- }
 
- func TestFileDiffRegistration(t *testing.T) {
 
- 	summoned := core.Registry.Summon((&items.FileDiff{}).Name())
 
- 	assert.Len(t, summoned, 1)
 
- 	assert.Equal(t, summoned[0].Name(), "FileDiff")
 
- 	summoned = core.Registry.Summon((&items.FileDiff{}).Provides()[0])
 
- 	assert.True(t, len(summoned) >= 1)
 
- 	matched := false
 
- 	for _, tp := range summoned {
 
- 		matched = matched || tp.Name() == "FileDiff"
 
- 	}
 
- 	assert.True(t, matched)
 
- }
 
- func TestFileDiffConsume(t *testing.T) {
 
- 	fd := fixtures.FileDiff()
 
- 	deps := map[string]interface{}{}
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	items.AddHash(t, cache, "291286b4ac41952cbd1389fda66420ec03c1a9fe")
 
- 	items.AddHash(t, cache, "334cde09da4afcb74f8d2b3e6fd6cce61228b485")
 
- 	items.AddHash(t, cache, "dc248ba2b22048cc730c571a748e8ffcf7085ab9")
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	changes := make(object.Changes, 3)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"994eac1cd07235bb9815e547a75c84265dea00f5"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("334cde09da4afcb74f8d2b3e6fd6cce61228b485"),
 
- 		},
 
- 	}}
 
- 	changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
 
- 		Name: ".travis.yml",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: ".travis.yml",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"),
 
- 		},
 
- 	},
 
- 	}
 
- 	changes[2] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "rbtree.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "rbtree.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("14c3fa5a1cca103032f10379467a3a2f210e5f94"),
 
- 		},
 
- 	}, To: object.ChangeEntry{},
 
- 	}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	res, err := fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	diffs := res[items.DependencyFileDiff].(map[string]items.FileDiffData)
 
- 	assert.Equal(t, len(diffs), 1)
 
- 	diff := diffs["analyser.go"]
 
- 	assert.Equal(t, diff.OldLinesOfCode, 307)
 
- 	assert.Equal(t, diff.NewLinesOfCode, 309)
 
- 	deletions := 0
 
- 	insertions := 0
 
- 	for _, edit := range diff.Diffs {
 
- 		switch edit.Type {
 
- 		case diffmatchpatch.DiffEqual:
 
- 			continue
 
- 		case diffmatchpatch.DiffInsert:
 
- 			insertions += utf8.RuneCountInString(edit.Text)
 
- 		case diffmatchpatch.DiffDelete:
 
- 			deletions += utf8.RuneCountInString(edit.Text)
 
- 		}
 
- 	}
 
- 	assert.Equal(t, deletions, 13)
 
- 	assert.Equal(t, insertions, 15)
 
- }
 
- func TestFileDiffConsumeInvalidBlob(t *testing.T) {
 
- 	fd := fixtures.FileDiff()
 
- 	deps := map[string]interface{}{}
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	items.AddHash(t, cache, "291286b4ac41952cbd1389fda66420ec03c1a9fe")
 
- 	items.AddHash(t, cache, "334cde09da4afcb74f8d2b3e6fd6cce61228b485")
 
- 	items.AddHash(t, cache, "dc248ba2b22048cc730c571a748e8ffcf7085ab9")
 
- 	cache[plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff")] = &items.CachedBlob{}
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	changes := make(object.Changes, 1)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"994eac1cd07235bb9815e547a75c84265dea00f5"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("334cde09da4afcb74f8d2b3e6fd6cce61228b485"),
 
- 		},
 
- 	}}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	res, err := fd.Consume(deps)
 
- 	assert.Len(t, res[hercules.DependencyFileDiff].(map[string]items.FileDiffData), 1)
 
- 	assert.Nil(t, err)
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "analyser.go",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "analyser.go",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("ffffffffffffffffffffffffffffffffffffffff"),
 
- 		},
 
- 	}}
 
- 	res, err = fd.Consume(deps)
 
- 	assert.Len(t, res[hercules.DependencyFileDiff].(map[string]items.FileDiffData), 1)
 
- 	assert.Nil(t, err)
 
- }
 
- func TestCountLines(t *testing.T) {
 
- 	blob, err := test.Repository.BlobObject(
 
- 		plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"))
 
- 	assert.Nil(t, err)
 
- 	cb := &items.CachedBlob{Blob: *blob}
 
- 	cb.Cache()
 
- 	lines, err := cb.CountLines()
 
- 	assert.Equal(t, lines, 12)
 
- 	assert.Nil(t, err)
 
- 	blob, err = internal.CreateDummyBlob(
 
- 		plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"), true)
 
- 	assert.Nil(t, err)
 
- 	cb = &items.CachedBlob{Blob: *blob}
 
- 	err = cb.Cache()
 
- 	assert.Equal(t, err.Error(), "dummy failure")
 
- 	// test_data/blob
 
- 	blob, err = test.Repository.BlobObject(
 
- 		plumbing.NewHash("c86626638e0bc8cf47ca49bb1525b40e9737ee64"))
 
- 	assert.Nil(t, err)
 
- 	cb = &items.CachedBlob{Blob: *blob}
 
- 	cb.Cache()
 
- 	lines, err = cb.CountLines()
 
- 	assert.Equal(t, lines, 0)
 
- 	assert.NotNil(t, err)
 
- 	assert.Equal(t, err.Error(), items.ErrorBinary.Error())
 
- }
 
- func TestBlobToString(t *testing.T) {
 
- 	blob, _ := test.Repository.BlobObject(
 
- 		plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"))
 
- 	cb := &items.CachedBlob{Blob: *blob}
 
- 	err := cb.Cache()
 
- 	assert.Nil(t, err)
 
- 	str := string(cb.Data)
 
- 	assert.Equal(t, str, `language: go
 
- go:
 
-   - 1.7
 
- go_import_path: gopkg.in/src-d/hercules.v1
 
- `+"  "+`
 
- script:
 
-   - go test -v -cpu=1,2 ./...
 
- notifications:
 
-   email: false
 
- `)
 
- 	blob, _ = internal.CreateDummyBlob(
 
- 		plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"), true)
 
- 	cb = &items.CachedBlob{Blob: *blob}
 
- 	err = cb.Cache()
 
- 	assert.NotNil(t, err)
 
- }
 
- func TestFileDiffDarkMagic(t *testing.T) {
 
- 	fd := fixtures.FileDiff()
 
- 	deps := map[string]interface{}{}
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	items.AddHash(t, cache, "448eb3f312849b0ca766063d06b09481c987b309") // 1.java
 
- 	items.AddHash(t, cache, "3312c92f3e8bdfbbdb30bccb6acd1b85bc338dfc") // 2.java
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	changes := make(object.Changes, 1)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"f02289bfe843388a1bb3c7dea210374082dd86b9"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"eca91acf1fd828f20dcb653a061d8c97d965bc6c"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "test.java",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "test.java",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("448eb3f312849b0ca766063d06b09481c987b309"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "test.java",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "test.java",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("3312c92f3e8bdfbbdb30bccb6acd1b85bc338dfc"),
 
- 		},
 
- 	}}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	res, err := fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	magicDiffs := res[items.DependencyFileDiff].(map[string]items.FileDiffData)["test.java"]
 
- 	fd.CleanupDisabled = true
 
- 	res, err = fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	plainDiffs := res[items.DependencyFileDiff].(map[string]items.FileDiffData)["test.java"]
 
- 	assert.NotEqual(t, magicDiffs.Diffs, plainDiffs.Diffs)
 
- 	assert.Equal(t, magicDiffs.OldLinesOfCode, plainDiffs.OldLinesOfCode)
 
- 	assert.Equal(t, magicDiffs.NewLinesOfCode, plainDiffs.NewLinesOfCode)
 
- }
 
- func TestFileDiffWhitespaceDarkMagic(t *testing.T) {
 
- 	fd := fixtures.FileDiff()
 
- 	deps := map[string]interface{}{}
 
- 	cache := map[plumbing.Hash]*items.CachedBlob{}
 
- 	items.AddHash(t, cache, "448eb3f312849b0ca766063d06b09481c987b309") // 1.java
 
- 	items.AddHash(t, cache, "3312c92f3e8bdfbbdb30bccb6acd1b85bc338dfc") // 2.java
 
- 	deps[items.DependencyBlobCache] = cache
 
- 	changes := make(object.Changes, 1)
 
- 	treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"f02289bfe843388a1bb3c7dea210374082dd86b9"))
 
- 	treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
 
- 		"eca91acf1fd828f20dcb653a061d8c97d965bc6c"))
 
- 	changes[0] = &object.Change{From: object.ChangeEntry{
 
- 		Name: "test.java",
 
- 		Tree: treeFrom,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "test.java",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("448eb3f312849b0ca766063d06b09481c987b309"),
 
- 		},
 
- 	}, To: object.ChangeEntry{
 
- 		Name: "test.java",
 
- 		Tree: treeTo,
 
- 		TreeEntry: object.TreeEntry{
 
- 			Name: "test.java",
 
- 			Mode: 0100644,
 
- 			Hash: plumbing.NewHash("3312c92f3e8bdfbbdb30bccb6acd1b85bc338dfc"),
 
- 		},
 
- 	}}
 
- 	deps[items.DependencyTreeChanges] = changes
 
- 	res, err := fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	magicDiffs := res[items.DependencyFileDiff].(map[string]items.FileDiffData)["test.java"]
 
- 	fd.WhitespaceIgnore = true
 
- 	res, err = fd.Consume(deps)
 
- 	assert.Nil(t, err)
 
- 	plainDiffs := res[items.DependencyFileDiff].(map[string]items.FileDiffData)["test.java"]
 
- 	assert.NotEqual(t, magicDiffs.Diffs, plainDiffs.Diffs)
 
- 	assert.Equal(t, magicDiffs.OldLinesOfCode, plainDiffs.OldLinesOfCode)
 
- 	assert.Equal(t, magicDiffs.NewLinesOfCode, plainDiffs.NewLinesOfCode)
 
- }
 
- func TestFileDiffFork(t *testing.T) {
 
- 	fd1 := fixtures.FileDiff()
 
- 	clones := fd1.Fork(1)
 
- 	assert.Len(t, clones, 1)
 
- 	fd2 := clones[0].(*items.FileDiff)
 
- 	assert.True(t, fd1 == fd2)
 
- 	fd1.Merge([]core.PipelineItem{fd2})
 
- }
 
 
  |