mon-entreprise/test/results.grid.test.js

216 lines
5.8 KiB
JavaScript
Raw Normal View History

import { expect } from 'chai'
import * as R from 'ramda'
import {
byBranch,
byName,
cell,
subCell
} from '../source/components/ResultsGrid.js'
import { enrichRule, rules as realRules } from '../source/engine/rules'
import reduceSteps from '../source/reducers/reduceSteps'
2017-11-28 15:00:43 +00:00
describe('results grid', function() {
it('should collect branches', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
2018-04-23 09:22:09 +00:00
{ foldedSteps: [], targetNames: ['salaire net'] },
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
let analysis = step2.analysis,
result = byBranch(analysis),
branches = R.keys(result)
expect(branches).to.have.lengthOf(4)
expect(branches).to.include('chômage')
expect(branches).to.include('santé')
expect(branches).to.include('retraite')
expect(branches).to.include('autre')
})
it('should collect branches with both targets', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
{
foldedSteps: [],
targetNames: ['salaire net', 'salaire total']
2018-04-23 09:22:09 +00:00
},
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
let analysis = step2.analysis,
result = byBranch(analysis),
branches = R.keys(result)
expect(branches).to.have.lengthOf(8)
expect(branches).to.include('chômage')
expect(branches).to.include('santé')
expect(branches).to.include('retraite')
expect(branches).to.include('logement')
expect(branches).to.include('famille')
expect(branches).to.include('autre')
expect(branches).to.include('transport')
expect(branches).to.include('formation')
})
it('should collect cells by name', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
{
foldedSteps: [],
targetNames: ['salaire net', 'salaire total']
},
2018-04-23 09:22:09 +00:00
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
let analysis = step2.analysis,
result = byBranch(analysis),
maladie = byName(result['santé']),
names = R.keys(maladie)
expect(names).to.have.lengthOf(5)
expect(names).to.include('contrat salarié . maladie')
expect(names).to.include('contrat salarié . ATMP')
expect(names).to.include('contrat salarié . complémentaire santé')
expect(names).to.include('contrat salarié . prévoyance obligatoire cadre')
expect(names).to.include('contrat salarié . médecine du travail')
})
it('should sum cells by branch and payer', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
{
foldedSteps: [],
targetNames: ['salaire net', 'salaire total']
},
2018-04-23 09:22:09 +00:00
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
let analysis = step2.analysis
expect(cell('retraite', 'salarié', analysis)).to.be.closeTo(257, 5)
expect(cell('autre', 'salarié', analysis)).to.be.closeTo(220, 5)
})
it('should access cell values', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
{
foldedSteps: [],
targetNames: ['salaire net', 'salaire total']
},
2018-04-23 09:22:09 +00:00
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
let analysis = step2.analysis,
result = byBranch(analysis),
maladie = byName(result['santé'])
expect(subCell(maladie, 'contrat salarié . ATMP', 'salarié')).to.be.closeTo(
0,
0.1
)
let defaultATMPRate = 2.22 / 100
expect(
subCell(maladie, 'contrat salarié . ATMP', 'employeur')
).to.be.closeTo(2300 * defaultATMPRate, 1)
})
it('should access taxe sur les salaires', function() {
let fakeState = {}
let stateSelector = () => name => fakeState[name]
let rules = realRules.map(enrichRule),
reducer = reduceSteps(rules, stateSelector)
var step1 = reducer(
{
foldedSteps: [],
targetNames: ['salaire net', 'salaire total']
},
2018-04-23 09:22:09 +00:00
{ type: 'START_CONVERSATION' }
)
fakeState['contrat salarié . salaire de base'] = 2300
var step2 = reducer(step1, {
type: 'STEP_ACTION',
name: 'fold',
step: 'contrat salarié . salaire de base'
})
fakeState['entreprise . association non lucrative'] = 'oui'
var step3 = reducer(step2, {
type: 'STEP_ACTION',
name: 'fold',
step: 'entreprise . association non lucrative'
})
fakeState['entreprise . effectif'] = 10
var step4 = reducer(step3, {
type: 'STEP_ACTION',
name: 'fold',
step: 'entreprise . effectif'
})
let analysis = step4.analysis,
result = byBranch(analysis),
autre = byName(result['autre'])
expect(
subCell(autre, 'contrat salarié . taxe sur les salaires', 'employeur')
).to.be.closeTo(51, 1)
})
})