2019-04-11 13:23:46 +00:00
|
|
|
import { expect } from 'chai'
|
2019-08-27 14:16:51 +00:00
|
|
|
import dedent from 'dedent-js'
|
2019-04-11 13:23:46 +00:00
|
|
|
import { enrichRule } from 'Engine/rules'
|
2019-08-27 14:16:51 +00:00
|
|
|
import { safeLoad } from 'js-yaml'
|
2019-04-11 13:23:46 +00:00
|
|
|
import { rules as realRules } from '../source/engine/rules'
|
|
|
|
import { analyse, analyseMany, parseAll } from '../source/engine/traverse'
|
|
|
|
|
2020-03-11 13:08:41 +00:00
|
|
|
describe('bug-analyse-many', function() {
|
2020-02-06 10:11:23 +00:00
|
|
|
it('complex inversion with composantes', () => {
|
|
|
|
let rawRules = dedent`
|
2019-04-11 16:23:05 +00:00
|
|
|
- nom: net
|
|
|
|
formule: brut - cotisations
|
|
|
|
- nom: cotisations
|
2019-08-27 14:16:51 +00:00
|
|
|
formule:
|
|
|
|
somme:
|
2019-11-28 11:03:23 +00:00
|
|
|
- cotisation a .salarié
|
2019-04-11 16:23:05 +00:00
|
|
|
- cotisation b
|
|
|
|
|
|
|
|
- nom: cotisation a
|
|
|
|
formule:
|
2020-03-11 13:08:41 +00:00
|
|
|
produit:
|
2019-04-11 16:23:05 +00:00
|
|
|
assiette: brut
|
|
|
|
composantes:
|
|
|
|
- attributs:
|
|
|
|
dû par: employeur
|
|
|
|
taux: 10%
|
|
|
|
- attributs:
|
|
|
|
dû par: salarié
|
|
|
|
taux: 10%
|
2019-08-27 14:16:51 +00:00
|
|
|
|
2019-04-11 16:23:05 +00:00
|
|
|
- nom: cotisation b
|
|
|
|
formule:
|
2020-03-11 13:08:41 +00:00
|
|
|
produit:
|
2019-04-11 16:23:05 +00:00
|
|
|
assiette: brut
|
|
|
|
composantes:
|
|
|
|
- attributs:
|
|
|
|
impôt sur le revenu: x
|
|
|
|
taux: 10%
|
|
|
|
- attributs:
|
|
|
|
impôt sur le revenu: y
|
|
|
|
taux: 10%
|
|
|
|
|
|
|
|
|
|
|
|
- nom: brut
|
2019-07-05 13:00:24 +00:00
|
|
|
unité: €
|
2019-04-11 16:23:05 +00:00
|
|
|
formule:
|
|
|
|
inversion numérique:
|
|
|
|
avec:
|
|
|
|
- net
|
|
|
|
`,
|
2020-02-06 10:11:23 +00:00
|
|
|
rules = parseAll(safeLoad(rawRules).map(enrichRule)),
|
|
|
|
stateSelector = name => ({ net: 700 }[name])
|
|
|
|
const targets = ['brut', 'cotisations']
|
|
|
|
const many = analyseMany(rules, targets)(stateSelector).targets
|
2019-04-11 16:23:05 +00:00
|
|
|
|
2020-02-06 10:11:23 +00:00
|
|
|
const one = analyse(rules, 'cotisations')(stateSelector).targets[0]
|
2019-04-11 16:23:05 +00:00
|
|
|
|
2020-02-06 10:11:23 +00:00
|
|
|
expect(many[1].nodeValue).to.be.closeTo(one.nodeValue, 0.1)
|
|
|
|
})
|
2020-03-11 13:08:41 +00:00
|
|
|
it('should compute the same contributions if asked with analyseMany or analyse', function() {
|
2020-02-06 10:11:23 +00:00
|
|
|
const situationSelector = dottedName =>
|
|
|
|
({
|
|
|
|
'contrat salarié . rémunération . net de cotisations': 3500,
|
|
|
|
'auto-entrepreneur': 'non',
|
|
|
|
'contrat salarié': 'oui',
|
|
|
|
dirigeant: 'assimilé salarié',
|
|
|
|
'contrat salarié . ATMP . taux réduit': 'oui',
|
|
|
|
'contrat salarié . CDD': 'non',
|
|
|
|
'contrat salarié . frais professionnels . indemnité kilométrique vélo . indemnité vélo active':
|
|
|
|
'non',
|
|
|
|
'contrat salarié . rémunération . avantages en nature . montant': 0,
|
|
|
|
'contrat salarié . temps partiel': 'non',
|
|
|
|
'établissement . localisation': {},
|
|
|
|
'contrat salarié . complémentaire santé . part employeur': 50,
|
|
|
|
'contrat salarié . complémentaire santé . forfait . en france': 50,
|
|
|
|
'entreprise . effectif': 1,
|
|
|
|
'entreprise . association non lucrative': 'non'
|
|
|
|
}[dottedName])
|
|
|
|
const rules = parseAll(realRules.map(enrichRule))
|
|
|
|
const targets = [
|
|
|
|
'contrat salarié . rémunération . brut de base',
|
|
|
|
'contrat salarié . cotisations . salariales'
|
|
|
|
]
|
|
|
|
const analyseManyValue = analyseMany(rules, targets)(situationSelector)
|
|
|
|
.targets[1]
|
|
|
|
const analyseValue = analyse(
|
|
|
|
rules,
|
|
|
|
'contrat salarié . cotisations . salariales'
|
|
|
|
)(situationSelector).targets[0]
|
2019-04-11 16:23:05 +00:00
|
|
|
|
2020-02-06 10:11:23 +00:00
|
|
|
expect(analyseManyValue.nodeValue).to.equal(analyseValue.nodeValue)
|
|
|
|
})
|
2019-04-11 13:23:46 +00:00
|
|
|
})
|