Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
87 lines
2.6 KiB
JavaScript
87 lines
2.6 KiB
JavaScript
import { describe, it, expect } from 'vitest';
|
|
import { validateAutomation } from '../validations';
|
|
|
|
describe('validateAutomation', () => {
|
|
it('should return no errors for a valid automation', () => {
|
|
const validAutomation = {
|
|
name: 'Test Automation',
|
|
description: 'A test automation',
|
|
event_name: 'message_created',
|
|
conditions: [
|
|
{
|
|
attribute_key: 'content',
|
|
filter_operator: 'contains',
|
|
values: 'hello',
|
|
},
|
|
],
|
|
actions: [
|
|
{ action_name: 'send_message', action_params: ['Hello there!'] },
|
|
],
|
|
};
|
|
const errors = validateAutomation(validAutomation);
|
|
expect(errors).toEqual({});
|
|
});
|
|
|
|
it('should return errors for missing basic fields', () => {
|
|
const invalidAutomation = {
|
|
name: '',
|
|
description: '',
|
|
event_name: '',
|
|
conditions: [],
|
|
actions: [],
|
|
};
|
|
const errors = validateAutomation(invalidAutomation);
|
|
expect(errors).toHaveProperty('name');
|
|
expect(errors).toHaveProperty('description');
|
|
expect(errors).toHaveProperty('event_name');
|
|
});
|
|
|
|
it('should return errors for invalid conditions', () => {
|
|
const automationWithInvalidConditions = {
|
|
name: 'Test',
|
|
description: 'Test',
|
|
event_name: 'message_created',
|
|
conditions: [{ attribute_key: '', filter_operator: '', values: '' }],
|
|
actions: [{ action_name: 'send_message', action_params: ['Hello'] }],
|
|
};
|
|
const errors = validateAutomation(automationWithInvalidConditions);
|
|
expect(errors).toHaveProperty('condition_0');
|
|
});
|
|
|
|
it('should return errors for invalid actions', () => {
|
|
const automationWithInvalidActions = {
|
|
name: 'Test',
|
|
description: 'Test',
|
|
event_name: 'message_created',
|
|
conditions: [
|
|
{
|
|
attribute_key: 'content',
|
|
filter_operator: 'contains',
|
|
values: 'hello',
|
|
},
|
|
],
|
|
actions: [{ action_name: 'send_message', action_params: [] }],
|
|
};
|
|
const errors = validateAutomation(automationWithInvalidActions);
|
|
expect(errors).toHaveProperty('action_0');
|
|
});
|
|
|
|
it('should not require action params for specific actions', () => {
|
|
const automationWithNoParamAction = {
|
|
name: 'Test',
|
|
description: 'Test',
|
|
event_name: 'message_created',
|
|
conditions: [
|
|
{
|
|
attribute_key: 'content',
|
|
filter_operator: 'contains',
|
|
values: 'hello',
|
|
},
|
|
],
|
|
actions: [{ action_name: 'mute_conversation' }],
|
|
};
|
|
const errors = validateAutomation(automationWithNoParamAction);
|
|
expect(errors).toEqual({});
|
|
});
|
|
});
|