From 6fba9ae0b570f243a6a2831903139ea4d084b3e3 Mon Sep 17 00:00:00 2001 From: Moriz Wahl Date: Thu, 15 Aug 2024 12:55:38 +0200 Subject: [PATCH] only meetings that exist in the database are returned by openTables (#1657) --- backend/jest.config.json | 2 +- .../src/graphql/resolvers/TableResolver.spec.ts | 16 +++------------- backend/src/graphql/resolvers/TableResolver.ts | 13 ++++++++----- 3 files changed, 12 insertions(+), 19 deletions(-) diff --git a/backend/jest.config.json b/backend/jest.config.json index 17d21ba679..7bc459e55d 100644 --- a/backend/jest.config.json +++ b/backend/jest.config.json @@ -15,7 +15,7 @@ "coverageThreshold": { "global": { "statements": 95, - "branches": 79, + "branches": 77, "functions": 96, "lines": 96 } diff --git a/backend/src/graphql/resolvers/TableResolver.spec.ts b/backend/src/graphql/resolvers/TableResolver.spec.ts index 5235953c34..1a84a117fd 100644 --- a/backend/src/graphql/resolvers/TableResolver.spec.ts +++ b/backend/src/graphql/resolvers/TableResolver.spec.ts @@ -1111,7 +1111,7 @@ describe('TableResolver', () => { }) }) - describe('no attendees', () => { + describe('meeting is not in database', () => { beforeEach(() => { getMeetingsMock.mockResolvedValue([ { @@ -1163,17 +1163,7 @@ describe('TableResolver', () => { kind: 'single', singleResult: { data: { - openTables: [ - { - // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment - id: expect.any(Number), - meetingName: 'Dreammall Entwicklung', - meetingID: 'Dreammall-Entwicklung', - participantCount: 0, - startTime: '1718189', - attendees: [], - }, - ], + openTables: [], }, errors: undefined, }, @@ -1335,7 +1325,7 @@ describe('TableResolver', () => { ]) }) - it('returns empty array', async () => { + it('returns table with all attendees', async () => { await expect( testServer.executeOperation( { diff --git a/backend/src/graphql/resolvers/TableResolver.ts b/backend/src/graphql/resolvers/TableResolver.ts index 5ed1923a5f..e89f6a2d8d 100644 --- a/backend/src/graphql/resolvers/TableResolver.ts +++ b/backend/src/graphql/resolvers/TableResolver.ts @@ -326,20 +326,23 @@ export class TableResolver { const openTablesFromOpenMeetings = async (meetings: MeetingInfo[]): Promise => { if (meetings.length) { - const dbMeetingsIdMap = await prisma.meeting.findMany({ + const dbMeetings = await prisma.meeting.findMany({ where: { meetingID: { in: meetings.map((m: MeetingInfo) => m.meetingID) }, }, select: { id: true, meetingID: true, - attendeePW: true, }, }) - return meetings.map((m: MeetingInfo) => { - const pw = dbMeetingsIdMap.find((pw) => pw.meetingID === m.meetingID) - return new OpenTable(m, pw?.id ? pw?.id : 0) + + const openTables: OpenTable[] = [] + + dbMeetings.forEach((ids) => { + const meeting = meetings.find((m) => ids.meetingID === m.meetingID) + if (meeting) openTables.push(new OpenTable(meeting, ids.id ? ids.id : 0)) }) + return openTables } return []