mirror of
https://github.com/balena-os/balena-supervisor.git
synced 2025-01-12 16:02:57 +00:00
6217546894
This also updates code to use the default import syntax instead of `import * as` when the imported module exposes a default. This is needed with the latest typescript version. Change-type: patch
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
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);
|
|
});
|
|
});
|
|
});
|