diff --git a/backend/e2etests/pay.test.after.js b/backend/e2etests/pay.test.after.js new file mode 100644 index 0000000..9265611 --- /dev/null +++ b/backend/e2etests/pay.test.after.js @@ -0,0 +1,46 @@ +import { expect } from "chai"; +import request from "supertest"; +import dotenv from "dotenv"; + +dotenv.config(); +const apiHost = process.env.API_HOST; +const endpoint = "pay"; + +describe(`${endpoint}`, function () { + describe("POST", function () { + it("fails to make a payment with invalid email address", async function () { + return request(apiHost) + .post(`${endpoint}`) + .set("Accept", "application/json") + .send({ + email: "wrong email", + tier: "new jobsika tier", + job_offer_id: "1", + }) + .expect(400) + .expect("Content-Type", "application/json; charset=utf-8") + .then((res) => { + expect(JSON.stringify(res.body)).contain("email field is invalid"); + }); + }); + + it("proceed with a payment", async function () { + return request(apiHost) + .post(`${endpoint}`) + .set("Accept", "application/json") + .send({ + email: "test@email.com", + tier: "new jobsika tier", + job_offer_id: "1", + }) + .expect(200) + .expect("Content-Type", "application/json; charset=utf-8") + .then((res) => { + expect(JSON.stringify(res.body)).contain( + "opencollective.com" + ); + }); + }); + + }); +}); diff --git a/backend/internal/handlers/pay_handler.go b/backend/internal/handlers/pay_handler.go index ba3f70c..26bb3af 100644 --- a/backend/internal/handlers/pay_handler.go +++ b/backend/internal/handlers/pay_handler.go @@ -4,6 +4,7 @@ import ( "errors" "fmt" "net/http" + "os" "strconv" "strings" "time" @@ -40,6 +41,14 @@ func PostPay(c *gin.Context) { return } + //We can't proceed with a payment on test mode as this will create unecessary + //payment on opencollective + if os.Getenv("TEST") == "true" { + //Send the link to the newly created opencollective tier to back to the client + c.JSON(http.StatusOK, gin.H{"tier_url": "https://opencollective.com/osscameroon/something-something"}) + return + } + //Create a new opencollective tier //The deletion should happen on the webhook or a day after created paymentClient, err := server.GetDefaultPaymentClient()