|
|
@ -15,6 +15,13 @@ const tapahtumaTyypit = {
|
|
|
|
|
|
|
|
|
|
|
|
lisääTunti: 'lisääTunti',
|
|
|
|
lisääTunti: 'lisääTunti',
|
|
|
|
poistaTunti: 'poistaTunti',
|
|
|
|
poistaTunti: 'poistaTunti',
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lisääTuntiLuokka: 'lisääTuntiLuokka',
|
|
|
|
|
|
|
|
poistaTuntiLuokka: 'poistaTuntiLuokka',
|
|
|
|
|
|
|
|
lisääTuntiOpettaja: 'lisääTuntiOpettaja',
|
|
|
|
|
|
|
|
poistaTuntiOpettaja: 'poistaTuntiOpettaja',
|
|
|
|
|
|
|
|
lisääTuntiTila: 'lisääTuntiTila',
|
|
|
|
|
|
|
|
poistaTuntiTila: 'poistaTuntiTila',
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Tapahtuma {
|
|
|
|
class Tapahtuma {
|
|
|
@ -41,11 +48,11 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
let paluuarvo = undefined;
|
|
|
|
let paluuarvo = undefined;
|
|
|
|
switch (tyyppi) {
|
|
|
|
switch (tyyppi) {
|
|
|
|
case tapahtumaTyypit.lisääAste:
|
|
|
|
case tapahtumaTyypit.lisääAste:
|
|
|
|
assertRange('lisääAste argumentit määrä', argumentit.length, 0, 1);
|
|
|
|
assertRange('lisääAste argumentit', argumentit.length, 0, 1);
|
|
|
|
paluuarvo = luokkaAsteet.lisää(...argumentit)
|
|
|
|
paluuarvo = luokkaAsteet.lisää(...argumentit)
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.poistaAste:
|
|
|
|
case tapahtumaTyypit.poistaAste:
|
|
|
|
assertEq('poistaAste argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('poistaAste argumentit', argumentit.length, 1);
|
|
|
|
let [poistettuAste] = argumentit;
|
|
|
|
let [poistettuAste] = argumentit;
|
|
|
|
luokkaAsteet.poista(poistettuAste);
|
|
|
|
luokkaAsteet.poista(poistettuAste);
|
|
|
|
// Poista poistettujen luokka-asteiden luokat tunneista
|
|
|
|
// Poista poistettujen luokka-asteiden luokat tunneista
|
|
|
@ -59,7 +66,7 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.muutaAste:
|
|
|
|
case tapahtumaTyypit.muutaAste:
|
|
|
|
assertEq('muutaAste argumentit määrä', argumentit.length, 2);
|
|
|
|
assertEq('muutaAste argumentit', argumentit.length, 2);
|
|
|
|
let [vanhaAste, uusiAste] = argumentit;
|
|
|
|
let [vanhaAste, uusiAste] = argumentit;
|
|
|
|
luokkaAsteet.muuta(vanhaAste, uusiAste);
|
|
|
|
luokkaAsteet.muuta(vanhaAste, uusiAste);
|
|
|
|
// Muuta muutetut luokka-asteet tunneissa
|
|
|
|
// Muuta muutetut luokka-asteet tunneissa
|
|
|
@ -76,11 +83,11 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääLuokka:
|
|
|
|
case tapahtumaTyypit.lisääLuokka:
|
|
|
|
assertEq('lisääLuokka argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('lisääLuokka argumentit', argumentit.length, 1);
|
|
|
|
luokkaAsteet.asteet[argumentit[0]].lisää();
|
|
|
|
luokkaAsteet.asteet[argumentit[0]].lisää();
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.poistaLuokka:
|
|
|
|
case tapahtumaTyypit.poistaLuokka:
|
|
|
|
assertEq('poistaLuokka argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('poistaLuokka argumentit', argumentit.length, 1);
|
|
|
|
let [aste] = argumentit;
|
|
|
|
let [aste] = argumentit;
|
|
|
|
luokkaAsteet.asteet[aste].poista();
|
|
|
|
luokkaAsteet.asteet[aste].poista();
|
|
|
|
// Poista luokka jota ei enää ole asteella tunneista
|
|
|
|
// Poista luokka jota ei enää ole asteella tunneista
|
|
|
@ -94,11 +101,11 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääOpettaja:
|
|
|
|
case tapahtumaTyypit.lisääOpettaja:
|
|
|
|
assertEq('lisääOpettaja argumentit määrä', argumentit.length, 2);
|
|
|
|
assertEq('lisääOpettaja argumentit', argumentit.length, 2);
|
|
|
|
opettajat.lisää(...argumentit);
|
|
|
|
opettajat.lisää(...argumentit);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.poistaOpettaja:
|
|
|
|
case tapahtumaTyypit.poistaOpettaja:
|
|
|
|
assertEq('poistaOpettaja argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('poistaOpettaja argumentit', argumentit.length, 1);
|
|
|
|
let [poistettuOpettaja] = argumentit;
|
|
|
|
let [poistettuOpettaja] = argumentit;
|
|
|
|
opettajat.poista(poistettuOpettaja);
|
|
|
|
opettajat.poista(poistettuOpettaja);
|
|
|
|
// Poista opettaja joita ei enää ole tunneista
|
|
|
|
// Poista opettaja joita ei enää ole tunneista
|
|
|
@ -108,11 +115,11 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääTila:
|
|
|
|
case tapahtumaTyypit.lisääTila:
|
|
|
|
assertEq('lisääTila argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('lisääTila argumentit', argumentit.length, 1);
|
|
|
|
paluuarvo = tilat.lisää(...argumentit);
|
|
|
|
paluuarvo = tilat.lisää(...argumentit);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.poistaTila:
|
|
|
|
case tapahtumaTyypit.poistaTila:
|
|
|
|
assertEq('poistaTila argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('poistaTila argumentit', argumentit.length, 1);
|
|
|
|
let [poistettuTila] = argumentit;
|
|
|
|
let [poistettuTila] = argumentit;
|
|
|
|
tilat.poista(poistettuTila);
|
|
|
|
tilat.poista(poistettuTila);
|
|
|
|
for (let [_, tunti] of tunnit.tunnit) {
|
|
|
|
for (let [_, tunti] of tunnit.tunnit) {
|
|
|
@ -121,14 +128,39 @@ function suorita(tyyppi, ...argumentit) {
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääTunti:
|
|
|
|
case tapahtumaTyypit.lisääTunti:
|
|
|
|
assertEq('lisääTunti argumentit määrä', argumentit.length, 4);
|
|
|
|
assertEq('lisääTunti argumentit', argumentit.length, 4);
|
|
|
|
paluuarvo = tunnit.lisää(...argumentit);
|
|
|
|
paluuarvo = tunnit.lisää(...argumentit);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case tapahtumaTyypit.poistaTunti:
|
|
|
|
case tapahtumaTyypit.poistaTunti:
|
|
|
|
assertEq('poistaTunti argumentit määrä', argumentit.length, 1);
|
|
|
|
assertEq('poistaTunti argumentit', argumentit.length, 1);
|
|
|
|
tunnit.poista(...argumentit);
|
|
|
|
tunnit.poista(...argumentit);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääTuntiLuokka:
|
|
|
|
|
|
|
|
assertEq('lisääTuntiLuokka argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).luokat.lisää(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case tapahtumaTyypit.poistaTuntiLuokka:
|
|
|
|
|
|
|
|
assertEq('poistaTuntiLuokka argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).luokat.poista(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääTuntiOpettaja:
|
|
|
|
|
|
|
|
assertEq('lisääTuntiOpettaja argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).opettajaLyhenteet.lisää(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case tapahtumaTyypit.poistaTuntiOpettaja:
|
|
|
|
|
|
|
|
assertEq('poistaTuntiOpettajat argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).opettajaLyhenteet.poista(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case tapahtumaTyypit.lisääTuntiTila:
|
|
|
|
|
|
|
|
assertEq('lisääTuntiTila argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).tilat.lisää(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case tapahtumaTyypit.poistaTuntiTila:
|
|
|
|
|
|
|
|
assertEq('poistaTuntiTila argumentit', argumentit.length, 2);
|
|
|
|
|
|
|
|
tunnit.tunnit.get(argumentit[0]).tilat.poista(argumentit[1]);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
|
throw new Error(`tuntematon tapahtumatyyppi ${tyyppi}`);
|
|
|
|
throw new Error(`tuntematon tapahtumatyyppi ${tyyppi}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -294,26 +326,29 @@ testi('tilojen käsittely', () => {
|
|
|
|
testi('tuntien käsittely', () => {
|
|
|
|
testi('tuntien käsittely', () => {
|
|
|
|
alustaMalli();
|
|
|
|
alustaMalli();
|
|
|
|
suorita(tapahtumaTyypit.lisääAste);
|
|
|
|
suorita(tapahtumaTyypit.lisääAste);
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääAste);
|
|
|
|
suorita(tapahtumaTyypit.lisääAste, 5);
|
|
|
|
suorita(tapahtumaTyypit.lisääAste, 5);
|
|
|
|
suorita(tapahtumaTyypit.lisääLuokka, 5);
|
|
|
|
suorita(tapahtumaTyypit.lisääLuokka, 5);
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'KV', 'Kari Virtanen');
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'KV', 'Kari Virtanen');
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'AS', 'Aili Savolainen');
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'AS', 'Aili Savolainen');
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'MM', 'Maija Meikäläinen');
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'MM', 'Maija Meikäläinen');
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääOpettaja, 'MaM', 'Matti Meikäläinen');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, '1A');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, '1A');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, '5B');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, '5B');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, 'Käsityöluokka');
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, 'Käsityöluokka');
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääTila, '5A');
|
|
|
|
assertEq('aluksi', tunnit.järjestyksessä(), []);
|
|
|
|
assertEq('aluksi', tunnit.järjestyksessä(), []);
|
|
|
|
|
|
|
|
|
|
|
|
assertEq('historia',
|
|
|
|
assertEq('historia',
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, 'Historia', '5B', 'KV', 1),
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, ['Historia'], ['5B'], ['KV'], [1]),
|
|
|
|
0
|
|
|
|
0
|
|
|
|
);
|
|
|
|
);
|
|
|
|
assertEq('äidinkieli',
|
|
|
|
assertEq('äidinkieli',
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, 'Äidinkieli', '1A', 'AS', 0),
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, ['Äidinkieli'], ['1A'], ['AS'], [0]),
|
|
|
|
1
|
|
|
|
1
|
|
|
|
);
|
|
|
|
);
|
|
|
|
assertEq('kuvataide',
|
|
|
|
assertEq('kuvataide',
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, 'Kuvataide', '5A', 'MM', 2),
|
|
|
|
suorita(tapahtumaTyypit.lisääTunti, ['Kuvataide'], ['5A'], ['MM'], [2]),
|
|
|
|
2
|
|
|
|
2
|
|
|
|
);
|
|
|
|
);
|
|
|
|
assertEq('lisättyä pituus', tunnit.järjestyksessä().length, 3);
|
|
|
|
assertEq('lisättyä pituus', tunnit.järjestyksessä().length, 3);
|
|
|
@ -343,9 +378,38 @@ testi('tuntien käsittely', () => {
|
|
|
|
assertEq('tila poistettua 1', tunnit.järjestyksessä()[1][1].tilat.alkiot(), [2]);
|
|
|
|
assertEq('tila poistettua 1', tunnit.järjestyksessä()[1][1].tilat.alkiot(), [2]);
|
|
|
|
assertEq('tila poistettua 2', tunnit.järjestyksessä()[2][1].tilat.alkiot(), [0]);
|
|
|
|
assertEq('tila poistettua 2', tunnit.järjestyksessä()[2][1].tilat.alkiot(), [0]);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääTuntiLuokka, 0, '2A');
|
|
|
|
|
|
|
|
assertEq('luokka lisättyä tunnille 0', tunnit.järjestyksessä()[0][1].luokat.alkiot(), ['2A']);
|
|
|
|
|
|
|
|
assertEq('luokka lisättyä tunnille 1', tunnit.järjestyksessä()[1][1].luokat.alkiot(), ['6A']);
|
|
|
|
|
|
|
|
assertEq('luokka lisättyä tunnille 2', tunnit.järjestyksessä()[2][1].luokat.alkiot(), []);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.poistaTuntiLuokka, 2, '6A');
|
|
|
|
|
|
|
|
assertEq('luokka poistettua tunnilta 0', tunnit.järjestyksessä()[0][1].luokat.alkiot(), ['2A']);
|
|
|
|
|
|
|
|
assertEq('luokka poistettua tunnilta 1', tunnit.järjestyksessä()[1][1].luokat.alkiot(), []);
|
|
|
|
|
|
|
|
assertEq('luokka poistettua tunnilta 2', tunnit.järjestyksessä()[2][1].luokat.alkiot(), []);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääTuntiOpettaja, 0, 'MaM');
|
|
|
|
|
|
|
|
assertEq('opettaja lisättyä tunnille 0', tunnit.järjestyksessä()[0][1].opettajaLyhenteet.alkiot(), ['MaM']);
|
|
|
|
|
|
|
|
assertEq('opettaja lisättyä tunnille 1', tunnit.järjestyksessä()[1][1].opettajaLyhenteet.alkiot(), ['MM']);
|
|
|
|
|
|
|
|
assertEq('opettaja lisättyä tunnille 2', tunnit.järjestyksessä()[2][1].opettajaLyhenteet.alkiot(), ['AS']);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.poistaTuntiOpettaja, 2, 'MM');
|
|
|
|
|
|
|
|
assertEq('opettaja poistettua tunnilta 0', tunnit.järjestyksessä()[0][1].opettajaLyhenteet.alkiot(), ['MaM']);
|
|
|
|
|
|
|
|
assertEq('opettaja poistettua tunnilta 1', tunnit.järjestyksessä()[1][1].opettajaLyhenteet.alkiot(), []);
|
|
|
|
|
|
|
|
assertEq('opettaja poistettua tunnilta 2', tunnit.järjestyksessä()[2][1].opettajaLyhenteet.alkiot(), ['AS']);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.lisääTuntiTila, 0, 3);
|
|
|
|
|
|
|
|
assertEq('tila lisäätyä tunnille 0', tunnit.järjestyksessä()[0][1].tilat.alkiot(), [3]);
|
|
|
|
|
|
|
|
assertEq('tila lisäätyä tunnille 1', tunnit.järjestyksessä()[1][1].tilat.alkiot(), [2]);
|
|
|
|
|
|
|
|
assertEq('tila lisäätyä tunnille 2', tunnit.järjestyksessä()[2][1].tilat.alkiot(), [0]);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.poistaTuntiTila, 1, 0);
|
|
|
|
|
|
|
|
assertEq('tila poistettua tunnilta 0', tunnit.järjestyksessä()[0][1].tilat.alkiot(), [3]);
|
|
|
|
|
|
|
|
assertEq('tila poistettua tunnilta 1', tunnit.järjestyksessä()[1][1].tilat.alkiot(), [2]);
|
|
|
|
|
|
|
|
assertEq('tila poistettua tunnilta 2', tunnit.järjestyksessä()[2][1].tilat.alkiot(), []);
|
|
|
|
|
|
|
|
|
|
|
|
suorita(tapahtumaTyypit.poistaTunti, 0);
|
|
|
|
suorita(tapahtumaTyypit.poistaTunti, 0);
|
|
|
|
assertEq('poistettua pituus', tunnit.järjestyksessä().length, 2);
|
|
|
|
assertEq('poistettua pituus', tunnit.järjestyksessä().length, 2);
|
|
|
|
|
|
|
|
|
|
|
|
alustaMalli();
|
|
|
|
alustaMalli();
|
|
|
|
// TODO: Luokkien ja opettajien listojen päivitys
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|