mirror of
https://github.com/brendan-ch/project-inter-server.git
synced 2026-04-17 07:50:31 +00:00
add tests for eta resolver on shuttle resolvers object
This commit is contained in:
104
test/resolvers/ShuttleResolverTests.test.ts
Normal file
104
test/resolvers/ShuttleResolverTests.test.ts
Normal file
@@ -0,0 +1,104 @@
|
||||
import { beforeEach, describe, expect, it } from "@jest/globals";
|
||||
import { ApolloServer } from "@apollo/server";
|
||||
import { ServerContext } from "../../src/ServerContext";
|
||||
import { UnoptimizedInMemoryRepository } from "../../src/repositories/UnoptimizedInMemoryRepository";
|
||||
import { readFileSync } from "fs";
|
||||
import { MergedResolvers } from "../../src/MergedResolvers";
|
||||
import { generateMockEtas, generateMockShuttles, generateMockSystems } from "../generators";
|
||||
import { IShuttle, ISystem } from "../../src/entities/entities";
|
||||
import assert = require("node:assert");
|
||||
|
||||
describe("ShuttleResolvers", () => {
|
||||
let testServer: ApolloServer<ServerContext>
|
||||
let repository: UnoptimizedInMemoryRepository;
|
||||
|
||||
beforeEach(async () => {
|
||||
const typeDefs = readFileSync("./schema.graphqls", "utf8");
|
||||
testServer = new ApolloServer({
|
||||
typeDefs,
|
||||
resolvers: MergedResolvers,
|
||||
});
|
||||
|
||||
repository = new UnoptimizedInMemoryRepository();
|
||||
});
|
||||
|
||||
describe("eta", () => {
|
||||
const query = `
|
||||
query GetShuttleETAs($systemId: ID!, $shuttleId: ID!, $stopId: ID!)
|
||||
{
|
||||
system(id: $systemId) {
|
||||
shuttle(id: $shuttleId) {
|
||||
eta(forStopId: $stopId) {
|
||||
secondsRemaining
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
`
|
||||
let mockSystem: ISystem;
|
||||
let mockShuttle: IShuttle;
|
||||
|
||||
beforeEach(async () => {
|
||||
// Arrange
|
||||
const mockSystems = generateMockSystems();
|
||||
mockSystem = mockSystems[0];
|
||||
mockSystem.id = "1";
|
||||
await repository.addOrUpdateSystem(mockSystem);
|
||||
|
||||
const mockShuttles = generateMockShuttles();
|
||||
mockShuttle = mockShuttles[0];
|
||||
mockShuttle.systemId = mockSystem.id;
|
||||
mockShuttle.id = "1";
|
||||
await repository.addOrUpdateShuttle(mockShuttle);
|
||||
});
|
||||
|
||||
it("returns ETA data for stop ID if exists", async () => {
|
||||
const etas = generateMockEtas();
|
||||
await Promise.all(etas.map(async (eta) => {
|
||||
eta.shuttleId = mockShuttle.id;
|
||||
await repository.addOrUpdateEta(eta);
|
||||
}));
|
||||
|
||||
const mockEta = etas[1];
|
||||
|
||||
// Act
|
||||
const response = await testServer.executeOperation({
|
||||
query,
|
||||
variables: {
|
||||
systemId: mockSystem.id,
|
||||
shuttleId: mockShuttle.id,
|
||||
stopId: mockEta.stopId,
|
||||
},
|
||||
}, {
|
||||
contextValue: {
|
||||
repository,
|
||||
},
|
||||
});
|
||||
|
||||
// Assert
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.shuttle.eta.secondsRemaining).toEqual(mockEta.secondsRemaining);
|
||||
});
|
||||
|
||||
it("returns null if it doesn't exist", async () => {
|
||||
const response = await testServer.executeOperation({
|
||||
query,
|
||||
variables: {
|
||||
systemId: mockSystem.id,
|
||||
shuttleId: mockShuttle.id,
|
||||
stopId: "nonexistent-stop",
|
||||
}
|
||||
}, {
|
||||
contextValue: {
|
||||
repository,
|
||||
}
|
||||
});
|
||||
|
||||
// Assert
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
expect((response.body.singleResult.data as any).system.shuttle.eta).toBeNull();
|
||||
});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user