From 43120fed59df9b905fd816a182929d9057cd130b Mon Sep 17 00:00:00 2001 From: Max Isom Date: Sat, 26 Oct 2024 16:49:49 -0700 Subject: [PATCH] Don't return duplicates on /unique --- src/courses/courses.service.ts | 2 +- src/tests/courses/courses.service.test.ts | 31 +++++++++++++++++++++-- 2 files changed, 30 insertions(+), 3 deletions(-) diff --git a/src/courses/courses.service.ts b/src/courses/courses.service.ts index 993913e..a2ad458 100644 --- a/src/courses/courses.service.ts +++ b/src/courses/courses.service.ts @@ -54,7 +54,7 @@ export class CoursesService { ))); } - return db.sql`SELECT *, to_json("offered") as offered FROM ${'Course'} WHERE ${where} ORDER BY ${'id'} ASC`.compile(); + return db.sql`SELECT DISTINCT ON (subject, crse) *, to_json("offered") as offered FROM ${'Course'} WHERE ${where} ORDER BY ${'subject'} ASC, ${'crse'} ASC, ${'year'} DESC, ${'semester'} DESC`.compile(); } getFirstCourseZapatosQuery(parameters?: FindFirstCourseParameters) { diff --git a/src/tests/courses/courses.service.test.ts b/src/tests/courses/courses.service.test.ts index 4b1dc59..a8c72eb 100644 --- a/src/tests/courses/courses.service.test.ts +++ b/src/tests/courses/courses.service.test.ts @@ -97,13 +97,40 @@ test.serial('returns unique courses (by CRSE & subject)', async t => { }); const allUniqueCoursesQuery = await service.getUniqueCoursesQuery(pool); - t.is((await pool.query(allUniqueCoursesQuery)).rowCount, 3); + t.is((await pool.query(allUniqueCoursesQuery)).rowCount, 2); const fallUniqueCoursesQuery = await service.getUniqueCoursesQuery(pool, {semester: Semester.FALL} as any); t.is((await pool.query(fallUniqueCoursesQuery)).rowCount, 2); const uniqueCoursesAfter2000Query = await service.getUniqueCoursesQuery(pool, {startYear: 2000} as any); - t.is((await pool.query(uniqueCoursesAfter2000Query)).rowCount, 2); + t.is((await pool.query(uniqueCoursesAfter2000Query)).rowCount, 1); +}); + +test.serial('getUniqueCourses does not return duplicate courses', async t => { + const {service, prisma, pool} = await getTestService(CoursesService, { + seedCourses: true + }); + + const {id, ...courseWithoutId} = await prisma.course.findFirstOrThrow(); + t.is(courseWithoutId.year, 2000); + + await prisma.course.createMany({ + data: [ + // Create same course in different term... + { + ...courseWithoutId, + semester: Semester.SUMMER, + year: 2001 + }, + ] + }); + + const allUniqueCoursesQuery = await service.getUniqueCoursesQuery(pool, {startYear: 1999} as any); + const results = await pool.query(allUniqueCoursesQuery); + + const cs1110Results = results.rows.filter(row => row.subject === 'CS' && row.crse === '1110'); + t.is(cs1110Results.length, 1); // Should not be duplicate results + t.is(cs1110Results[0].year, 2001);// Contains the latest version }); test.serial('returns unique courses with updatedSince', async t => {