2022-10-25 02:03:48 +00:00
|
|
|
import * as express from 'express';
|
|
|
|
import * as request from 'supertest';
|
2024-02-29 22:00:39 +00:00
|
|
|
import type { SinonStub } from 'sinon';
|
2022-10-25 02:03:48 +00:00
|
|
|
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();
|
2024-02-29 22:00:39 +00:00
|
|
|
app.get('/locked', () => {
|
2022-10-25 02:03:48 +00:00
|
|
|
throw new UpdatesLockedError();
|
|
|
|
});
|
2024-02-29 22:00:39 +00:00
|
|
|
app.get('/errored', () => {
|
2022-10-25 02:03:48 +00:00
|
|
|
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);
|
2024-02-29 22:00:39 +00:00
|
|
|
app.get('/', (_, res) => res.sendStatus(200));
|
|
|
|
app.post('/', (_, res) => res.sendStatus(304));
|
2022-10-25 02:03:48 +00:00
|
|
|
(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);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|