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.v10"
- "gopkg.in/src-d/hercules.v10/internal"
- "gopkg.in/src-d/hercules.v10/internal/core"
- items "gopkg.in/src-d/hercules.v10/internal/plumbing"
- "gopkg.in/src-d/hercules.v10/internal/test"
- "gopkg.in/src-d/hercules.v10/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})
- }
|