CodiceFiscaleJS/tests/index.spec.js

468 lines
13 KiB
JavaScript
Raw Normal View History

import CodiceFiscale from '../src/codice-fiscale.js';
2020-09-17 16:04:50 +02:00
import { Comune } from '../src/comune.js';
2018-10-08 11:27:13 +02:00
let { describe, test, expect } = global
describe('Codice Fiscale', () => {
test('esiste un oggetto chiamato CodiceFiscale', () => {
expect(CodiceFiscale).toBeDefined()
2018-10-08 11:27:13 +02:00
})
})
describe('CodiceFiscale.surnameCode', () => {
test('è definito', () => {
expect(CodiceFiscale.surnameCode).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('restituisce il corretto risultato in caso di sufficienti consonanti', () => {
expect(CodiceFiscale.surnameCode('Moreno')).toBe('MRN')
})
test('restituisce il corretto risultato in caso di insufficienti consonanti', () => {
expect(CodiceFiscale.surnameCode('Julea')).toBe('JLU')
})
})
describe('CodiceFiscale.nameCode', () => {
test('è definito', () => {
expect(CodiceFiscale.nameCode).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('restituisce il corretto risultato in caso di sufficienti consonanti', () => {
expect(CodiceFiscale.nameCode('Marco')).toBe('MRC')
})
test('restituisce il corretto risultato in caso di insufficienti consonanti', () => {
expect(CodiceFiscale.nameCode('Luca')).toBe('LCU')
})
})
describe('CodiceFiscale.dateCode', () => {
test('è definito', () => {
expect(CodiceFiscale.dateCode).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('restituisce il corretto risultato', () => {
expect(CodiceFiscale.dateCode(1, 1, 2000, 'M')).toBe('00A01')
})
})
describe('CodiceFiscale.getCheckCode', () => {
test('è definito', () => {
expect(CodiceFiscale.getCheckCode).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('restituisce il corretto risultato', () => {
expect(CodiceFiscale.getCheckCode('MRNLCU00A01H501')).toBe('J')
})
})
describe('CodiceFiscale.compute', () => {
test('è definito', () => {
expect(CodiceFiscale.compute).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('calcola il codice fiscale', () => {
expect(CodiceFiscale.compute({
name: 'Luca',
surname: 'Moreno',
gender: 'M',
day: 1,
month: 1,
year: 2000,
birthplace: 'Roma',
birthplaceProvincia: 'RM'
}))
.toBe('MRNLCU00A01H501J')
})
2020-09-17 16:04:50 +02:00
test('calcola il codice fiscale anche per i nati nel comune di Bolzano 😁', () => {
expect(CodiceFiscale.compute({
name: 'Mario',
surname: 'Rossi',
gender: 'M',
day: 1,
month: 1,
year: 1980,
birthplace: 'Bolzano',
birthplaceProvincia: 'BZ'
}))
.toBe('RSSMRA80A01A952F')
})
2020-09-30 14:01:09 +02:00
test('calcola il codice fiscale anche per i nati nel comune di Bolzano 😁', () => {
expect(CodiceFiscale.compute({
name: 'Mario',
surname: 'Rossi',
gender: 'M',
day: 1,
month: 1,
year: 1980,
birthplace: 'Chiaravalle',
birthplaceProvincia: 'AN'
}))
.toBeDefined()
})
2021-02-17 11:26:51 +01:00
let invalidCfis = "BLIPTR93MO4A674Q";
test('controlla il codice fiscale con una regex', () => {
expect(CodiceFiscale.check(invalidCfis)).toEqual(false);
});
2020-09-25 17:32:52 +02:00
2020-09-17 16:04:50 +02:00
2018-10-08 11:27:13 +02:00
test("calcola il codice fiscale di persone nate all'estero", () => {
expect(CodiceFiscale.compute({
name: 'Luca',
surname: 'Moreno',
gender: 'M',
day: 1,
month: 1,
year: 2000,
birthplace: 'Albania',
birthplaceProvincia: 'EE'
}))
.toBe('MRNLCU00A01Z100P')
})
test('se il comune non esiste lancia un eccezione', () => {
var comuneInventato = function () {
CodiceFiscale.compute({
name: 'Luca',
surname: 'Moreno',
gender: 'M',
day: 1,
month: 1,
year: 2000,
birthplace: 'Foo',
birthplaceProvincia: 'EE'
})
}
expect(comuneInventato).toThrowError('Comune with name of Foo and prov EE doesn\'t exists')
2018-10-08 11:27:13 +02:00
})
2020-09-25 17:32:52 +02:00
test('calcola il codice fiscale anche quando viene passato come birthplace il CC di un comune', ()=>{
expect(CodiceFiscale.compute({ name: "mario", surname: "rossi", gender: "M", birthday: "2000-01-01", birthplace: "H501" })).toBeDefined()
})
2018-10-08 11:27:13 +02:00
})
describe('CodiceFiscale.findLocationCode', () => {
test('è definito', () => {
expect(CodiceFiscale.findLocationCode).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('trova il codice del comune', () => {
expect(CodiceFiscale.findLocationCode('Roma', 'RM')).toBe('H501')
})
test('trova il codice di un comune che contiene apostrofi', () => {
expect(CodiceFiscale.findLocationCode("Sant'Angelo Romano", 'RM')).toBe('I284')
})
test('trova il codice di un comune che contiene lettere accentate', () => {
expect(CodiceFiscale.findLocationCode('Riccò del Golfo di Spezia', 'SP')).toBe('H275')
})
test('se la provincia non esiste lancia un eccezione', () => {
var comuneInventato = function () {
CodiceFiscale.findLocationCode('Foo', 'Bar')
}
expect(comuneInventato).toThrowError('Comune with name of Foo and prov Bar doesn\'t exists')
2018-10-08 11:27:13 +02:00
})
test('se il comune non esiste lancia un eccezione', () => {
var comuneInventato = function () {
CodiceFiscale.findLocationCode('Foo', 'RM')
}
expect(comuneInventato).toThrowError('Comune with name of Foo and prov RM doesn\'t exists')
2018-10-08 11:27:13 +02:00
})
})
describe('CodiceFiscale.check', () => {
test('è definito', () => {
expect(CodiceFiscale.check).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('controlla se il codice fiscale è valido', () => {
expect(CodiceFiscale.check('MRNLCU00A01H501J')).toBe(true)
})
2019-06-27 00:11:55 +02:00
test('controlla se un codice fiscale lowercase è valido', () => {
2019-06-27 00:34:27 +02:00
expect(CodiceFiscale.check('MRNLCU00A01H501J'.toLowerCase())).toBe(true)
2019-06-27 00:11:55 +02:00
})
2018-10-08 11:27:13 +02:00
test('controlla che sia composto dal non più 16 valori alfanumerici', () => {
expect(CodiceFiscale.check('MRNLCU00A01H501JK')).toBe(false)
})
test('controlla che sia composto dal almeno 16 valori alfanumerici', () => {
expect(CodiceFiscale.check('MRNLCU00A01H501J3')).toBe(false)
})
test('controlla che il carattere di controllo sia esatto', () => {
expect(CodiceFiscale.check('VNDLDL87D07B963G')).toBe(false)
})
test('funziona anche in caso di omocodie', () => {
expect(CodiceFiscale.check('BNZVCN32S10E57PV')).toBe(true)
expect(CodiceFiscale.check('BNZVCNPNSMLERTPX')).toBe(true)
})
})
describe('CodiceFiscale.getOmocodie', () => {
test('è definito', () => {
expect(CodiceFiscale.getOmocodie).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test('calcola le omocodie dato un codice fiscale', () => {
expect(CodiceFiscale.getOmocodie('BNZVCN32S10E573Z'))
.toEqual(expect.arrayContaining(['BNZVCN32S10E57PV', 'BNZVCNPNSMLERTPX']))
})
})
describe('Calcolo codice fiscale inverso -> metodo .computeInverse', () => {
test('è definito', () => {
expect(CodiceFiscale.computeInverse).toBeDefined()
2018-10-08 11:27:13 +02:00
})
test("se l'input non è una stringa lancia un eccezione", () => {
var notAString = function () {
CodiceFiscale.computeInverse(0)
}
expect(notAString).toThrowError("Comune constructor accept either a valid string or a plain object. Check the documentation")
2018-10-08 11:27:13 +02:00
})
test("restituisce falso se l'input è stringa formattata male", () => {
var notValid = function () {
CodiceFiscale.computeInverse('BNZVCN32SC0E573Z')
}
expect(notValid).toThrowError("Provided input is not a valid Codice Fiscale")
2018-10-08 11:27:13 +02:00
})
/* Nome: MARIO
* Cognome: ROSSI
* Nato a : ROMA (RM)
* Giorno : 23
* Mese : Giugno (6)
* Anno : 1980
* Sesso : M
*/
let mario_rossi_cf = "RSSMRA80H23H501T";
2018-10-08 11:27:13 +02:00
test('restituisce il genere corretto', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).gender).toEqual('M')
2018-10-08 11:27:13 +02:00
})
test('restituisce la città natale corretta', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).birthplace).toEqual('ROMA')
2018-10-08 11:27:13 +02:00
})
test('restituisce la provincia della città natale corretta', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).birthplaceProvincia).toEqual('RM')
2018-10-08 11:27:13 +02:00
})
test('restituisce il giorno di nascita come numero compreso tra 1 e 31', () => {
let day = CodiceFiscale.computeInverse(mario_rossi_cf).day
expect(day >= 1 && day <= 31).toBe(true)
})
test('restituisce il giorno corretto', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).day).toBe(23)
})
test('restituisce il mese corretto', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).month).toBe(6);
})
test('restituisce anno corretto', () => {
expect(CodiceFiscale.computeInverse(mario_rossi_cf).year).toBe(1980);
2018-10-08 11:27:13 +02:00
})
/* Nome: GIUSEPPE
* Cognome: ESPOSITO
* Nato a : NAPOLI (NP)
* Giorno : 18
* Mese : Febbraio (2)
* Anno : 1975
* Sesso : M
* OMOCODIA: true
*/
let giuseppe_esposito_cf = "SPSGPP75B18F83VM";
test('restituisce la città natale corretta nonostante omocodia', () => {
expect(CodiceFiscale.computeInverse(giuseppe_esposito_cf).birthplace).toEqual('NAPOLI')
})
2020-05-26 21:46:30 +02:00
});
2019-04-14 14:08:40 +02:00
describe('Calcolo codice fiscale inverso -> metodo .computeInverse per le donne', () => {
test('è definito', () => {
expect(CodiceFiscale.computeInverse).toBeDefined()
})
test("se l'input non è una stringa lancia un eccezione", () => {
var notAString = function () {
CodiceFiscale.computeInverse(0)
}
expect(notAString).toThrowError("Comune constructor accept either a valid string or a plain object. Check the documentation")
})
test("restituisce falso se l'input è stringa formattata male", () => {
var notValid = function () {
CodiceFiscale.computeInverse('BNZVCN32SC0E573Z')
}
expect(notValid).toThrowError("Provided input is not a valid Codice Fiscale")
})
/* Nome: MARIA
* Cognome: ROSSI
* Nato a : ROMA (RM)
* Giorno : 23
* Mese : Giugno (6)
* Anno : 1980
* Sesso : F
*/
let maria_rossi_cf = "RSSMRA80H63H501X";
test('restituisce il genere corretto', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).gender).toEqual('F')
})
test('restituisce la città natale corretta', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).birthplace).toEqual('ROMA')
})
test('restituisce la provincia della città natale corretta', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).birthplaceProvincia).toEqual('RM')
})
test('restituisce il giorno di nascita come numero compreso tra 1 e 31', () => {
let day = CodiceFiscale.computeInverse(maria_rossi_cf).day
expect(day >= 1 && day <= 31).toBe(true)
})
test('restituisce il giorno corretto', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).day).toBe(23)
})
test('restituisce il mese corretto', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).month).toBe(6);
})
test('restituisce anno corretto', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).year).toBe(1980);
})
2019-04-14 15:14:17 +02:00
test('la data corretta', () => {
expect(CodiceFiscale.computeInverse(maria_rossi_cf).birthday).toBe("1980-06-23");
})
2019-04-14 14:08:40 +02:00
})
2020-05-29 23:16:10 +02:00
describe('Calcolo del codice fiscale inverso',()=>{
/* Nome: MARIA
* Cognome: ROSSI
* Nato a : Acquacanina (MC)
* Giorno : 23
* Mese : Giugno (6)
* Anno : 1980
* Sesso : F
*/
// Acquacanina non è più un comune ma una frazione
let maria_rossi_cf = "RSSMRA80T63A031E";
test('funziona con i comuni soppressi', () => {
expect(CodiceFiscale.reverse(maria_rossi_cf).birthplace).toEqual('ACQUACANINA');
expect(CodiceFiscale.reverse(maria_rossi_cf).birthplaceProvincia).toEqual('MC');
})
/* Nome: MARIA
* Cognome: ROSSI
* Nato a : VIMERCATO (MI)
* Giorno : 23
* Mese : Giugno (6)
* Anno : 1980
* Sesso : F
*/
// Vimercate nel 1980 era in provincia di Milano, ora appartiene alla provincia di Monza e della Brianza (MB)
let maria_rossi_cf2 = "RSSMRA80T63M052X";
test('funziona con i comuni che hanno cambiato provincia, restituendo la provincia a cui è assegnato attualmente il comune', () => {
expect(CodiceFiscale.reverse(maria_rossi_cf2).birthplace).toEqual('VIMERCATE');
expect(CodiceFiscale.reverse(maria_rossi_cf2).birthplaceProvincia).toEqual('MB');
2020-07-17 00:37:12 +02:00
});
describe('non rileva anomalie con il comune di Calendasco',()=>{
test('calcola il codice fiscale', () => {
expect(CodiceFiscale.compute({
name: 'Mario',
surname: 'Rossi',
gender: 'M',
day: 25,
month: 12,
year: 1980,
birthplace: 'Calendasco'
}))
.toBe('RSSMRA80T25B405Z')
})
test("e anche il codice fiscale inverso", () => {
let reverse = CodiceFiscale.reverse('RSSMRA80T25B405Z');
expect(reverse.name).toEqual('MRA');
expect(reverse.surname).toEqual('RSS');
expect(reverse.gender).toEqual('M');
expect(reverse.day).toEqual(25);
expect(reverse.month).toEqual(12);
expect(reverse.year).toEqual(1980);
expect(reverse.birthplace).toEqual('CALENDASCO');
expect(reverse.birthplaceProvincia).toEqual('PC');
});
});
2020-05-29 23:16:10 +02:00
})
2020-09-17 16:04:50 +02:00
describe("La classe Comune", ()=>{
test("trova il comune di Bolzano", ()=>{
let bz = new Comune("Bolzano", "BZ")
expect(bz.nome).toEqual('BOLZANO')
})
})
2021-02-17 10:45:00 +01:00
2021-02-17 11:26:51 +01:00
2021-02-17 10:45:00 +01:00
describe("Il metodo toString()", ()=>{
test("funziona correttamente anche con le omocodie", ()=>{
let cf = new CodiceFiscale({
name: "Mario",
surname: "Rossi",
gender: "M",
birthday: "1987-02-01",
birthplace: "H501"
});
expect(cf.toString()).toBe("RSSMRA87B01H501A");
cf.omocodie();
expect(cf.toString()).toBe("RSSMRA87B01H501A");
2020-09-17 16:04:50 +02:00
})
2021-02-17 11:26:51 +01:00
})