import express from 'express'; import 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); }); }); });