2020-10-08 09:29:07 +00:00
|
|
|
import { expect } from 'chai'
|
|
|
|
import dedent from 'dedent-js'
|
2020-11-04 17:05:46 +00:00
|
|
|
import { cyclesInDependenciesGraph } from '../source/AST/graph'
|
2020-10-08 09:29:07 +00:00
|
|
|
|
|
|
|
describe('Cyclic dependencies detectron 3000 ™', () => {
|
|
|
|
it('should detect the trivial formule cycle', () => {
|
|
|
|
const rules = dedent`
|
|
|
|
a:
|
|
|
|
formule: a + 1
|
|
|
|
`
|
|
|
|
const cycles = cyclesInDependenciesGraph(rules)
|
|
|
|
expect(cycles).to.deep.equal([['a']])
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should detect nested and parallel formule cycles', () => {
|
|
|
|
const rules = dedent`
|
|
|
|
a:
|
|
|
|
formule: b + 1
|
|
|
|
b:
|
|
|
|
formule: c + d + 1
|
|
|
|
c:
|
|
|
|
formule: a + 1
|
|
|
|
d:
|
|
|
|
formule: b + 1
|
|
|
|
`
|
|
|
|
const cycles = cyclesInDependenciesGraph(rules)
|
|
|
|
expect(cycles).to.deep.equal([['d', 'c', 'b', 'a']])
|
|
|
|
})
|
2020-11-04 17:05:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
it('should not detect formule cycles due to parent dependancy', () => {
|
|
|
|
const rules = dedent`
|
|
|
|
a:
|
|
|
|
formule: b + 1
|
|
|
|
a . b:
|
|
|
|
formule: 3
|
|
|
|
`
|
|
|
|
const cycles = cyclesInDependenciesGraph(rules)
|
|
|
|
expect(cycles).to.deep.equal([])
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
it('should not detect cycles due to replacement', () => {
|
|
|
|
const rules = dedent`
|
|
|
|
a:
|
|
|
|
formule: b + 1
|
|
|
|
a . b:
|
|
|
|
formule: 3
|
|
|
|
a . c:
|
|
|
|
remplace: b
|
|
|
|
formule: a
|
|
|
|
`
|
|
|
|
const cycles = cyclesInDependenciesGraph(rules)
|
|
|
|
expect(cycles).to.deep.equal([["a . c", "a"]])
|
|
|
|
})
|
2020-10-08 09:29:07 +00:00
|
|
|
})
|