balena-supervisor/test/unit/device-api/middleware.spec.ts

52 lines
1.4 KiB
TypeScript
Raw Normal View History

import * as express from 'express';
import * as request from 'supertest';
import type { SinonStub } from 'sinon';
import { expect } from 'chai';
import * as middleware from '~/src/device-api/middleware';
import { UpdatesLockedError } from '~/lib/errors';
import log from '~/lib/supervisor-console';
describe('device-api/middleware', () => {
let app: express.Application;
describe('errors', () => {
before(() => {
app = express();
app.get('/locked', () => {
throw new UpdatesLockedError();
});
app.get('/errored', () => {
throw new Error();
});
app.use(middleware.errors);
});
it('responds with 423 if updates are locked', async () => {
await request(app).get('/locked').expect(423);
});
it('responds with 503 if any other error', async () => {
await request(app).get('/errored').expect(503);
});
});
describe('logging', () => {
before(() => {
app = express();
app.use(middleware.logging);
app.get('/', (_, res) => res.sendStatus(200));
app.post('/', (_, res) => res.sendStatus(304));
(log.api as SinonStub).reset();
});
it('logs API request methods and status codes', async () => {
await request(app).get('/');
expect((log.api as SinonStub).lastCall?.firstArg).to.match(/get.*200/i);
await request(app).post('/');
expect((log.api as SinonStub).lastCall?.firstArg).to.match(/post.*304/i);
});
});
});