mirror of
https://github.com/bluewave-labs/Checkmate.git
synced 2026-01-01 23:29:39 -06:00
380 lines
9.7 KiB
JavaScript
Executable File
380 lines
9.7 KiB
JavaScript
Executable File
import {
|
|
createCheck,
|
|
getChecks,
|
|
getTeamChecks,
|
|
deleteChecks,
|
|
deleteChecksByTeamId,
|
|
updateChecksTTL,
|
|
} from "../../controllers/checkController.js";
|
|
import jwt from "jsonwebtoken";
|
|
import { errorMessages, successMessages } from "../../utils/messages.js";
|
|
import sinon from "sinon";
|
|
describe("Check Controller - createCheck", function () {
|
|
let req, res, next, handleError;
|
|
|
|
beforeEach(function () {
|
|
req = {
|
|
params: {},
|
|
body: {},
|
|
db: {
|
|
createCheck: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
handleError = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore(); // Restore the original methods after each test
|
|
});
|
|
|
|
it("should reject with a validation if params are invalid", async function () {
|
|
await createCheck(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should reject with a validation error if body is invalid", async function () {
|
|
req.params = {
|
|
monitorId: "monitorId",
|
|
};
|
|
await createCheck(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.params = {
|
|
monitorId: "monitorId",
|
|
};
|
|
req.body = {
|
|
monitorId: "monitorId",
|
|
status: true,
|
|
responseTime: 100,
|
|
statusCode: 200,
|
|
message: "message",
|
|
};
|
|
req.db.createCheck.rejects(new Error("error"));
|
|
await createCheck(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
});
|
|
|
|
it("should return a success message if check is created", async function () {
|
|
req.params = {
|
|
monitorId: "monitorId",
|
|
};
|
|
req.db.createCheck.resolves({ id: "123" });
|
|
req.body = {
|
|
monitorId: "monitorId",
|
|
status: true,
|
|
responseTime: 100,
|
|
statusCode: 200,
|
|
message: "message",
|
|
};
|
|
await createCheck(req, res, next);
|
|
expect(res.status.calledWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_CREATE,
|
|
data: { id: "123" },
|
|
})
|
|
).to.be.true;
|
|
expect(next.notCalled).to.be.true;
|
|
});
|
|
});
|
|
|
|
describe("Check Controller - getChecks", function () {
|
|
let req, res, next;
|
|
|
|
beforeEach(function () {
|
|
req = {
|
|
params: {},
|
|
query: {},
|
|
db: {
|
|
getChecks: sinon.stub(),
|
|
getChecksCount: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it("should reject with a validation error if params are invalid", async function () {
|
|
await getChecks(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should return a success message if checks are found", async function () {
|
|
req.params = {
|
|
monitorId: "monitorId",
|
|
};
|
|
req.db.getChecks.resolves([{ id: "123" }]);
|
|
req.db.getChecksCount.resolves(1);
|
|
await getChecks(req, res, next);
|
|
expect(res.status.calledWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_GET,
|
|
data: { checksCount: 1, checks: [{ id: "123" }] },
|
|
})
|
|
).to.be.true;
|
|
expect(next.notCalled).to.be.true;
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.params = {
|
|
monitorId: "monitorId",
|
|
};
|
|
req.db.getChecks.rejects(new Error("error"));
|
|
await getChecks(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
});
|
|
});
|
|
|
|
describe("Check Controller - getTeamChecks", function () {
|
|
let req, res, next;
|
|
|
|
beforeEach(function () {
|
|
req = {
|
|
params: {},
|
|
query: {},
|
|
db: {
|
|
getTeamChecks: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it("should reject with a validation error if params are invalid", async function () {
|
|
await getTeamChecks(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should return 200 and check data on successful validation and data retrieval", async function () {
|
|
req.params = { teamId: "1" };
|
|
const checkData = [{ id: 1, name: "Check 1" }];
|
|
req.db.getTeamChecks.resolves(checkData);
|
|
|
|
await getTeamChecks(req, res, next);
|
|
expect(req.db.getTeamChecks.calledOnceWith(req)).to.be.true;
|
|
expect(res.status.calledOnceWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledOnceWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_GET,
|
|
data: checkData,
|
|
})
|
|
).to.be.true;
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.params = { teamId: "1" };
|
|
req.db.getTeamChecks.rejects(new Error("Retrieval Error"));
|
|
await getTeamChecks(req, res, next);
|
|
expect(req.db.getTeamChecks.calledOnceWith(req)).to.be.true;
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(res.status.notCalled).to.be.true;
|
|
expect(res.json.notCalled).to.be.true;
|
|
});
|
|
});
|
|
|
|
describe("Check Controller - deleteChecks", function () {
|
|
let req, res, next;
|
|
|
|
beforeEach(function () {
|
|
req = {
|
|
params: {},
|
|
db: {
|
|
deleteChecks: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it("should reject with an error if param validation fails", async function () {
|
|
await deleteChecks(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.params = { monitorId: "1" };
|
|
req.db.deleteChecks.rejects(new Error("Deletion Error"));
|
|
await deleteChecks(req, res, next);
|
|
expect(req.db.deleteChecks.calledOnceWith(req.params.monitorId)).to.be.true;
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(res.status.notCalled).to.be.true;
|
|
expect(res.json.notCalled).to.be.true;
|
|
});
|
|
|
|
it("should delete checks successfully", async function () {
|
|
req.params = { monitorId: "123" };
|
|
req.db.deleteChecks.resolves(1);
|
|
await deleteChecks(req, res, next);
|
|
expect(req.db.deleteChecks.calledOnceWith(req.params.monitorId)).to.be.true;
|
|
expect(res.status.calledOnceWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledOnceWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_DELETE,
|
|
data: { deletedCount: 1 },
|
|
})
|
|
).to.be.true;
|
|
});
|
|
});
|
|
|
|
describe("Check Controller - deleteChecksByTeamId", function () {
|
|
let req, res, next;
|
|
|
|
beforeEach(function () {
|
|
req = {
|
|
params: {},
|
|
db: {
|
|
deleteChecksByTeamId: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it("should reject with an error if param validation fails", async function () {
|
|
await deleteChecksByTeamId(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.params = { teamId: "1" };
|
|
req.db.deleteChecksByTeamId.rejects(new Error("Deletion Error"));
|
|
await deleteChecksByTeamId(req, res, next);
|
|
expect(req.db.deleteChecksByTeamId.calledOnceWith(req.params.teamId)).to.be.true;
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(res.status.notCalled).to.be.true;
|
|
expect(res.json.notCalled).to.be.true;
|
|
});
|
|
|
|
it("should delete checks successfully", async function () {
|
|
req.params = { teamId: "123" };
|
|
req.db.deleteChecksByTeamId.resolves(1);
|
|
await deleteChecksByTeamId(req, res, next);
|
|
expect(req.db.deleteChecksByTeamId.calledOnceWith(req.params.teamId)).to.be.true;
|
|
expect(res.status.calledOnceWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledOnceWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_DELETE,
|
|
data: { deletedCount: 1 },
|
|
})
|
|
).to.be.true;
|
|
});
|
|
});
|
|
|
|
describe("Check Controller - updateCheckTTL", function () {
|
|
let stub, req, res, next;
|
|
|
|
beforeEach(function () {
|
|
stub = sinon.stub(jwt, "verify").callsFake(() => {
|
|
return { teamId: "123" };
|
|
});
|
|
|
|
req = {
|
|
body: {},
|
|
headers: { authorization: "Bearer token" },
|
|
settingsService: {
|
|
getSettings: sinon.stub().returns({ jwtSecret: "my_secret" }),
|
|
},
|
|
db: {
|
|
updateChecksTTL: sinon.stub(),
|
|
},
|
|
};
|
|
res = {
|
|
status: sinon.stub().returnsThis(),
|
|
json: sinon.stub(),
|
|
};
|
|
next = sinon.stub();
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
stub.restore();
|
|
});
|
|
|
|
it("should reject if body validation fails", async function () {
|
|
await updateChecksTTL(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
expect(next.firstCall.args[0].status).to.equal(422);
|
|
});
|
|
|
|
it("should throw a JwtError if verification fails", async function () {
|
|
stub.restore();
|
|
req.body = {
|
|
ttl: 1,
|
|
};
|
|
await updateChecksTTL(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.instanceOf(jwt.JsonWebTokenError);
|
|
});
|
|
|
|
it("should call next with error if data retrieval fails", async function () {
|
|
req.body = {
|
|
ttl: 1,
|
|
};
|
|
req.db.updateChecksTTL.rejects(new Error("Update Error"));
|
|
await updateChecksTTL(req, res, next);
|
|
expect(next.firstCall.args[0]).to.be.an("error");
|
|
});
|
|
|
|
it("should update TTL successfully", async function () {
|
|
req.body = {
|
|
ttl: 1,
|
|
};
|
|
req.db.updateChecksTTL.resolves();
|
|
await updateChecksTTL(req, res, next);
|
|
expect(req.db.updateChecksTTL.calledOnceWith("123", 1 * 86400)).to.be.true;
|
|
expect(res.status.calledOnceWith(200)).to.be.true;
|
|
expect(
|
|
res.json.calledOnceWith({
|
|
success: true,
|
|
msg: successMessages.CHECK_UPDATE_TTL,
|
|
})
|
|
).to.be.true;
|
|
});
|
|
});
|