test: assignments data
This commit is contained in:
parent
a452b9fc4f
commit
1f5fce3529
1 changed files with 24 additions and 12 deletions
|
@ -1,48 +1,60 @@
|
|||
import { beforeAll, describe, expect, it } from 'vitest';
|
||||
import { setupTestApp } from '../../setup-tests';
|
||||
import { AssignmentRepository } from '../../../src/data/assignments/assignment-repository';
|
||||
import { getAssignmentRepository, getClassRepository } from '../../../src/data/repositories';
|
||||
import { ClassRepository } from '../../../src/data/classes/class-repository';
|
||||
import { getAssignmentRepository } from '../../../src/data/repositories';
|
||||
import { getClass01, getClass02 } from '../../test_assets/classes/classes.testdata';
|
||||
import { getAssignment02, getAssignment03 } from '../../test_assets/assignments/assignments.testdata';
|
||||
import { getTestleerkracht1 } from '../../test_assets/users/teachers.testdata';
|
||||
|
||||
describe('AssignmentRepository', () => {
|
||||
let assignmentRepository: AssignmentRepository;
|
||||
let classRepository: ClassRepository;
|
||||
|
||||
beforeAll(async () => {
|
||||
await setupTestApp();
|
||||
assignmentRepository = getAssignmentRepository();
|
||||
classRepository = getClassRepository();
|
||||
});
|
||||
|
||||
it('should return the requested assignment', async () => {
|
||||
const class_ = await classRepository.findById('34d484a1-295f-4e9f-bfdc-3e7a23d86a89');
|
||||
const class_ = getClass02();
|
||||
const usedAssignment = getAssignment02();
|
||||
const assignment = await assignmentRepository.findByClassAndId(class_!, 21001);
|
||||
|
||||
expect(assignment).toBeTruthy();
|
||||
expect(assignment!.title).toBe('tool');
|
||||
expect(assignment!.description).toBe(usedAssignment.description);
|
||||
expect(assignment!.id).toBe(usedAssignment.id);
|
||||
expect(assignment!.learningPathHruid).toBe(usedAssignment.learningPathHruid);
|
||||
expect(assignment!.within.classId).toBe(usedAssignment.within.classId);
|
||||
expect(assignment!.title).toBe(usedAssignment.title);
|
||||
});
|
||||
|
||||
it('should return all assignments for a class', async () => {
|
||||
const class_ = await classRepository.findById('34d484a1-295f-4e9f-bfdc-3e7a23d86a89');
|
||||
const class_ = getClass02();
|
||||
const usedAssignment = getAssignment02();
|
||||
const assignments = await assignmentRepository.findAllAssignmentsInClass(class_!);
|
||||
|
||||
expect(assignments).toBeTruthy();
|
||||
expect(assignments).toHaveLength(1);
|
||||
expect(assignments[0].title).toBe('tool');
|
||||
const assignment = assignments[0];
|
||||
expect(assignment.description).toBe(usedAssignment.description);
|
||||
expect(assignment.id).toBe(usedAssignment.id);
|
||||
expect(assignment.learningPathHruid).toBe(usedAssignment.learningPathHruid);
|
||||
expect(assignment.within.classId).toBe(usedAssignment.within.classId);
|
||||
expect(assignment.title).toBe(usedAssignment.title);
|
||||
});
|
||||
|
||||
it('should find all by username of the responsible teacher', async () => {
|
||||
const result = await assignmentRepository.findAllByResponsibleTeacher('testleerkracht1');
|
||||
const teacher = getTestleerkracht1();
|
||||
const result = await assignmentRepository.findAllByResponsibleTeacher(teacher.username);
|
||||
const resultIds = result.map((it) => it.id).sort((a, b) => (a ?? 0) - (b ?? 0));
|
||||
|
||||
expect(resultIds).toEqual([21000, 21002, 21003, 21004]);
|
||||
});
|
||||
|
||||
it('should not find removed assignment', async () => {
|
||||
const class_ = await classRepository.findById('id01');
|
||||
await assignmentRepository.deleteByClassAndId(class_!, 3);
|
||||
const deleted = getAssignment03();
|
||||
await assignmentRepository.deleteByClassAndId(deleted.within, deleted.id!);
|
||||
|
||||
const assignment = await assignmentRepository.findByClassAndId(class_!, 3);
|
||||
const assignment = await assignmentRepository.findByClassAndId(deleted.within, deleted.id!);
|
||||
|
||||
expect(assignment).toBeNull();
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue