Alexandre Bodin 07e7cfc0bd Make lint stricter and fix the errors
Signed-off-by: Alexandre Bodin <bodin.alex@gmail.com>
2020-11-02 19:41:42 +01:00

96 lines
2.5 KiB
JavaScript

'use strict';
const { registerAndLogin } = require('../../../../test/helpers/auth');
const createModelsUtils = require('../../../../test/helpers/models');
const { createAuthRequest } = require('../../../../test/helpers/request');
let modelsUtils;
let rq;
describe('Test type time', () => {
beforeAll(async () => {
const token = await registerAndLogin();
rq = createAuthRequest(token);
modelsUtils = createModelsUtils({ rq });
await modelsUtils.createContentTypeWithType('withtime', 'time');
}, 60000);
afterAll(async () => {
await modelsUtils.deleteContentType('withtime');
}, 60000);
test('Create entry with valid value JSON', async () => {
const res = await rq.post('/content-manager/explorer/application::withtime.withtime', {
body: {
field: '10:10:57.123',
},
});
expect(res.statusCode).toBe(200);
expect(res.body).toMatchObject({
field: '10:10:57.123',
});
});
test.each(['00:00:00', '01:03:11.2', '01:03:11.93', '01:03:11.123'])(
'Accepts multiple time formats %s',
async input => {
const res = await rq.post('/content-manager/explorer/application::withtime.withtime', {
body: {
field: input,
},
});
expect(res.statusCode).toBe(200);
}
);
test.each(['24:11:23', '23:72:11', '12:45:83', 1234, {}, 'test', new Date()])(
'Throws on invalid time (%s)',
async input => {
const res = await rq.post('/content-manager/explorer/application::withtime.withtime', {
body: {
field: input,
},
});
expect(res.statusCode).toBe(400);
}
);
test('Reading entry, returns correct value', async () => {
const res = await rq.get('/content-manager/explorer/application::withtime.withtime');
expect(res.statusCode).toBe(200);
expect(Array.isArray(res.body)).toBe(true);
res.body.forEach(entry => {
expect(entry.field).toMatch(/^2[0-3]|[01][0-9]:[0-5][0-9]:[0-5][0-9](.[0-9]{1,3})?$/);
});
});
test('Updating entry sets the right value and format JSON', async () => {
const res = await rq.post('/content-manager/explorer/application::withtime.withtime', {
body: {
field: '12:11:04',
},
});
const uptimeRes = await rq.put(
`/content-manager/explorer/application::withtime.withtime/${res.body.id}`,
{
body: {
field: '13:45:19.123',
},
}
);
expect(uptimeRes.statusCode).toBe(200);
expect(uptimeRes.body).toMatchObject({
id: res.body.id,
field: '13:45:19.123',
});
});
});