mirror of
https://github.com/brendan-ch/project-inter-server.git
synced 2026-04-17 07:50:31 +00:00
Add orderedStops property to the Route type
This commit is contained in:
@@ -43,8 +43,21 @@ export const RouteResolvers: Resolvers<ServerContext> = {
|
||||
routeId: parent.id,
|
||||
route: parent,
|
||||
systemId: system.id,
|
||||
updatedTimeMs: orderedStop.updatedTime,
|
||||
updatedTime: orderedStop.updatedTime,
|
||||
}
|
||||
},
|
||||
orderedStops: async (parent, args, contextValue, _info) => {
|
||||
const system = contextValue.findSystemById(parent.systemId);
|
||||
if (!system) return null;
|
||||
|
||||
const orderedStops = await system.shuttleRepository.getOrderedStopsByRouteId(parent.id);
|
||||
return orderedStops.map(({ routeId, stopId, position, systemId, updatedTime }) => ({
|
||||
routeId,
|
||||
stopId,
|
||||
position,
|
||||
systemId,
|
||||
updatedTime,
|
||||
}));
|
||||
}
|
||||
},
|
||||
}
|
||||
|
||||
@@ -144,4 +144,60 @@ describe("RouteResolvers", () => {
|
||||
expect(orderedStop).toBeNull();
|
||||
});
|
||||
});
|
||||
|
||||
describe("orderedStops", () => {
|
||||
async function getResponseForOrderedStopsQuery() {
|
||||
const query = `
|
||||
query GetRouteOrderedStop($systemId: ID!, $routeId: ID!) {
|
||||
system(id: $systemId) {
|
||||
route(id: $routeId) {
|
||||
orderedStops {
|
||||
stopId
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
`;
|
||||
|
||||
return await holder.testServer.executeOperation({
|
||||
query,
|
||||
variables: {
|
||||
systemId: mockSystem.id,
|
||||
routeId: mockRoute.id,
|
||||
},
|
||||
}, {
|
||||
contextValue: context,
|
||||
});
|
||||
}
|
||||
|
||||
it("returns ordered stops using provided data", async () => {
|
||||
let orderedStops = generateMockOrderedStops();
|
||||
orderedStops = orderedStops.filter((stop) => stop.routeId === orderedStops[0].routeId);
|
||||
|
||||
await Promise.all(orderedStops.map(async (stop) => {
|
||||
await context.systems[0].shuttleRepository.addOrUpdateOrderedStop(stop);
|
||||
}))
|
||||
|
||||
const response = await getResponseForOrderedStopsQuery();
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
|
||||
const retrievedOrderedStops = (response.body.singleResult.data as any).system.route.orderedStops;
|
||||
expect(retrievedOrderedStops).toHaveLength(orderedStops.length);
|
||||
retrievedOrderedStops.map((retrievedStop: any) => {
|
||||
expect(orderedStops.find((originalStop) => originalStop.stopId === retrievedStop.stopId)).not.toBeUndefined();
|
||||
});
|
||||
});
|
||||
|
||||
it("returns empty array if there are no ordered stops", async () => {
|
||||
const response = await getResponseForOrderedStopsQuery();
|
||||
|
||||
assert(response.body.kind === "single");
|
||||
expect(response.body.singleResult.errors).toBeUndefined();
|
||||
|
||||
const retrievedOrderedStops = (response.body.singleResult.data as any).system.route.orderedStops;
|
||||
expect(retrievedOrderedStops).toHaveLength(0);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user