-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Adds aws-sdk-client-mock for testing
- Loading branch information
Showing
6 changed files
with
129 additions
and
90 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,104 +2,118 @@ const chai = require("chai"); | |
const expect = chai.expect; | ||
chai.use(require("chai-http")); | ||
const ApiToken = requireSource("api/api-token"); | ||
const { mockClient } = require("aws-sdk-client-mock"); | ||
const { S3Client, PutObjectCommand } = require("@aws-sdk/client-s3"); | ||
|
||
const { handler } = requireSource("handlers/post-chat-feedback"); | ||
const { handler, uploadToS3 } = requireSource("handlers/post-chat-feedback"); | ||
|
||
describe("Chat feedback route", () => { | ||
const s3Mock = mockClient(S3Client); | ||
helpers.saveEnvironment(); | ||
|
||
beforeEach(() => { | ||
process.env.API_TOKEN_SECRET = "abc123"; | ||
process.env.API_TOKEN_NAME = "dcapiTEST"; | ||
process.env.MEDIACONVERT_DESTINATION_BUCKET = "delete-me"; | ||
s3Mock.reset(); | ||
}); | ||
|
||
it("should return 401 if user is not logged in", async () => { | ||
let requestBody = JSON.stringify({ | ||
sentiment: "positive", | ||
context: { | ||
ref: "5a6e1d76-0d4c-43c5-ab2c-4687112ba102", | ||
question: "What is the capital of France?", | ||
answer: "Paris", | ||
source_documents: ["https://doc1", "https://doc2"], | ||
}, | ||
feedback: { | ||
options: ["option1"], | ||
text: "Great answer!", | ||
email: "[email protected]", | ||
}, | ||
describe("Form POST submission", () => { | ||
beforeEach(() => { | ||
s3Mock.on(PutObjectCommand).resolves({}); | ||
}); | ||
|
||
const event = helpers | ||
.mockEvent("POST", "/chat-feedback") | ||
.body(requestBody) | ||
.render(); | ||
const response = await handler(event); | ||
expect(response.statusCode).to.equal(401); | ||
expect(response.body).to.equal("Authorization Required"); | ||
}); | ||
|
||
it("should fail if request body is invalid", async () => { | ||
const token = new ApiToken().user({ uid: "abc123" }).sign(); | ||
it("should return 401 if user is not logged in", async () => { | ||
let requestBody = JSON.stringify({ | ||
sentiment: "positive", | ||
context: { | ||
ref: "5a6e1d76-0d4c-43c5-ab2c-4687112ba102", | ||
question: "What is the capital of France?", | ||
answer: "Paris", | ||
source_documents: ["https://doc1", "https://doc2"], | ||
}, | ||
feedback: { | ||
options: ["option1"], | ||
text: "Great answer!", | ||
email: "[email protected]", | ||
}, | ||
}); | ||
|
||
let requestBody = JSON.stringify({ | ||
sentiment: "neutral", | ||
context: { | ||
ref: "3fc98004-995b-4491-94fd-aea48a0363ba", | ||
question: "What is the capital of France?", | ||
answer: "Paris", | ||
source_documents: ["https://doc1", "https://doc2"], | ||
}, | ||
feedback: { | ||
options: ["option1"], | ||
text: "Great answer!", | ||
email: "[email protected]", | ||
}, | ||
const event = helpers | ||
.mockEvent("POST", "/chat-feedback") | ||
.body(requestBody) | ||
.render(); | ||
const response = await handler(event); | ||
expect(response.statusCode).to.equal(401); | ||
expect(response.body).to.equal("Authorization Required"); | ||
}); | ||
|
||
const event = helpers | ||
.mockEvent("POST", "/chat-feedback") | ||
.body(requestBody) | ||
.headers({ | ||
Cookie: `${process.env.API_TOKEN_NAME}=${token}`, | ||
}) | ||
.render(); | ||
const response = await handler(event); | ||
expect(response.statusCode).to.equal(400); | ||
expect(response.body).to.equal( | ||
`"sentiment is not one of enum values: positive,negative"` | ||
); | ||
}); | ||
it("should fail if request body is invalid", async () => { | ||
const token = new ApiToken().user({ uid: "abc123" }).sign(); | ||
|
||
// it("should upload to S3 and return 200 on valid input", async () => { | ||
// const token = new ApiToken().user({ uid: "abc123" }).sign(); | ||
let requestBody = JSON.stringify({ | ||
sentiment: "neutral", | ||
context: { | ||
ref: "3fc98004-995b-4491-94fd-aea48a0363ba", | ||
question: "What is the capital of France?", | ||
answer: "Paris", | ||
source_documents: ["https://doc1", "https://doc2"], | ||
}, | ||
feedback: { | ||
options: ["option1"], | ||
text: "Great answer!", | ||
email: "[email protected]", | ||
}, | ||
}); | ||
|
||
// const requestBody = JSON.stringify({ | ||
// sentiment: "negative", | ||
// context: { | ||
// ref: "e6005d7c-e03b-43f7-94a3-e327b4b5a538", | ||
// question: "What is the capital of France?", | ||
// answer: "Rome", | ||
// source_documents: ["https://doc1", "https://doc2"], | ||
// }, | ||
// feedback: { | ||
// options: ["option1"], | ||
// text: "Bad answer!", | ||
// email: "[email protected]" | ||
// } | ||
// }); | ||
const event = helpers | ||
.mockEvent("POST", "/chat-feedback") | ||
.body(requestBody) | ||
.headers({ | ||
Cookie: `${process.env.API_TOKEN_NAME}=${token}`, | ||
}) | ||
.render(); | ||
const response = await handler(event); | ||
expect(response.statusCode).to.equal(400); | ||
expect(response.body).to.equal( | ||
`"sentiment is not one of enum values: positive,negative"` | ||
); | ||
}); | ||
|
||
// nock(`https://${process.env.MEDIACONVERT_DESTINATION_BUCKET}.s3.amazonaws.com`).put('/1001').reply(200); | ||
describe("Saving feedback", () => { | ||
xit("should upload to S3 and return 200", async () => { | ||
const token = new ApiToken().user({ uid: "abc123" }).sign(); | ||
|
||
// const event = helpers | ||
// .mockEvent("POST", "/chat-feedback") | ||
// .body(requestBody) | ||
// .headers({ | ||
// Cookie: `${process.env.API_TOKEN_NAME}=${token}`, | ||
// }) | ||
// .render(); | ||
// const response = await handler(event); | ||
// expect(response.statusCode).to.equal(200); | ||
// expect(response.body).to.equal('{"message":"Feedback received. Thank you."}'); | ||
// }); | ||
const requestBody = JSON.stringify({ | ||
sentiment: "negative", | ||
context: { | ||
ref: "e6005d7c-e03b-43f7-94a3-e327b4b5a538", | ||
question: "What is the capital of France?", | ||
answer: "Rome", | ||
source_documents: ["https://doc1", "https://doc2"], | ||
}, | ||
feedback: { | ||
options: ["option1"], | ||
text: "Bad answer!", | ||
email: "[email protected]", | ||
}, | ||
}); | ||
|
||
const event = helpers | ||
.mockEvent("POST", "/chat-feedback") | ||
.body(requestBody) | ||
.headers({ | ||
Cookie: `${process.env.API_TOKEN_NAME}=${token}`, | ||
}) | ||
.render(); | ||
const response = await handler(event); | ||
expect(response.statusCode).to.equal(200); | ||
expect(response.body).to.equal( | ||
'{"message":"Feedback received. Thank you."}' | ||
); | ||
expect(s3Mock.calls(PutObjectCommand).length).to.equal(1); | ||
expect(s3Mock.calls(0).args[0].input).lessThanOrEqual({ | ||
Bucket: process.env.MEDIACONVERT_DESTINATION_BUCKET, | ||
Key: "negative/e6005d7c-e03b-43f7-94a3-e327b4b5a538", | ||
}); | ||
}); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters