uast_test.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. // +build !disable_babelfish
  2. package uast
  3. import (
  4. "bytes"
  5. "fmt"
  6. "io/ioutil"
  7. "os"
  8. "path"
  9. "testing"
  10. "github.com/gogo/protobuf/proto"
  11. "github.com/stretchr/testify/assert"
  12. "gopkg.in/bblfsh/sdk.v2/uast"
  13. "gopkg.in/bblfsh/sdk.v2/uast/nodes"
  14. "gopkg.in/src-d/go-git.v4/plumbing"
  15. "gopkg.in/src-d/go-git.v4/plumbing/object"
  16. "gopkg.in/src-d/hercules.v10/internal/core"
  17. "gopkg.in/src-d/hercules.v10/internal/pb"
  18. items "gopkg.in/src-d/hercules.v10/internal/plumbing"
  19. "gopkg.in/src-d/hercules.v10/internal/test"
  20. )
  21. func fixtureUASTExtractor() *Extractor {
  22. exr := Extractor{Endpoint: "0.0.0.0:9432"}
  23. err := exr.Initialize(test.Repository)
  24. if err != nil {
  25. panic(err)
  26. }
  27. return &exr
  28. }
  29. func AddHash(t *testing.T, cache map[plumbing.Hash]*items.CachedBlob, hash string) {
  30. objhash := plumbing.NewHash(hash)
  31. blob, err := test.Repository.BlobObject(objhash)
  32. assert.Nil(t, err)
  33. cb := &items.CachedBlob{Blob: *blob}
  34. err = cb.Cache()
  35. assert.Nil(t, err)
  36. cache[objhash] = cb
  37. }
  38. func TestUASTExtractorMeta(t *testing.T) {
  39. exr := fixtureUASTExtractor()
  40. defer exr.Dispose()
  41. assert.Equal(t, exr.Name(), "UAST")
  42. assert.Equal(t, len(exr.Provides()), 1)
  43. assert.Equal(t, exr.Provides()[0], DependencyUasts)
  44. assert.Equal(t, len(exr.Requires()), 2)
  45. assert.Equal(t, exr.Requires()[0], items.DependencyTreeChanges)
  46. assert.Equal(t, exr.Requires()[1], items.DependencyBlobCache)
  47. opts := exr.ListConfigurationOptions()
  48. assert.Len(t, opts, 5)
  49. assert.Equal(t, opts[0].Name, ConfigUASTEndpoint)
  50. assert.Equal(t, opts[1].Name, ConfigUASTTimeout)
  51. assert.Equal(t, opts[2].Name, ConfigUASTPoolSize)
  52. assert.Equal(t, opts[3].Name, ConfigUASTFailOnErrors)
  53. assert.Equal(t, opts[4].Name, ConfigUASTIgnoreMissingDrivers)
  54. feats := exr.Features()
  55. assert.Len(t, feats, 1)
  56. assert.Equal(t, feats[0], FeatureUast)
  57. }
  58. func TestUASTExtractorConfiguration(t *testing.T) {
  59. exr := fixtureUASTExtractor()
  60. defer exr.Dispose()
  61. facts := map[string]interface{}{}
  62. assert.Nil(t, exr.Configure(facts))
  63. facts[ConfigUASTEndpoint] = "localhost:9432"
  64. facts[ConfigUASTTimeout] = 15
  65. facts[ConfigUASTPoolSize] = 7
  66. facts[ConfigUASTFailOnErrors] = true
  67. facts[ConfigUASTIgnoreMissingDrivers] = []string{"test"}
  68. assert.Nil(t, exr.Configure(facts))
  69. assert.Equal(t, exr.Endpoint, facts[ConfigUASTEndpoint])
  70. assert.NotNil(t, exr.Context)
  71. assert.Equal(t, exr.PoolSize, facts[ConfigUASTPoolSize])
  72. assert.Equal(t, exr.FailOnErrors, true)
  73. assert.Equal(t, exr.IgnoredMissingDrivers, map[string]bool{"test": true})
  74. }
  75. func TestUASTExtractorRegistration(t *testing.T) {
  76. summoned := core.Registry.Summon((&Extractor{}).Name())
  77. assert.Len(t, summoned, 1)
  78. assert.Equal(t, summoned[0].Name(), "UAST")
  79. summoned = core.Registry.Summon((&Extractor{}).Provides()[0])
  80. assert.Len(t, summoned, 1)
  81. assert.Equal(t, summoned[0].Name(), "UAST")
  82. }
  83. func TestUASTExtractorNoBabelfish(t *testing.T) {
  84. exr := Extractor{Endpoint: "0.0.0.0:56934"}
  85. err := exr.Initialize(test.Repository)
  86. assert.NotNil(t, err)
  87. }
  88. func TestUASTExtractorConsume(t *testing.T) {
  89. exr := fixtureUASTExtractor()
  90. defer exr.Dispose()
  91. changes := make(object.Changes, 4)
  92. // 2b1ed978194a94edeabbca6de7ff3b5771d4d665
  93. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  94. "96c6ece9b2f3c7c51b83516400d278dea5605100"))
  95. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  96. "251f2094d7b523d5bcc60e663b6cf38151bf8844"))
  97. changes[0] = &object.Change{From: object.ChangeEntry{
  98. Name: "analyser.go",
  99. Tree: treeFrom,
  100. TreeEntry: object.TreeEntry{
  101. Name: "analyser.go",
  102. Mode: 0100644,
  103. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  104. },
  105. }, To: object.ChangeEntry{},
  106. }
  107. changes[1] = &object.Change{From: object.ChangeEntry{
  108. Name: "cmd/hercules/main.go",
  109. Tree: treeFrom,
  110. TreeEntry: object.TreeEntry{
  111. Name: "cmd/hercules/main.go",
  112. Mode: 0100644,
  113. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  114. },
  115. }, To: object.ChangeEntry{
  116. Name: "cmd/hercules/main.go",
  117. Tree: treeTo,
  118. TreeEntry: object.TreeEntry{
  119. Name: "cmd/hercules/main.go",
  120. Mode: 0100644,
  121. Hash: plumbing.NewHash("f7d918ec500e2f925ecde79b51cc007bac27de72"),
  122. },
  123. },
  124. }
  125. changes[2] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  126. Name: "linux.png",
  127. Tree: treeTo,
  128. TreeEntry: object.TreeEntry{
  129. Name: "linux.png",
  130. Mode: 0100644,
  131. Hash: plumbing.NewHash("81f2b6d1fa5357f90e9dead150cd515720897545"),
  132. },
  133. },
  134. }
  135. changes[3] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  136. Name: "README.md",
  137. Tree: treeTo,
  138. TreeEntry: object.TreeEntry{
  139. Name: "README.md",
  140. Mode: 0100644,
  141. Hash: plumbing.NewHash("5248c86995f6d60eb57730da18b5e020a4341863"),
  142. },
  143. },
  144. }
  145. cache := map[plumbing.Hash]*items.CachedBlob{}
  146. for _, hash := range []string{
  147. "baa64828831d174f40140e4b3cfa77d1e917a2c1",
  148. "5d78f57d732aed825764347ec6f3ab74d50d0619",
  149. "c29112dbd697ad9b401333b80c18a63951bc18d9",
  150. "f7d918ec500e2f925ecde79b51cc007bac27de72",
  151. "81f2b6d1fa5357f90e9dead150cd515720897545",
  152. "5248c86995f6d60eb57730da18b5e020a4341863",
  153. } {
  154. AddHash(t, cache, hash)
  155. }
  156. deps := map[string]interface{}{}
  157. deps[items.DependencyBlobCache] = cache
  158. deps[items.DependencyTreeChanges] = changes
  159. deps[core.DependencyCommit], _ = test.Repository.CommitObject(
  160. plumbing.NewHash("2b1ed978194a94edeabbca6de7ff3b5771d4d665"))
  161. res, err := exr.Consume(deps)
  162. assert.Len(t, res[DependencyUasts], 1)
  163. assert.Nil(t, err)
  164. res, err = exr.Consume(deps)
  165. assert.Len(t, res[DependencyUasts], 1)
  166. assert.Nil(t, err)
  167. exr.FailOnErrors = true
  168. res, err = exr.Consume(deps)
  169. assert.Nil(t, res)
  170. assert.NotNil(t, err)
  171. exr.FailOnErrors = false
  172. hash := plumbing.NewHash("5d78f57d732aed825764347ec6f3ab74d50d0619")
  173. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  174. Name: "labours.py",
  175. Tree: treeTo,
  176. TreeEntry: object.TreeEntry{
  177. Name: "labours.py",
  178. Mode: 0100644,
  179. Hash: hash,
  180. },
  181. },
  182. }
  183. deps[items.DependencyTreeChanges] = changes[:2]
  184. res, err = exr.Consume(deps)
  185. assert.Nil(t, err)
  186. uasts := res[DependencyUasts].(map[plumbing.Hash]nodes.Node)
  187. assert.Equal(t, len(uasts), 1)
  188. assert.Equal(t, len(uasts[hash].(nodes.Object)["body"].(nodes.Array)), 24)
  189. exr.IgnoredMissingDrivers = map[string]bool{}
  190. changes[2] = changes[3]
  191. deps[items.DependencyTreeChanges] = changes[:3]
  192. res, err = exr.Consume(deps)
  193. assert.Nil(t, err)
  194. exr.FailOnErrors = true
  195. res, err = exr.Consume(deps)
  196. assert.Nil(t, res)
  197. assert.NotNil(t, err)
  198. exr.FailOnErrors = false
  199. }
  200. func TestUASTExtractorFork(t *testing.T) {
  201. exr1 := fixtureUASTExtractor()
  202. defer exr1.Dispose()
  203. clones := exr1.Fork(1)
  204. assert.Len(t, clones, 1)
  205. exr2 := clones[0].(*Extractor)
  206. assert.True(t, exr1 == exr2)
  207. exr1.Merge([]core.PipelineItem{exr2})
  208. }
  209. func fixtureUASTChanges() *Changes {
  210. ch := Changes{}
  211. ch.Configure(nil)
  212. ch.Initialize(test.Repository)
  213. return &ch
  214. }
  215. func TestUASTChangesMeta(t *testing.T) {
  216. ch := fixtureUASTChanges()
  217. assert.Equal(t, ch.Name(), "UASTChanges")
  218. assert.Equal(t, len(ch.Provides()), 1)
  219. assert.Equal(t, ch.Provides()[0], DependencyUastChanges)
  220. assert.Equal(t, len(ch.Requires()), 2)
  221. assert.Equal(t, ch.Requires()[0], DependencyUasts)
  222. assert.Equal(t, ch.Requires()[1], items.DependencyTreeChanges)
  223. opts := ch.ListConfigurationOptions()
  224. assert.Len(t, opts, 0)
  225. }
  226. func TestUASTChangesRegistration(t *testing.T) {
  227. summoned := core.Registry.Summon((&Changes{}).Name())
  228. assert.Len(t, summoned, 1)
  229. assert.Equal(t, summoned[0].Name(), "UASTChanges")
  230. summoned = core.Registry.Summon((&Changes{}).Provides()[0])
  231. assert.True(t, len(summoned) >= 1)
  232. matched := false
  233. for _, tp := range summoned {
  234. matched = matched || tp.Name() == "UASTChanges"
  235. }
  236. assert.True(t, matched)
  237. }
  238. func newNodeWithType(name string) nodes.Node {
  239. return nodes.Object{
  240. uast.KeyType: nodes.String(name),
  241. uast.KeyToken: nodes.String("my_token"),
  242. }
  243. }
  244. func TestUASTChangesConsume(t *testing.T) {
  245. var uastsArray []nodes.Node
  246. uasts := map[plumbing.Hash]nodes.Node{}
  247. hash := plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe")
  248. uasts[hash] = newNodeWithType("uno")
  249. uastsArray = append(uastsArray, uasts[hash])
  250. hash = plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9")
  251. uasts[hash] = newNodeWithType("dos")
  252. uastsArray = append(uastsArray, uasts[hash])
  253. hash = plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1")
  254. uasts[hash] = newNodeWithType("tres")
  255. uastsArray = append(uastsArray, uasts[hash])
  256. hash = plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9")
  257. uasts[hash] = newNodeWithType("quatro")
  258. uastsArray = append(uastsArray, uasts[hash])
  259. changes := make(object.Changes, 3)
  260. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  261. "a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
  262. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  263. "994eac1cd07235bb9815e547a75c84265dea00f5"))
  264. changes[0] = &object.Change{From: object.ChangeEntry{
  265. Name: "analyser.go",
  266. Tree: treeFrom,
  267. TreeEntry: object.TreeEntry{
  268. Name: "analyser.go",
  269. Mode: 0100644,
  270. Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
  271. },
  272. }, To: object.ChangeEntry{
  273. Name: "analyser.go",
  274. Tree: treeTo,
  275. TreeEntry: object.TreeEntry{
  276. Name: "analyser.go",
  277. Mode: 0100644,
  278. Hash: plumbing.NewHash("baa64828831d174f40140e4b3cfa77d1e917a2c1"),
  279. },
  280. }}
  281. changes[1] = &object.Change{From: object.ChangeEntry{}, To: object.ChangeEntry{
  282. Name: "cmd/hercules/main.go",
  283. Tree: treeTo,
  284. TreeEntry: object.TreeEntry{
  285. Name: "cmd/hercules/main.go",
  286. Mode: 0100644,
  287. Hash: plumbing.NewHash("c29112dbd697ad9b401333b80c18a63951bc18d9"),
  288. },
  289. },
  290. }
  291. changes[2] = &object.Change{To: object.ChangeEntry{}, From: object.ChangeEntry{
  292. Name: ".travis.yml",
  293. Tree: treeTo,
  294. TreeEntry: object.TreeEntry{
  295. Name: ".travis.yml",
  296. Mode: 0100644,
  297. Hash: plumbing.NewHash("291286b4ac41952cbd1389fda66420ec03c1a9fe"),
  298. },
  299. },
  300. }
  301. deps := map[string]interface{}{}
  302. deps[DependencyUasts] = uasts
  303. deps[items.DependencyTreeChanges] = changes
  304. ch := fixtureUASTChanges()
  305. ch.cache[changes[0].From.TreeEntry.Hash] = uastsArray[3]
  306. ch.cache[changes[2].From.TreeEntry.Hash] = uastsArray[0]
  307. resultMap, err := ch.Consume(deps)
  308. assert.Nil(t, err)
  309. result := resultMap[DependencyUastChanges].([]Change)
  310. assert.Len(t, result, 3)
  311. assert.Equal(t, result[0].Change, changes[0])
  312. assert.Equal(t, result[0].Before, uastsArray[3])
  313. assert.Equal(t, result[0].After, uastsArray[2])
  314. assert.Equal(t, result[1].Change, changes[1])
  315. assert.Nil(t, result[1].Before)
  316. assert.Equal(t, result[1].After, uastsArray[1])
  317. assert.Equal(t, result[2].Change, changes[2])
  318. assert.Equal(t, result[2].Before, uastsArray[0])
  319. assert.Nil(t, result[2].After)
  320. }
  321. func TestUASTChangesFork(t *testing.T) {
  322. changes1 := fixtureUASTChanges()
  323. changes1.cache[plumbing.ZeroHash] = nil
  324. clones := changes1.Fork(1)
  325. assert.Len(t, clones, 1)
  326. changes2 := clones[0].(*Changes)
  327. assert.False(t, changes1 == changes2)
  328. assert.Equal(t, changes1.cache, changes2.cache)
  329. delete(changes1.cache, plumbing.ZeroHash)
  330. assert.Len(t, changes2.cache, 1)
  331. changes1.Merge([]core.PipelineItem{changes2})
  332. }
  333. func fixtureUASTChangesSaver() *ChangesSaver {
  334. ch := ChangesSaver{}
  335. ch.Initialize(test.Repository)
  336. return &ch
  337. }
  338. func TestUASTChangesSaverMeta(t *testing.T) {
  339. chs := fixtureUASTChangesSaver()
  340. assert.Equal(t, chs.Name(), "UASTChangesSaver")
  341. assert.True(t, len(chs.Description()) > 0)
  342. assert.Equal(t, len(chs.Provides()), 0)
  343. assert.Equal(t, len(chs.Requires()), 1)
  344. assert.Equal(t, chs.Requires()[0], DependencyUastChanges)
  345. opts := chs.ListConfigurationOptions()
  346. assert.Len(t, opts, 1)
  347. assert.Equal(t, opts[0].Name, ConfigUASTChangesSaverOutputPath)
  348. assert.Equal(t, chs.Flag(), "dump-uast-changes")
  349. }
  350. func TestUASTChangesSaverConfiguration(t *testing.T) {
  351. facts := map[string]interface{}{}
  352. chs := fixtureUASTChangesSaver()
  353. chs.Configure(facts)
  354. assert.Empty(t, chs.OutputPath)
  355. facts[ConfigUASTChangesSaverOutputPath] = "libre"
  356. chs.Configure(facts)
  357. assert.Equal(t, chs.OutputPath, "libre")
  358. }
  359. func TestUASTChangesSaverRegistration(t *testing.T) {
  360. summoned := core.Registry.Summon((&ChangesSaver{}).Name())
  361. assert.Len(t, summoned, 1)
  362. assert.Equal(t, summoned[0].Name(), "UASTChangesSaver")
  363. leaves := core.Registry.GetLeaves()
  364. matched := false
  365. for _, tp := range leaves {
  366. if tp.Flag() == (&ChangesSaver{}).Flag() {
  367. matched = true
  368. break
  369. }
  370. }
  371. assert.True(t, matched)
  372. }
  373. func TestUASTChangesSaverPayload(t *testing.T) {
  374. chs := fixtureUASTChangesSaver()
  375. deps := map[string]interface{}{}
  376. changes := make([]Change, 1)
  377. deps[DependencyUastChanges] = changes
  378. deps[core.DependencyCommit], _ = test.Repository.CommitObject(
  379. plumbing.NewHash("2b1ed978194a94edeabbca6de7ff3b5771d4d665"))
  380. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  381. "a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
  382. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  383. "994eac1cd07235bb9815e547a75c84265dea00f5"))
  384. changes[0] = Change{Before: nodes.Object{}, After: nodes.Object{},
  385. Change: &object.Change{From: object.ChangeEntry{
  386. Name: "analyser.go",
  387. Tree: treeFrom,
  388. TreeEntry: object.TreeEntry{
  389. Name: "analyser.go",
  390. Mode: 0100644,
  391. Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
  392. },
  393. }, To: object.ChangeEntry{
  394. Name: "analyser.go",
  395. Tree: treeTo,
  396. TreeEntry: object.TreeEntry{
  397. Name: "analyser.go",
  398. Mode: 0100644,
  399. Hash: plumbing.NewHash("334cde09da4afcb74f8d2b3e6fd6cce61228b485"),
  400. },
  401. }}}
  402. chs.Consume(deps)
  403. res := chs.Finalize()
  404. tmpdir, err := ioutil.TempDir("", "hercules-test-")
  405. assert.Nil(t, err)
  406. defer os.RemoveAll(tmpdir)
  407. chs.OutputPath = tmpdir
  408. buffer := &bytes.Buffer{}
  409. chs.Serialize(res, true, buffer)
  410. pbResults := &pb.UASTChangesSaverResults{}
  411. proto.Unmarshal(buffer.Bytes(), pbResults)
  412. assert.Len(t, pbResults.Changes, 1)
  413. assert.Equal(t, pbResults.Changes[0].FileName, "analyser.go")
  414. assert.Equal(t, pbResults.Changes[0].SrcAfter,
  415. path.Join(tmpdir, "0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.src"))
  416. assert.Equal(t, pbResults.Changes[0].SrcBefore,
  417. path.Join(tmpdir, "0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.src"))
  418. assert.Equal(t, pbResults.Changes[0].UastAfter,
  419. path.Join(tmpdir, "0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.pb"))
  420. assert.Equal(t, pbResults.Changes[0].UastBefore,
  421. path.Join(tmpdir, "0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.pb"))
  422. checkFiles := func() {
  423. files, err := ioutil.ReadDir(tmpdir)
  424. assert.Nil(t, err)
  425. assert.Len(t, files, 4)
  426. names := map[string]int{
  427. "0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.src": 1,
  428. "0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.src": 1,
  429. "0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.pb": 1,
  430. "0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.pb": 1,
  431. }
  432. matches := 0
  433. for _, fi := range files {
  434. matches += names[fi.Name()]
  435. os.Remove(fi.Name())
  436. }
  437. assert.Equal(t, matches, len(names))
  438. }
  439. checkFiles()
  440. buffer.Truncate(0)
  441. chs.Serialize(res, false, buffer)
  442. assert.Equal(t, buffer.String(), fmt.Sprintf(` - {file: analyser.go, src0: %s/0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.src, src1: %s/0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.src, uast0: %s/0_0_before_dc248ba2b22048cc730c571a748e8ffcf7085ab9.pb, uast1: %s/0_0_after_334cde09da4afcb74f8d2b3e6fd6cce61228b485.pb}
  443. `, tmpdir, tmpdir, tmpdir, tmpdir))
  444. checkFiles()
  445. }
  446. func TestUASTChangesSaverConsumeMerge(t *testing.T) {
  447. chs := fixtureUASTChangesSaver()
  448. deps := map[string]interface{}{}
  449. changes := make([]Change, 1)
  450. deps[DependencyUastChanges] = changes
  451. deps[core.DependencyCommit], _ = test.Repository.CommitObject(
  452. plumbing.NewHash("2b1ed978194a94edeabbca6de7ff3b5771d4d665"))
  453. treeFrom, _ := test.Repository.TreeObject(plumbing.NewHash(
  454. "a1eb2ea76eb7f9bfbde9b243861474421000eb96"))
  455. treeTo, _ := test.Repository.TreeObject(plumbing.NewHash(
  456. "994eac1cd07235bb9815e547a75c84265dea00f5"))
  457. changes[0] = Change{Before: nodes.Object{}, After: nodes.Object{},
  458. Change: &object.Change{From: object.ChangeEntry{
  459. Name: "analyser.go",
  460. Tree: treeFrom,
  461. TreeEntry: object.TreeEntry{
  462. Name: "analyser.go",
  463. Mode: 0100644,
  464. Hash: plumbing.NewHash("dc248ba2b22048cc730c571a748e8ffcf7085ab9"),
  465. },
  466. }, To: object.ChangeEntry{
  467. Name: "analyser.go",
  468. Tree: treeTo,
  469. TreeEntry: object.TreeEntry{
  470. Name: "analyser.go",
  471. Mode: 0100644,
  472. Hash: plumbing.NewHash("334cde09da4afcb74f8d2b3e6fd6cce61228b485"),
  473. },
  474. }}}
  475. deps[core.DependencyCommit], _ = test.Repository.CommitObject(
  476. plumbing.NewHash("cce947b98a050c6d356bc6ba95030254914027b1"))
  477. chs.Consume(deps)
  478. assert.Len(t, chs.result, 1)
  479. chs.Consume(deps)
  480. assert.Len(t, chs.result, 2)
  481. deps[core.DependencyCommit], _ = test.Repository.CommitObject(
  482. plumbing.NewHash("dd9dd084d5851d7dc4399fc7dbf3d8292831ebc5"))
  483. chs.Consume(deps)
  484. assert.Len(t, chs.result, 3)
  485. chs.Consume(deps)
  486. assert.Len(t, chs.result, 3)
  487. }
  488. func TestUASTChangesSaverFork(t *testing.T) {
  489. saver1 := fixtureUASTChangesSaver()
  490. clones := saver1.Fork(1)
  491. assert.Len(t, clones, 1)
  492. saver2 := clones[0].(*ChangesSaver)
  493. assert.True(t, saver1 == saver2)
  494. saver1.Merge([]core.PipelineItem{saver2})
  495. }