feat(backend): Functionaliteit toegevoegd om alle submissions zichtbaar voor een bepaalde leerling of leerkracht op te vragen.
This commit is contained in:
parent
03fa7c7b14
commit
9135b9c5b0
9 changed files with 338 additions and 156 deletions
|
@ -31,6 +31,13 @@ describe('AssignmentRepository', () => {
|
|||
expect(assignments[0].title).toBe('tool');
|
||||
});
|
||||
|
||||
it('should find all by username of the responsible teacher', async () => {
|
||||
const result = await assignmentRepository.findAllByResponsibleTeacher("FooFighters")
|
||||
const resultIds = result.map(it => it.id).sort();
|
||||
|
||||
expect(resultIds).toEqual([1, 3, 4]);
|
||||
});
|
||||
|
||||
it('should not find removed assignment', async () => {
|
||||
const class_ = await classRepository.findById('id01');
|
||||
await assignmentRepository.deleteByClassAndId(class_!, 3);
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import { beforeAll, describe, expect, it } from 'vitest';
|
||||
import { setupTestApp } from '../../setup-tests';
|
||||
import { SubmissionRepository } from '../../../src/data/assignments/submission-repository';
|
||||
import {beforeAll, describe, expect, it} from 'vitest';
|
||||
import {setupTestApp} from '../../setup-tests';
|
||||
import {SubmissionRepository} from '../../../src/data/assignments/submission-repository';
|
||||
import {
|
||||
getAssignmentRepository,
|
||||
getClassRepository,
|
||||
|
@ -8,12 +8,32 @@ import {
|
|||
getStudentRepository,
|
||||
getSubmissionRepository,
|
||||
} from '../../../src/data/repositories';
|
||||
import { LearningObjectIdentifier } from '../../../src/entities/content/learning-object-identifier';
|
||||
import { Language } from '@dwengo-1/common/util/language';
|
||||
import { StudentRepository } from '../../../src/data/users/student-repository';
|
||||
import { GroupRepository } from '../../../src/data/assignments/group-repository';
|
||||
import { AssignmentRepository } from '../../../src/data/assignments/assignment-repository';
|
||||
import { ClassRepository } from '../../../src/data/classes/class-repository';
|
||||
import {LearningObjectIdentifier} from '../../../src/entities/content/learning-object-identifier';
|
||||
import {Language} from '@dwengo-1/common/util/language';
|
||||
import {StudentRepository} from '../../../src/data/users/student-repository';
|
||||
import {GroupRepository} from '../../../src/data/assignments/group-repository';
|
||||
import {AssignmentRepository} from '../../../src/data/assignments/assignment-repository';
|
||||
import {ClassRepository} from '../../../src/data/classes/class-repository';
|
||||
import {Submission} from "../../../src/entities/assignments/submission.entity";
|
||||
|
||||
export function checkSubmissionsForStudentNoordkaap(result: Submission[]) {
|
||||
sortSubmissions(result);
|
||||
|
||||
expect(result[0].learningObjectHruid).toBe("id01");
|
||||
expect(result[0].submissionNumber).toBe(2);
|
||||
|
||||
expect(result[1].learningObjectHruid).toBe("id02");
|
||||
expect(result[1].submissionNumber).toBe(1);
|
||||
|
||||
expect(result[2].learningObjectHruid).toBe("id02");
|
||||
expect(result[2].submissionNumber).toBe(2);
|
||||
|
||||
expect(result[3].learningObjectHruid).toBe("id03");
|
||||
expect(result[3].submissionNumber).toBe(1);
|
||||
|
||||
expect(result[4].learningObjectHruid).toBe("id03");
|
||||
expect(result[4].submissionNumber).toBe(2);
|
||||
}
|
||||
|
||||
describe('SubmissionRepository', () => {
|
||||
let submissionRepository: SubmissionRepository;
|
||||
|
@ -59,6 +79,42 @@ describe('SubmissionRepository', () => {
|
|||
expect(submission?.submissionTime.getDate()).toBe(25);
|
||||
});
|
||||
|
||||
it('should find all submissions for all groups of a student', async () => {
|
||||
const result = await submissionRepository.findAllSubmissionsForAllGroupsOfStudent("Noordkaap");
|
||||
expect(result.length).toBe(5);
|
||||
|
||||
checkSubmissionsForStudentNoordkaap(result);
|
||||
});
|
||||
|
||||
it('should find all submissions for a certain assignment', async () => {
|
||||
const clazz = await classRepository.findById('id01');
|
||||
const assignment = await assignmentRepository.findByClassAndId(clazz!, 1);
|
||||
const result = await submissionRepository.findAllSubmissionsForAssignment(assignment!);
|
||||
|
||||
sortSubmissions(result);
|
||||
|
||||
expect(result).toHaveLength(5);
|
||||
|
||||
expect(result[0].learningObjectHruid).toBe("id01");
|
||||
expect(result[0].submissionNumber).toBe(1);
|
||||
|
||||
expect(result[1].learningObjectHruid).toBe("id02");
|
||||
expect(result[1].submissionNumber).toBe(1);
|
||||
|
||||
expect(result[2].learningObjectHruid).toBe("id02");
|
||||
expect(result[2].submissionNumber).toBe(2);
|
||||
|
||||
expect(result[3].learningObjectHruid).toBe("id03");
|
||||
expect(result[3].submissionNumber).toBe(1);
|
||||
|
||||
expect(result[4].learningObjectHruid).toBe("id03");
|
||||
expect(result[4].submissionNumber).toBe(2);
|
||||
|
||||
// But not submission7 (id01, submission number: 3), since it was submitted for an assignment
|
||||
|
||||
sortSubmissions(result);
|
||||
});
|
||||
|
||||
it('should not find a deleted submission', async () => {
|
||||
const id = new LearningObjectIdentifier('id01', Language.English, 1);
|
||||
await submissionRepository.deleteSubmissionByLearningObjectAndSubmissionNumber(id, 1);
|
||||
|
@ -68,3 +124,11 @@ describe('SubmissionRepository', () => {
|
|||
expect(submission).toBeNull();
|
||||
});
|
||||
});
|
||||
|
||||
function sortSubmissions(submissions: Submission[]) {
|
||||
submissions.sort((a, b) => {
|
||||
if (a.learningObjectHruid < b.learningObjectHruid) return -1;
|
||||
if (a.learningObjectHruid > b.learningObjectHruid) return 1;
|
||||
return a.submissionNumber! - b.submissionNumber!;
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue