mon-entreprise/publicodes/test/cycles.test.js

92 lines
2.2 KiB
JavaScript
Raw Normal View History

2020-09-22 19:03:08 +00:00
import { expect } from 'chai'
import dedent from 'dedent-js'
import graphlib from '@dagrejs/graphlib'
import { DependencyType } from '../source/cyclesLib/rulesDependencies'
import { flattenOneLevelRemplaceLoops } from '../source/cyclesLib/graph'
2020-09-22 19:03:08 +00:00
2020-09-22 19:49:14 +00:00
import { cyclicDependencies } from '../source/cyclesLib'
2020-09-22 19:03:08 +00:00
describe('Remplace loops flatten-o-tron 2500 ™', () => {
it(`should replace 2 nodes referencing each other with formule and replacedBy by
4 nodes without loop`, () => {
const g = new graphlib.Graph()
g.setEdge('b', 'c', { type: DependencyType.formule })
g.setEdge('c', 'b', { type: DependencyType.replacedBy })
const flattenedGraph = flattenOneLevelRemplaceLoops(g)
})
})
describe('Cyclic dependencies detectron 3000 ™', () => {
2020-09-22 19:03:08 +00:00
it('should detect the trivial formule cycle', () => {
const rules = dedent`
a:
formule: a + 1
`
2020-09-22 19:49:14 +00:00
const cycles = cyclicDependencies(rules)
2020-09-22 19:03:08 +00:00
expect(cycles).to.deep.equal([['a']])
})
it('should detect the trivial replace cycle', () => {
const rules = dedent`
a:
remplace: a
`
2020-09-22 19:49:14 +00:00
const cycles = cyclicDependencies(rules)
2020-09-22 19:03:08 +00:00
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
`
2020-09-22 19:49:14 +00:00
const cycles = cyclicDependencies(rules)
2020-09-22 19:03:08 +00:00
expect(cycles).to.deep.equal([['d', 'c', 'b', 'a']])
})
it('should not detect 1 level formule + remplace', () => {
const rules = dedent`
b:
formule: c + 1
remplace: c
c:
formule: 0
`
2020-09-22 19:49:14 +00:00
const cycles = cyclicDependencies(rules)
2020-09-22 19:03:08 +00:00
expect(cycles).to.be.empty
})
it('should detect 1 level rend non applicable + remplace ❓', () => {
const rules = dedent`
b:
remplace: c
c:
rend non applicable: b
`
const cycles = cyclicDependencies(rules)
expect(cycles).to.deep.equal([['c', 'b']])
})
2020-09-22 19:03:08 +00:00
it('should detect a 2 levels formuleX2 + remplace (but why? 😢)', () => {
const rules = dedent`
a:
formule: b + 1
remplace: c
b:
formule: c + 1
c:
formule: 0
`
2020-09-22 19:49:14 +00:00
const cycles = cyclicDependencies(rules)
2020-09-22 19:03:08 +00:00
expect(cycles).to.deep.equal([['c', 'b', 'a']])
})
})