test: Add tests for create form submission API endpoint
This commit is contained in:
@@ -0,0 +1,86 @@
|
|||||||
|
import { vi, describe, it, expect, beforeEach } from 'vitest';
|
||||||
|
import request from 'supertest';
|
||||||
|
import Crypto from 'crypto';
|
||||||
|
import app from '../../../../../app.js';
|
||||||
|
import { createUser } from '../../../../../../test/factories/user.js';
|
||||||
|
import { createFlow } from '../../../../../../test/factories/flow.js';
|
||||||
|
import { createStep } from '../../../../../../test/factories/step.js';
|
||||||
|
import * as license from '../../../../../helpers/license.ee.js';
|
||||||
|
import * as formHandler from '../../../../../helpers/form-handler.ee.js';
|
||||||
|
|
||||||
|
describe('POST /internal/api/v1/forms/:formId', () => {
|
||||||
|
let currentUser, flow, formStep;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
vi.spyOn(license, 'hasValidLicense').mockResolvedValue(true);
|
||||||
|
vi.spyOn(formHandler, 'default').mockResolvedValue(undefined);
|
||||||
|
|
||||||
|
currentUser = await createUser();
|
||||||
|
flow = await createFlow({ userId: currentUser.id });
|
||||||
|
|
||||||
|
formStep = await createStep({
|
||||||
|
flowId: flow.id,
|
||||||
|
appKey: 'forms',
|
||||||
|
key: 'form',
|
||||||
|
type: 'trigger',
|
||||||
|
parameters: {
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
key: 'name',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'email',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should process form submission successfully', async () => {
|
||||||
|
const formData = {
|
||||||
|
name: 'John Doe',
|
||||||
|
email: 'john@example.com',
|
||||||
|
};
|
||||||
|
|
||||||
|
await request(app)
|
||||||
|
.post(`/internal/api/v1/forms/${flow.id}`)
|
||||||
|
.send(formData)
|
||||||
|
.expect(204);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return 400 for invalid trigger step', async () => {
|
||||||
|
await formStep.$query().patch({ appKey: 'github' });
|
||||||
|
|
||||||
|
const formData = {
|
||||||
|
name: 'John Doe',
|
||||||
|
email: 'john@example.com',
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await request(app)
|
||||||
|
.post(`/internal/api/v1/forms/${flow.id}`)
|
||||||
|
.send(formData)
|
||||||
|
.expect(400);
|
||||||
|
|
||||||
|
expect(response.body.errors).toStrictEqual({
|
||||||
|
general: ['Invalid trigger step'],
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return 404 for non-existent form', async () => {
|
||||||
|
const nonExistentFormId = Crypto.randomUUID();
|
||||||
|
|
||||||
|
const formData = {
|
||||||
|
name: 'John Doe',
|
||||||
|
email: 'john@example.com',
|
||||||
|
};
|
||||||
|
|
||||||
|
await request(app)
|
||||||
|
.post(`/internal/api/v1/forms/${nonExistentFormId}`)
|
||||||
|
.send(formData)
|
||||||
|
.expect(404);
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
import { renderObject, renderError } from '../../../../helpers/renderer.js';
|
import { renderObject, renderError } from '../../../../../helpers/renderer.js';
|
||||||
import Flow from '../../../../models/flow.js';
|
import Flow from '../../../../../models/flow.js';
|
||||||
|
|
||||||
export default async (request, response) => {
|
export default async (request, response) => {
|
||||||
const form = await Flow.query()
|
const form = await Flow.query()
|
||||||
|
|||||||
Reference in New Issue
Block a user