Skip to content

Commit

Permalink
fix: Tidy up
Browse files Browse the repository at this point in the history
  • Loading branch information
DafyddLlyr committed Oct 3, 2023
1 parent 7279188 commit 9243b20
Show file tree
Hide file tree
Showing 3 changed files with 134 additions and 164 deletions.
18 changes: 10 additions & 8 deletions api.planx.uk/modules/webhooks/docs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -128,14 +128,16 @@ components:
content:
application/json:
schema:
type: object
properties:
message:
type: string
enum: ["success"]
event_id:
type: string
description: Internal Hasura ID of the generated event
type: array
items:
type: object
properties:
message:
type: string
enum: ["success"]
event_id:
type: string
description: Internal Hasura ID of the generated event
paths:
/webhooks/hasura/sendSlackNotification:
post:
Expand Down
6 changes: 2 additions & 4 deletions api.planx.uk/modules/webhooks/paymentRequestEvents/schema.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
import { z } from "zod";
import { ValidatedRequestHandler } from "../../../shared/middleware/validate";

// TODO: Make this better
type Response = [any, any] | any[];
import { ScheduledEventResponse } from "../../../hasura/metadata";

export const createPaymentEventSchema = z.object({
body: z.object({
Expand All @@ -19,5 +17,5 @@ export type CreatePaymentEvent = z.infer<

export type CreatePaymentEventController = ValidatedRequestHandler<
typeof createPaymentEventSchema,
Response
ScheduledEventResponse[]
>;
274 changes: 122 additions & 152 deletions api.planx.uk/modules/webhooks/sendNotification/index.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -210,166 +210,136 @@ describe("Send Slack notifications endpoint", () => {
expect(mockAdmin.session.find).toHaveBeenCalledTimes(1);
expect(response.body.message).toBe("Posted to Slack");
expect(response.body.data).toMatch(/abc123/);
});

it("adds a status to the Slack message for a disability exemption", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest
.fn()
.mockResolvedValue(mockSessionWithDisabilityExemption);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.data).toMatch(/[Exempt]/);
});
});

it("adds a status to the Slack message for a resubmission exemption", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest
.fn()
.mockResolvedValue(mockSessionWithResubmissionExemption);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.data).toMatch(/[Resubmission]/);
});
});

it("handles missing sessions", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest.fn().mockResolvedValueOnce(null);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockAdmin.session.find).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
});

it("adds an exemption status if there's no fee for the session", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest
.fn()
.mockResolvedValue(mockSessionWithoutFee);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.data).toMatch(/abc123/);
expect(response.body.data).toMatch(/test-council/);
expect(response.body.data).toMatch(/[Exempt]/);
});
});

it("handles missing sessions", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest.fn().mockResolvedValueOnce(null);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockAdmin.session.find).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
});

it("returns error when Slack fails", async () => {
process.env.APP_ENVIRONMENT = "production";
mockSend.mockRejectedValue("Fail!");

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
it("adds a status to the Slack message for a disability exemption", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest
.fn()
.mockResolvedValue(mockSessionWithDisabilityExemption);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.data).toMatch(/[Exempt]/);
});
});

it("adds a status to the Slack message for a resubmission exemption", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest
.fn()
.mockResolvedValue(mockSessionWithResubmissionExemption);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.data).toMatch(/[Resubmission]/);
});
});

it("handles missing sessions", async () => {
process.env.APP_ENVIRONMENT = "production";
mockAdmin.session.find = jest.fn().mockResolvedValueOnce(null);

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockAdmin.session.find).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
});

it("returns error when Slack fails", async () => {
process.env.APP_ENVIRONMENT = "production";
mockSend.mockRejectedValue("Fail!");

await post(ENDPOINT)
.query({ type: "uniform-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
});
});
});

describe("Email notifications", () => {
const body: EmailBody = {
event: {
data: {
new: {
session_id: "abc123",
team_slug: "testTeam",
request: {
personalisation: {
serviceName: "testServiceName",
describe("Email notifications", () => {
const body: EmailBody = {
event: {
data: {
new: {
session_id: "abc123",
team_slug: "testTeam",
request: {
personalisation: {
serviceName: "testServiceName",
},
},
},
},
},
},
};

it("skips the staging environment", async () => {
process.env.APP_ENVIRONMENT = "staging";
await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.message).toMatch(/skipping Slack notification/);
});
});

it("posts to Slack on success", async () => {
process.env.APP_ENVIRONMENT = "production";

await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(SlackNotify).toHaveBeenCalledWith(
process.env.SLACK_WEBHOOK_URL,
);
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.message).toBe("Posted to Slack");
expect(response.body.data).toMatch(/abc123/);
expect(response.body.data).toMatch(/testTeam/);
expect(response.body.data).toMatch(/testServiceName/);
});
});

it("returns error when Slack fails", async () => {
process.env.APP_ENVIRONMENT = "production";
mockSend.mockRejectedValue("Fail!");

await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
};

it("skips the staging environment", async () => {
process.env.APP_ENVIRONMENT = "staging";
await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(response.body.message).toMatch(
/skipping Slack notification/,
);
});
});

it("posts to Slack on success", async () => {
process.env.APP_ENVIRONMENT = "production";

await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(200)
.then((response) => {
expect(SlackNotify).toHaveBeenCalledWith(
process.env.SLACK_WEBHOOK_URL,
);
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.message).toBe("Posted to Slack");
expect(response.body.data).toMatch(/abc123/);
expect(response.body.data).toMatch(/testTeam/);
expect(response.body.data).toMatch(/testServiceName/);
});
});

it("returns error when Slack fails", async () => {
process.env.APP_ENVIRONMENT = "production";
mockSend.mockRejectedValue("Fail!");

await post(ENDPOINT)
.query({ type: "email-submission" })
.set({ Authorization: process.env.HASURA_PLANX_API_KEY })
.send(body)
.expect(500)
.then((response) => {
expect(mockSend).toHaveBeenCalledTimes(1);
expect(response.body.error).toMatch(/Failed to send/);
});
});
});
});
});

0 comments on commit 9243b20

Please sign in to comment.