2018-06-06 08:22:46 +00:00
|
|
|
/* @flow */
|
|
|
|
|
|
|
|
import { expect } from 'chai'
|
2018-07-12 08:09:41 +00:00
|
|
|
import FicheDePaieSelectors, {
|
2018-06-28 14:58:34 +00:00
|
|
|
COTISATION_BRANCHE_ORDER
|
2018-07-12 08:09:41 +00:00
|
|
|
} from 'Selectors/ficheDePaieSelectors'
|
2018-06-06 08:22:46 +00:00
|
|
|
|
2018-09-03 11:57:39 +00:00
|
|
|
import { simulationTargetNames } from '../source/config'
|
2018-08-30 17:00:09 +00:00
|
|
|
|
2018-06-18 09:28:47 +00:00
|
|
|
let state = {
|
|
|
|
form: {
|
|
|
|
conversation: {
|
|
|
|
values: {
|
2018-06-28 15:01:31 +00:00
|
|
|
'contrat salarié': { salaire: { 'brut de base': '2300' } },
|
|
|
|
entreprise: { effectif: '50' }
|
2018-06-18 09:28:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2018-08-30 17:00:09 +00:00
|
|
|
targetNames: simulationTargetNames,
|
2018-07-25 14:07:53 +00:00
|
|
|
conversationStarted: true,
|
|
|
|
conversationSteps: {
|
|
|
|
foldedSteps: []
|
|
|
|
}
|
2018-06-18 09:28:47 +00:00
|
|
|
}
|
2018-06-06 08:22:46 +00:00
|
|
|
|
2018-08-30 17:00:09 +00:00
|
|
|
let paySlip = null
|
2018-06-18 09:28:47 +00:00
|
|
|
|
|
|
|
describe('pay slip selector', function() {
|
2018-08-28 12:16:57 +00:00
|
|
|
beforeEach(() => {
|
2018-08-30 17:00:09 +00:00
|
|
|
paySlip = FicheDePaieSelectors(state)
|
2018-08-28 12:16:57 +00:00
|
|
|
expect(paySlip).not.to.eq(null)
|
|
|
|
})
|
2018-06-06 08:22:46 +00:00
|
|
|
it('should have cotisations grouped by branches in the proper ordering', function() {
|
2018-08-28 12:16:57 +00:00
|
|
|
// $FlowFixMe
|
2018-06-06 08:22:46 +00:00
|
|
|
let branches = paySlip.cotisations.map(([branche]) => branche)
|
|
|
|
expect(branches).to.eql(COTISATION_BRANCHE_ORDER)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should collect all cotisations in a branche', function() {
|
2018-08-28 12:16:57 +00:00
|
|
|
// $FlowFixMe
|
2018-06-06 08:22:46 +00:00
|
|
|
let cotisationsSanté = (paySlip.cotisations.find(
|
|
|
|
([branche]) => branche === 'santé'
|
|
|
|
) || [])[1].map(cotisation => cotisation.nom)
|
|
|
|
expect(cotisationsSanté).to.have.lengthOf(3)
|
|
|
|
expect(cotisationsSanté).to.include('maladie')
|
|
|
|
expect(cotisationsSanté).to.include('complémentaire santé')
|
|
|
|
expect(cotisationsSanté).to.include('médecine du travail')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should sum all cotisations', function() {
|
2018-08-28 12:16:57 +00:00
|
|
|
// $FlowFixMe
|
2018-06-06 08:22:46 +00:00
|
|
|
const montantTotalCotisations = paySlip.totalCotisations
|
2018-06-28 15:01:31 +00:00
|
|
|
expect(montantTotalCotisations.partPatronale).to.be.closeTo(992, 5)
|
2018-06-06 08:22:46 +00:00
|
|
|
expect(montantTotalCotisations.partSalariale).to.be.closeTo(520, 5)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should have value for "salarié" and "employeur" for a cotisation', function() {
|
2018-08-28 12:16:57 +00:00
|
|
|
// $FlowFixMe
|
2018-06-06 08:22:46 +00:00
|
|
|
let cotisationATMP = (paySlip.cotisations.find(
|
|
|
|
([branche]) =>
|
|
|
|
branche === 'accidents du travail / maladies professionnelles'
|
|
|
|
) || [])[1][0]
|
|
|
|
expect(cotisationATMP.montant.partSalariale).to.be.closeTo(0, 0.1)
|
|
|
|
let defaultATMPRate = 2.22 / 100
|
|
|
|
expect(cotisationATMP.montant.partPatronale).to.be.closeTo(
|
|
|
|
2300 * defaultATMPRate,
|
|
|
|
1
|
|
|
|
)
|
|
|
|
})
|
|
|
|
})
|