strapi/packages/strapi-plugin-content-manager/test/components/repeatable-required.test.e2e.js

499 lines
12 KiB
JavaScript
Raw Normal View History

2019-08-09 10:44:24 +02:00
const { registerAndLogin } = require('../../../../test/helpers/auth');
const createModelsUtils = require('../../../../test/helpers/models');
const { createAuthRequest } = require('../../../../test/helpers/request');
let modelsUtils;
let rq;
describe.each([
['CONTENT MANAGER', '/content-manager/explorer/application::withcomponent.withcomponent'],
2019-10-22 18:01:03 +02:00
['GENERATED API', '/withcomponents'],
])('[%s] => Non repeatable and Not required component', (_, path) => {
2019-08-09 10:44:24 +02:00
beforeAll(async () => {
const token = await registerAndLogin();
const authRq = createAuthRequest(token);
modelsUtils = createModelsUtils({ rq: authRq });
2019-10-22 18:01:03 +02:00
await modelsUtils.createComponent({
name: 'somecomponent',
2019-08-09 10:44:24 +02:00
attributes: {
name: {
type: 'string',
},
},
});
2019-12-12 10:15:25 +01:00
await modelsUtils.createContentTypeWithType('withcomponent', 'component', {
component: 'default.somecomponent',
2019-08-09 10:44:24 +02:00
repeatable: true,
required: true,
});
rq = authRq.defaults({
baseUrl: `http://localhost:1337${path}`,
});
}, 60000);
afterAll(async () => {
2019-10-29 18:39:25 +01:00
await modelsUtils.deleteComponent('default.somecomponent');
2019-12-12 10:15:25 +01:00
await modelsUtils.deleteContentType('withcomponent');
2019-08-09 11:04:48 +02:00
}, 60000);
2019-08-09 10:44:24 +02:00
describe('POST new entry', () => {
test('Creating entry with JSON works', async () => {
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
],
},
});
expect(res.statusCode).toBe(200);
expect(Array.isArray(res.body.field)).toBe(true);
expect(res.body.field).toEqual(
expect.arrayContaining([
expect.objectContaining({
id: expect.anything(),
name: 'someString',
}),
])
);
});
test('Creating entry with formdata works', async () => {
const res = await rq.post('/', {
formData: {
data: JSON.stringify({
field: [
{
name: 'someValue',
},
],
}),
},
});
expect(res.statusCode).toBe(200);
expect(Array.isArray(res.body.field)).toBe(true);
expect(res.body.field).toEqual(
expect.arrayContaining([
expect.objectContaining({
id: expect.anything(),
name: 'someValue',
}),
])
);
});
test.each(['someString', 128219, false, {}, null])(
'Throws if the field is not an object %p',
async value => {
const res = await rq.post('/', {
body: {
field: value,
},
});
expect(res.statusCode).toBe(400);
}
);
test('Can send an empty array', async () => {
const res = await rq.post('/', {
body: {
field: [],
},
});
expect(res.statusCode).toBe(200);
expect(res.body.field).toEqual([]);
});
2019-10-22 18:01:03 +02:00
test('Throws when component is not provided', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {},
});
expect(res.statusCode).toBe(400);
});
});
describe('GET entries', () => {
test('Data is orderd in the order sent', async () => {
const res = await rq.post('/', {
body: {
field: [
{
name: 'firstString',
},
{
name: 'someString',
},
],
},
});
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
expect(Array.isArray(getRes.body.field)).toBe(true);
expect(getRes.body.field[0]).toMatchObject({
name: 'firstString',
});
expect(getRes.body.field[1]).toMatchObject({
name: 'someString',
});
});
2019-10-22 18:01:03 +02:00
test('Should return entries with their nested components', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.get('/');
expect(res.statusCode).toBe(200);
expect(Array.isArray(res.body)).toBe(true);
res.body.forEach(entry => {
expect(Array.isArray(entry.field)).toBe(true);
if (entry.field.length === 0) return;
expect(entry.field).toEqual(
expect.arrayContaining([
expect.objectContaining({
name: expect.any(String),
}),
])
);
});
});
});
describe('PUT entry', () => {
test.each(['someString', 128219, false, {}, null])(
'Throws when sending invalid updated field %p',
async value => {
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: value,
},
});
expect(updateRes.statusCode).toBe(400);
// shouldn't have been updated
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
2019-08-09 11:45:31 +02:00
expect(getRes.body).toMatchObject({
id: res.body.id,
field: res.body.field,
});
2019-08-09 10:44:24 +02:00
}
);
test('Updates order at each request', async () => {
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
{
name: 'otherString',
},
],
},
});
expect(res.body.field[0]).toMatchObject({
name: 'someString',
});
expect(res.body.field[1]).toMatchObject({
name: 'otherString',
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: [
{
name: 'otherString',
},
{
name: 'someString',
},
],
},
});
expect(updateRes.statusCode).toBe(200);
expect(Array.isArray(updateRes.body.field)).toBe(true);
expect(updateRes.body.field[0]).toMatchObject({
name: 'otherString',
});
expect(updateRes.body.field[1]).toMatchObject({
name: 'someString',
});
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
expect(Array.isArray(getRes.body.field)).toBe(true);
expect(getRes.body.field[0]).toMatchObject({
name: 'otherString',
});
expect(getRes.body.field[1]).toMatchObject({
name: 'someString',
});
});
2019-10-22 18:01:03 +02:00
test('Keeps the previous value if component not sent', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
{
name: 'otherString',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {},
});
expect(updateRes.statusCode).toBe(200);
2019-08-09 11:45:31 +02:00
expect(updateRes.body).toMatchObject({
id: res.body.id,
field: res.body.field,
});
2019-08-09 10:44:24 +02:00
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
2019-08-09 11:45:31 +02:00
expect(getRes.body).toMatchObject({
id: res.body.id,
field: res.body.field,
});
2019-08-09 10:44:24 +02:00
});
2019-10-22 18:01:03 +02:00
test('Removes previous components if empty array sent', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: [],
},
});
const expectResult = {
id: res.body.id,
field: [],
};
expect(updateRes.statusCode).toBe(200);
expect(updateRes.body).toMatchObject(expectResult);
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
expect(getRes.body).toMatchObject(expectResult);
});
2019-10-22 18:01:03 +02:00
test('Replaces the previous components if sent without id', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: [
{
name: 'new String',
},
],
},
});
expect(updateRes.statusCode).toBe(200);
const oldIds = res.body.field.map(val => val.id);
updateRes.body.field.forEach(val => {
expect(oldIds.includes(val.id)).toBe(false);
});
expect(updateRes.body).toMatchObject({
id: res.body.id,
field: [
{
name: 'new String',
},
],
});
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
expect(getRes.body).toMatchObject({
id: res.body.id,
field: [
{
name: 'new String',
},
],
});
});
2019-10-22 18:01:03 +02:00
test('Throws on invalid id in component', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: [
{
id: 'invalid_id',
name: 'new String',
},
],
},
});
expect(updateRes.statusCode).toBe(400);
});
2019-10-22 18:01:03 +02:00
test('Updates component with ids, create new ones and removes old ones', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'one',
},
{
name: 'two',
},
{
name: 'three',
},
],
},
});
const updateRes = await rq.put(`/${res.body.id}`, {
body: {
field: [
{
2019-10-22 18:01:03 +02:00
id: res.body.field[0].id, // send old id to update the previous component
2019-08-09 10:44:24 +02:00
name: 'newOne',
},
{
name: 'newTwo',
},
{
id: res.body.field[2].id,
name: 'three',
},
{
name: 'four',
},
],
},
});
const expectedResult = {
id: res.body.id,
field: [
{
id: res.body.field[0].id,
name: 'newOne',
},
{
name: 'newTwo',
},
{
id: res.body.field[2].id,
name: 'three',
},
{
name: 'four',
},
],
};
expect(updateRes.statusCode).toBe(200);
expect(updateRes.body).toMatchObject(expectedResult);
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(200);
expect(getRes.body).toMatchObject(expectedResult);
});
});
describe('DELETE entry', () => {
2019-10-22 18:01:03 +02:00
test('Returns entry with components', async () => {
2019-08-09 10:44:24 +02:00
const res = await rq.post('/', {
body: {
field: [
{
name: 'someString',
},
{
name: 'someOtherString',
},
{
name: 'otherSomeString',
},
],
},
});
const deleteRes = await rq.delete(`/${res.body.id}`);
expect(deleteRes.statusCode).toBe(200);
expect(deleteRes.body).toMatchObject(res.body);
const getRes = await rq.get(`/${res.body.id}`);
expect(getRes.statusCode).toBe(404);
});
});
});