mon-entreprise/test/real-rules.test.js

58 lines
1.7 KiB
JavaScript
Raw Normal View History

/*
Les mécanismes sont testés dans mécanismes/ comme le sont les variables directement dans la base YAML.
On y créée dans chaque fichier une base YAML autonome, dans laquelle intervient le mécanisme à tester,
puis on teste idéalement tous ses comportements sans en faire intervenir d'autres.
*/
2018-06-13 16:50:51 +00:00
import { AssertionError } from 'chai'
import { merge } from 'ramda'
import { exampleAnalysisSelector } from 'Selectors/analyseSelectors'
import { rules } from '../source/engine/ruleWithVersementTransport'
import { parseAll } from '../source/engine/traverse'
2018-06-13 16:50:51 +00:00
// les variables dans les tests peuvent être exprimées relativement à l'espace de nom de la règle,
// comme dans sa formule
let runExamples = (examples, rule) =>
examples.map(ex => {
let runExample = exampleAnalysisSelector(
{
currentExample: {
situation: ex.situation,
dottedName: rule.dottedName
}
},
{ dottedName: rule.dottedName }
),
exampleValue = runExample.nodeValue,
goal = ex['valeur attendue'],
ok =
exampleValue === goal
? true
: typeof goal === 'number'
? Math.abs((exampleValue - goal) / goal) < 0.001
: goal === null && exampleValue === 0
return merge(ex, {
ok,
rule: runExample
})
})
let parsedRules = parseAll(rules)
describe('Tests des règles de notre base de règles', () =>
parsedRules.map(rule => {
if (!rule.exemples) return null
describe(rule.name, () => {
2018-06-13 16:50:51 +00:00
let examples = runExamples(rule.exemples, rule)
examples.map(example =>
it(example.nom + '', () => {
if (!example.ok)
throw new AssertionError(`
Valeur attendue : ${example['valeur attendue']}
Valeur obtenue : ${example.rule.nodeValue}
`)
})
)
})
}))