test: testen voor group repo klaargezet, er is nog iets mis

This commit is contained in:
Laure Jablonski 2025-03-08 21:47:05 +01:00
parent 8389b7a157
commit a220743083
2 changed files with 97 additions and 24 deletions

View file

@ -0,0 +1,70 @@
import { beforeAll, describe, expect, it } from 'vitest';
import { setupTestApp } from '../setup-tests';
import { GroupRepository } from '../../src/data/assignments/group-repository';
import {
getAssignmentRepository,
getClassRepository,
getGroupRepository,
} from '../../src/data/repositories';
import { AssignmentRepository } from '../../src/data/assignments/assignment-repository';
import { ClassRepository } from '../../src/data/classes/class-repository';
import { Class } from '../../src/entities/classes/class.entity';
describe('GroupRepository', () => {
let GroupRepository: GroupRepository;
let AssignmentRepository: AssignmentRepository;
let ClassRepository: ClassRepository;
beforeAll(async () => {
await setupTestApp();
GroupRepository = getGroupRepository();
AssignmentRepository = getAssignmentRepository();
ClassRepository = getClassRepository();
});
it('should return the requested group', async () => {
const class_ = await ClassRepository.findById('id01');
const assignment = await AssignmentRepository.findByClassAndId(
class_!,
1
);
const group = await GroupRepository.findByAssignmentAndGroupNumber(
assignment!,
1
);
expect(group).toBeTruthy();
});
it('should return all groups for assignment', async () => {
const class_ = await ClassRepository.findById('id01');
const assignment = await AssignmentRepository.findByClassAndId(
class_!,
1
);
const groups = await GroupRepository.findAllGroupsForAssignment(
assignment!
);
expect(groups).toBeTruthy();
expect(groups).toHaveLength(3);
});
// it('should not find removed group', async () => {
// const class_ = await ClassRepository.findById('id02');
// const assignment = await AssignmentRepository.findByClassAndId(
// class_!,
// 1
// );
// await GroupRepository.deleteByAssignmentAndGroupNumber(assignment!, 1);
// const group = await GroupRepository.findByAssignmentAndGroupNumber(
// assignment!,
// 1
// );
// expect(group).toBeNull();
// });
});

View file

@ -392,34 +392,32 @@ export async function setupTestApp() {
groups: [], groups: [],
}); });
// const group01 = em.create(Group, { const group01 = em.create(Group, {
// assignment: assignment01, assignment: assignment01,
// groupNumber: 1, groupNumber: 1,
// members: [student01, student02], members: [student01, student02],
// }); });
// const group02 = em.create(Group, { const group02 = em.create(Group, {
// assignment: assignment01, assignment: assignment01,
// groupNumber: 2, groupNumber: 2,
// members: [student03, student04], members: [student03, student04],
// }); });
// const group03 = em.create(Group, { const group03 = em.create(Group, {
// assignment: assignment01, assignment: assignment01,
// groupNumber: 3, groupNumber: 3,
// members: [student05, student06], members: [student05, student06],
// }); });
// const group04 = em.create(Group, { const group04 = em.create(Group, {
// assignment: assignment02, assignment: assignment02,
// groupNumber: 1, groupNumber: 4,
// members: [student04], members: [student04],
// }); });
// assignment01.groups.push(group01); assignment01.groups = [group01, group02, group03];
// assignment01.groups.push(group02); assignment02.groups = [group04];
// assignment01.groups.push(group03);
// assignment02.groups.push(group04);
const teacherInvitation01 = em.create(TeacherInvitation, { const teacherInvitation01 = em.create(TeacherInvitation, {
sender: teacher02, sender: teacher02,
@ -627,6 +625,11 @@ export async function setupTestApp() {
teacherInvitation03, teacherInvitation03,
teacherInvitation04, teacherInvitation04,
assignment01, assignment01,
assignment02,
assignment03, assignment03,
group01,
group02,
group03,
group04,
]); ]);
} }