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:
@@ -52,6 +52,7 @@ type Route {
|
|||||||
id: ID!
|
id: ID!
|
||||||
systemId: ID!
|
systemId: ID!
|
||||||
orderedStop(forStopId: ID): OrderedStop
|
orderedStop(forStopId: ID): OrderedStop
|
||||||
|
orderedStops: [OrderedStop]
|
||||||
shuttles: [Shuttle!]
|
shuttles: [Shuttle!]
|
||||||
polylineCoordinates: [Coordinates!]!
|
polylineCoordinates: [Coordinates!]!
|
||||||
color: String!
|
color: String!
|
||||||
|
|||||||
@@ -43,8 +43,21 @@ export const RouteResolvers: Resolvers<ServerContext> = {
|
|||||||
routeId: parent.id,
|
routeId: parent.id,
|
||||||
route: parent,
|
route: parent,
|
||||||
systemId: system.id,
|
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();
|
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