mirror of
https://github.com/brendan-ch/project-inter-server.git
synced 2026-04-17 16:00:32 +00:00
Move all tests to subdirectories underneath code to be tested
This commit is contained in:
108
src/resolvers/__tests__/StopResolverTests.test.ts
Normal file
108
src/resolvers/__tests__/StopResolverTests.test.ts
Normal file
@@ -0,0 +1,108 @@
|
||||
import { beforeEach, describe, expect, it } from "@jest/globals";
|
||||
import {
|
||||
setupTestServerContext,
|
||||
setupTestServerHolder
|
||||
} from "../../../test/testHelpers/apolloTestServerHelpers";
|
||||
import { generateMockEtas, generateMockOrderedStops } from "../../../test/testHelpers/mockDataGenerators";
|
||||
import { IStop } from "../../entities/ShuttleRepositoryEntities";
|
||||
import { addMockStopToRepository } from "../../../test/testHelpers/repositorySetupHelpers";
|
||||
import assert = require("node:assert");
|
||||
|
||||
describe("StopResolvers", () => {
|
||||
const holder = setupTestServerHolder();
|
||||
const context = setupTestServerContext();
|
||||
|
||||
let mockStop: IStop;
|
||||
|
||||
beforeEach(async () => {
|
||||
mockStop = await addMockStopToRepository(context.systems[0].shuttleRepository, context.systems[0].id);
|
||||
})
|
||||
|
||||
async function getResponseForQuery(query: string) {
|
||||
return await holder.testServer.executeOperation({
|
||||
query,
|
||||
variables: {
|
||||
systemId: context.systems[0].id,
|
||||
stopId: mockStop.id,
|
||||
},
|
||||
}, {
|
||||
contextValue: context,
|
||||
});
|
||||
}
|
||||
|
||||
describe("orderedStops", () => {
|
||||
const query = `
|
||||
query GetOrderedStops($systemId: ID!, $stopId: ID!) {
|
||||
system(id: $systemId) {
|
||||
stop(id: $stopId) {
|
||||
orderedStops {
|
||||
routeId
|
||||
stopId
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
`
|
||||
|
||||
|
||||
it("returns ordered stops if they exist for the stop ID", async () => {
|
||||
let mockOrderedStops = generateMockOrderedStops();
|
||||
mockOrderedStops = mockOrderedStops.filter((orderedStop) => orderedStop.stopId === mockOrderedStops[0].stopId);
|
||||
await Promise.all(mockOrderedStops.map(async orderedStop => {
|
||||
orderedStop.stopId = mockStop.id;
|
||||
await context.systems[0].shuttleRepository.addOrUpdateOrderedStop(orderedStop);
|
||||
}));
|
||||
|
||||
const response = await getResponseForQuery(query);
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.stop.orderedStops).toHaveLength(mockOrderedStops.length);
|
||||
});
|
||||
|
||||
it("returns empty array if no ordered stops exist", async () => {
|
||||
const response = await getResponseForQuery(query);
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.stop.orderedStops).toHaveLength(0);
|
||||
});
|
||||
});
|
||||
|
||||
describe("etas", () => {
|
||||
const query = `
|
||||
query GetEtas($systemId: ID!, $stopId: ID!) {
|
||||
system(id: $systemId) {
|
||||
stop(id: $stopId) {
|
||||
etas {
|
||||
secondsRemaining
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
`
|
||||
|
||||
it("returns ETAs if they exist for the stop ID", async () => {
|
||||
let mockEtas = generateMockEtas();
|
||||
mockEtas = mockEtas.filter((eta) => eta.stopId === mockEtas[0].stopId);
|
||||
await Promise.all(mockEtas.map(async eta => {
|
||||
eta.stopId = mockStop.id;
|
||||
await context.systems[0].shuttleRepository.addOrUpdateEta(eta);
|
||||
}));
|
||||
|
||||
const response = await getResponseForQuery(query);
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.stop.etas).toHaveLength(mockEtas.length);
|
||||
});
|
||||
|
||||
it("returns empty array if no ETAs exist", async () => {
|
||||
const response = await getResponseForQuery(query);
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.stop.etas).toHaveLength(0);
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user