pad.libre-service.eu-etherpad/src/tests/backend/specs/api/api.js

60 lines
1.6 KiB
JavaScript
Raw Normal View History

'use strict';
2020-03-29 20:56:49 +02:00
/**
* API specs
*
* Tests for generic overarching HTTP API related features not related to any
* specific part of the data model or domain. For example: tests for versioning
* and openapi definitions.
*/
const common = require('../../common');
2021-02-03 13:08:43 +01:00
const validateOpenAPI = require('openapi-schema-validation').validate;
2020-03-29 20:56:49 +02:00
let agent;
const apiKey = common.apiKey;
let apiVersion = 1;
2020-03-29 20:56:49 +02:00
const makeid = () => {
let text = '';
const possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for (let i = 0; i < 5; i++) {
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
};
const testPadId = makeid();
2020-03-29 20:56:49 +02:00
const endPoint = (point) => `/api/${apiVersion}/${point}?apikey=${apiKey}`;
describe(__filename, function () {
before(async function () { agent = await common.init(); });
2021-02-13 01:01:46 +01:00
it('can obtain API version', async function () {
await agent.get('/api/')
.expect(200)
.expect((res) => {
apiVersion = res.body.currentVersion;
if (!res.body.currentVersion) throw new Error('No version set in API');
return;
2021-02-13 01:01:46 +01:00
});
2020-03-29 20:56:49 +02:00
});
2021-02-13 01:01:46 +01:00
it('can obtain valid openapi definition document', async function () {
2021-02-13 20:00:06 +01:00
this.timeout(15000);
2021-02-13 01:01:46 +01:00
await agent.get('/api/openapi.json')
.expect(200)
.expect((res) => {
const {valid, errors} = validateOpenAPI(res.body, 3);
if (!valid) {
const prettyErrors = JSON.stringify(errors, null, 2);
throw new Error(`Document is not valid OpenAPI. ${errors.length} ` +
`validation errors:\n${prettyErrors}`);
}
2021-02-13 01:01:46 +01:00
});
2020-03-29 20:56:49 +02:00
});
});