mirror of
https://github.com/brendan-ch/project-inter-server.git
synced 2026-04-17 07:50:31 +00:00
add test case for eta stop
This commit is contained in:
@@ -1,10 +1,12 @@
|
|||||||
import { beforeEach, describe, it } from "@jest/globals";
|
import { beforeEach, describe, expect, it } from "@jest/globals";
|
||||||
import { ApolloServer } from "@apollo/server";
|
import { ApolloServer } from "@apollo/server";
|
||||||
import { UnoptimizedInMemoryRepository } from "../../src/repositories/UnoptimizedInMemoryRepository";
|
import { UnoptimizedInMemoryRepository } from "../../src/repositories/UnoptimizedInMemoryRepository";
|
||||||
import { setUpTestServer } from "../testHelpers/apolloSetupHelpers";
|
import { setUpTestServer } from "../testHelpers/apolloSetupHelpers";
|
||||||
import { ServerContext } from "../../src/ServerContext";
|
import { ServerContext } from "../../src/ServerContext";
|
||||||
import { ISystem } from "../../src/entities/entities";
|
import { IShuttle, ISystem } from "../../src/entities/entities";
|
||||||
import { addMockSystemToRepository } from "../testHelpers/repositorySetupHelpers";
|
import { addMockSystemToRepository } from "../testHelpers/repositorySetupHelpers";
|
||||||
|
import { generateMockEtas, generateMockShuttles, generateMockStops } from "../generators";
|
||||||
|
import assert = require("node:assert");
|
||||||
|
|
||||||
describe("EtaResolvers", () => {
|
describe("EtaResolvers", () => {
|
||||||
let testServer: ApolloServer<ServerContext>;
|
let testServer: ApolloServer<ServerContext>;
|
||||||
@@ -16,10 +18,16 @@ describe("EtaResolvers", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
let mockSystem: ISystem;
|
let mockSystem: ISystem;
|
||||||
|
let mockShuttle: IShuttle;
|
||||||
|
|
||||||
beforeEach(async () => {
|
beforeEach(async () => {
|
||||||
mockSystem = await addMockSystemToRepository(repository);
|
mockSystem = await addMockSystemToRepository(repository);
|
||||||
})
|
|
||||||
|
const mockShuttles = generateMockShuttles();
|
||||||
|
mockShuttle = mockShuttles[0];
|
||||||
|
mockShuttle.systemId = mockSystem.id;
|
||||||
|
await repository.addOrUpdateShuttle(mockShuttle);
|
||||||
|
});
|
||||||
|
|
||||||
describe("stop", () => {
|
describe("stop", () => {
|
||||||
const query = `
|
const query = `
|
||||||
@@ -37,7 +45,35 @@ describe("EtaResolvers", () => {
|
|||||||
`;
|
`;
|
||||||
|
|
||||||
it("returns the associated stop if it exists", async () => {
|
it("returns the associated stop if it exists", async () => {
|
||||||
|
const stops = generateMockStops();
|
||||||
|
const stop = stops[0];
|
||||||
|
stop.systemId = mockSystem.id;
|
||||||
|
|
||||||
|
const etas = generateMockEtas();
|
||||||
|
await Promise.all(etas.map(async (eta) => {
|
||||||
|
eta.stopId = stop.id;
|
||||||
|
await repository.addOrUpdateEta(eta);
|
||||||
|
}));
|
||||||
|
const expectedEta = etas[0];
|
||||||
|
|
||||||
|
await repository.addOrUpdateStop(stop);
|
||||||
|
|
||||||
|
const response = await testServer.executeOperation({
|
||||||
|
query,
|
||||||
|
variables: {
|
||||||
|
systemId: mockSystem.id,
|
||||||
|
shuttleId: mockShuttle.id,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
contextValue: {
|
||||||
|
repository,
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
assert(response.body.kind === "single");
|
||||||
|
expect(response.body.singleResult.errors).toBeUndefined();
|
||||||
|
const eta = (response.body.singleResult.data?.system as any).shuttle.etas[0];
|
||||||
|
expect(eta.stop.id).toEqual(expectedEta.stopId);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user