uast_test.go 17 KB

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