98 lines
5.6 KiB
Python
98 lines
5.6 KiB
Python
from io import BytesIO
|
|
import unittest
|
|
|
|
import numpy as np
|
|
import pandas as pd
|
|
from backend import his_io
|
|
|
|
|
|
class TestHisio(unittest.TestCase):
|
|
|
|
def check_students_table(self, table):
|
|
self.assertEqual(table.shape, (6, 20))
|
|
self.assertEqual(list(table.columns),
|
|
['Examplan.id', 'PrüfungsNr.', 'Titel', 'Nachname', 'Vorname', 'Leistung', 'Versuch',
|
|
'Status', 'ECTS', 'Semester', 'Jahr', 'Prüfungsperiode', 'Vermerk', 'Thema', 'Beginn',
|
|
'Gepl. Ende', 'Tatsächl. Ende', 'Prüfungsart', 'Prüfungsform', 'LockVersion'])
|
|
|
|
self.assertEqual(table.index.name, 'Matrikelnummer')
|
|
self.assertEqual(list(table.index), [3434343, 3535353, 3131313, 2323232, 3737373, 3939393])
|
|
self.assertEqual(list(table['Examplan.id']), [1414141, 1515151, 1111111, 1313131, 1717171, 1919191])
|
|
self.assertEqual(list(table['Nachname']), ['Hendrix', 'Lukather', 'Mayer', 'Page', 'Townshend', 'Van Halen'])
|
|
self.assertEqual(list(table['LockVersion']), [
|
|
'ea56ef45-1b42-4a9f-8dc2-e9f3b8e6c9a1=0,109aefbb-988c-44a8-a72d-82ad0025dcb0=0,6aed40c3-8ca7-4cf8-8004-534c11121a43=0,',
|
|
'1e851fa6-6f69-4fe4-a1a8-510ab8e5c6ea=0,eeecd36a-ee4a-4897-b7db-464542618fb3=0,3fda53aa-2106-4f8b-a832-03aa57917cb2=0,',
|
|
'fd952c3a-c789-4af2-88fd-0dbe8ea0e68b=0,5a639ec2-eec4-4d53-bd92-5ed368f164c3=0,26270d08-a83b-4c2a-94e3-fc732553ef99=0,',
|
|
'ee3f3068-dad7-489c-a5e7-f2eccaedacf7=0,92e970b1-d447-4009-8dde-676d6a31a337=0,8c29a40c-8aa1-4585-b77b-78b410e3d12d=0,',
|
|
'1832c736-1d8c-4d49-bdcd-4295fc5bf3b4=0,8f5bf01d-9cc3-4bb9-86c1-c6d5d0cbc45a=0,9c9cce83-7a96-47fb-acdd-8fc0fd5fddfa=0,',
|
|
'14d1b781-a879-4115-a444-c87b725bbfe2=0,98e734b2-3253-43c2-a173-2fe7e686bc93=0,cb6d9ca0-b3e5-40c9-b7f9-e6e3e4511e50=0,'])
|
|
self.assertEqual(dict(table.dtypes), his_io.dtypes.students_table)
|
|
|
|
def check_header(self, header):
|
|
self.assertEqual(header.shape, (4, 21))
|
|
self.assertEqual(list(header[0]), ['5160 - Rocket Science (Prüfung) | Prüfer/-in: Schröder, Enrico | Wintersemester 2023/24 | Prüfungsperiode 1', None, 'EXAM_CHECK_TOKEN', 'startHISsheet'])
|
|
self.assertEqual(header.iloc[2, 1], '6711e6e8b09fe054d0216a4745b5c56d')
|
|
|
|
def test(self):
|
|
with open('5160-RocketScience-WiSe_2023.xlsx', 'rb') as f:
|
|
self.table_bytes = BytesIO(f.read())
|
|
|
|
students_table, his_header = None, None
|
|
with self.subTest('read'):
|
|
students_table, his_header = his_io.read_excel(self.table_bytes)
|
|
self.assertIsNotNone(students_table)
|
|
self.assertIsNotNone(his_header)
|
|
|
|
|
|
with self.subTest('students_table'):
|
|
self.check_students_table(students_table)
|
|
self.assertTrue(students_table['Leistung'].isna().all())
|
|
|
|
with self.subTest('his_header'):
|
|
self.check_header(his_header)
|
|
|
|
with self.subTest('prepare_table'):
|
|
points_table = his_io.prepare_table(students_table)
|
|
self.assertEqual(points_table.shape, (6, 22))
|
|
self.assertEqual(list(points_table.columns),
|
|
['Examplan.id', 'PrüfungsNr.', 'Titel', 'Nachname', 'Vorname', 'Leistung', 'Versuch',
|
|
'Status', 'ECTS', 'Semester', 'Jahr', 'Prüfungsperiode', 'Vermerk', 'Thema', 'Beginn',
|
|
'Gepl. Ende', 'Tatsächl. Ende', 'Prüfungsart', 'Prüfungsform', 'LockVersion', 'Punkte', 'Note'])
|
|
self.assertTrue(points_table['Punkte'].isna().all())
|
|
self.assertTrue(points_table['Note'].isna().all())
|
|
|
|
with self.subTest('export'):
|
|
points_table['1'] = [1, 2, 3, 4, 5, 0]
|
|
points_table['2'] = [0, 1, 2, 3, 4, 5]
|
|
points_table['Punkte'] = [1, 2, 3, 4, 5, 6]
|
|
points_table['Note'] = ['1,0', '2,0', '3,0', '4,0', '5,0', 'NT']
|
|
grades_table = pd.DataFrame({'Note': ['1,0', '2,0', '3,0', '4,0', '5,0', 'NT'],
|
|
'Prozent': [0.9, 0.8, 0.6, 0.4, 0.2, 0.1],
|
|
'Untergrenze': [100, 80, 60, 40, 20, 0],
|
|
'Obergrenze': [100, 80, 60, 40, 20, 0]})
|
|
|
|
export_bytes = his_io.export(points_table, his_header, ['1', '2'], grades_table)
|
|
self.assertIsNotNone(export_bytes)
|
|
|
|
exported_students_table, exported_his_header = his_io.read_excel(export_bytes)
|
|
self.check_students_table(exported_students_table)
|
|
self.assertEqual(list(exported_students_table['Leistung']), ['1,0', '2,0', '3,0', '4,0', '5,0', 'NT'])
|
|
self.check_header(exported_his_header)
|
|
|
|
with self.subTest('exported_summary'):
|
|
summary_sheet = pd.read_excel(export_bytes, header=None, sheet_name='Aufgaben')
|
|
self.assertIsNotNone(summary_sheet)
|
|
self.assertEqual(summary_sheet.shape, (7, 7))
|
|
self.assertEqual(list(summary_sheet.iloc[0]), ['Matrikelnummer', 'Nachname', 'Vorname', 'Punkte', 'Note', 1, 2])
|
|
self.assertEqual(list(summary_sheet.iloc[1]), [3434343, 'Hendrix', 'Jimi', 1, '1,0', 1, 0])
|
|
self.assertEqual(list(summary_sheet.iloc[6]), [3939393, 'Van Halen', 'Eddie', 6, 'NT', 0, 5])
|
|
|
|
with self.subTest('exported_grades_table'):
|
|
grades_table = pd.read_excel(export_bytes, header=None, sheet_name='Notenschlüssel')
|
|
self.assertIsNotNone(grades_table)
|
|
self.assertEqual(grades_table.shape, (6, 4))
|
|
self.assertEqual(list(grades_table.iloc[2]), ['3,0', 0.6, 60, 60])
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main() |