refactor(core): Update dynamic node parameter endpoints to use DTOs (#12379)

This commit is contained in:
कारतोफ्फेलस्क्रिप्ट™
2024-12-30 15:48:44 +01:00
committed by GitHub
parent f08db47077
commit 1674dd0f88
21 changed files with 875 additions and 171 deletions

View File

@@ -1,34 +1,223 @@
import type {
OptionsRequestDto,
ResourceLocatorRequestDto,
ResourceMapperFieldsRequestDto,
ActionResultRequestDto,
} from '@n8n/api-types';
import { mock } from 'jest-mock-extended';
import type { ILoadOptions, IWorkflowExecuteAdditionalData } from 'n8n-workflow';
import type {
ILoadOptions,
IWorkflowExecuteAdditionalData,
INodePropertyOptions,
NodeParameterValueType,
} from 'n8n-workflow';
import { DynamicNodeParametersController } from '@/controllers/dynamic-node-parameters.controller';
import type { DynamicNodeParametersRequest } from '@/requests';
import type { AuthenticatedRequest } from '@/requests';
import type { DynamicNodeParametersService } from '@/services/dynamic-node-parameters.service';
import * as AdditionalData from '@/workflow-execute-additional-data';
describe('DynamicNodeParametersController', () => {
const service = mock<DynamicNodeParametersService>();
const controller = new DynamicNodeParametersController(service);
let service: jest.Mocked<DynamicNodeParametersService>;
let controller: DynamicNodeParametersController;
let mockUser: { id: string };
let baseAdditionalData: IWorkflowExecuteAdditionalData;
beforeEach(() => {
jest.clearAllMocks();
service = mock<DynamicNodeParametersService>();
controller = new DynamicNodeParametersController(service);
mockUser = { id: 'user123' };
baseAdditionalData = mock<IWorkflowExecuteAdditionalData>();
jest.spyOn(AdditionalData, 'getBase').mockResolvedValue(baseAdditionalData);
});
describe('getOptions', () => {
it('should take `loadOptions` as object', async () => {
jest
.spyOn(AdditionalData, 'getBase')
.mockResolvedValue(mock<IWorkflowExecuteAdditionalData>());
const basePayload: OptionsRequestDto = {
path: '/test/path',
nodeTypeAndVersion: { name: 'TestNode', version: 1 },
currentNodeParameters: {},
};
const req = mock<DynamicNodeParametersRequest.Options>();
const loadOptions: ILoadOptions = {};
req.body.loadOptions = loadOptions;
it('should call getOptionsViaMethodName when methodName is provided', async () => {
const payload: OptionsRequestDto = {
...basePayload,
methodName: 'testMethod',
};
const req = { user: mockUser } as AuthenticatedRequest;
await controller.getOptions(req);
const expectedResult: INodePropertyOptions[] = [{ name: 'test', value: 'value' }];
service.getOptionsViaMethodName.mockResolvedValue(expectedResult);
const zerothArg = service.getOptionsViaLoadOptions.mock.calls[0][0];
const result = await controller.getOptions(req, mock(), payload);
expect(zerothArg).toEqual(loadOptions);
expect(service.getOptionsViaMethodName).toHaveBeenCalledWith(
'testMethod',
'/test/path',
baseAdditionalData,
{ name: 'TestNode', version: 1 },
{},
undefined,
);
expect(result).toEqual(expectedResult);
});
it('should call getOptionsViaLoadOptions when loadOptions is provided', async () => {
const loadOptions: ILoadOptions = {
routing: {
operations: {},
},
};
const payload: OptionsRequestDto = {
...basePayload,
loadOptions,
};
const req = { user: mockUser } as AuthenticatedRequest;
const expectedResult: INodePropertyOptions[] = [{ name: 'test', value: 'value' }];
service.getOptionsViaLoadOptions.mockResolvedValue(expectedResult);
const result = await controller.getOptions(req, mock(), payload);
expect(service.getOptionsViaLoadOptions).toHaveBeenCalledWith(
loadOptions,
baseAdditionalData,
{ name: 'TestNode', version: 1 },
{},
undefined,
);
expect(result).toEqual(expectedResult);
});
it('should return empty array when no method or load options are provided', async () => {
const req = { user: mockUser } as AuthenticatedRequest;
const result = await controller.getOptions(req, mock(), basePayload);
expect(result).toEqual([]);
});
});
describe('getResourceLocatorResults', () => {
const basePayload: ResourceLocatorRequestDto = {
path: '/test/path',
nodeTypeAndVersion: { name: 'TestNode', version: 1 },
methodName: 'testMethod',
currentNodeParameters: {},
};
it('should call getResourceLocatorResults with correct parameters', async () => {
const payload: ResourceLocatorRequestDto = {
...basePayload,
filter: 'testFilter',
paginationToken: 'testToken',
};
const req = { user: mockUser } as AuthenticatedRequest;
const expectedResult = { results: [{ name: 'test', value: 'value' }] };
service.getResourceLocatorResults.mockResolvedValue(expectedResult);
const result = await controller.getResourceLocatorResults(req, mock(), payload);
expect(service.getResourceLocatorResults).toHaveBeenCalledWith(
'testMethod',
'/test/path',
baseAdditionalData,
{ name: 'TestNode', version: 1 },
{},
undefined,
'testFilter',
'testToken',
);
expect(result).toEqual(expectedResult);
});
});
describe('getResourceMappingFields', () => {
const basePayload: ResourceMapperFieldsRequestDto = {
path: '/test/path',
nodeTypeAndVersion: { name: 'TestNode', version: 1 },
methodName: 'testMethod',
currentNodeParameters: {},
};
it('should call getResourceMappingFields with correct parameters', async () => {
const req = { user: mockUser } as AuthenticatedRequest;
const expectedResult = { fields: [] };
service.getResourceMappingFields.mockResolvedValue(expectedResult);
const result = await controller.getResourceMappingFields(req, mock(), basePayload);
expect(service.getResourceMappingFields).toHaveBeenCalledWith(
'testMethod',
'/test/path',
baseAdditionalData,
{ name: 'TestNode', version: 1 },
{},
undefined,
);
expect(result).toEqual(expectedResult);
});
});
describe('getLocalResourceMappingFields', () => {
const basePayload: ResourceMapperFieldsRequestDto = {
path: '/test/path',
nodeTypeAndVersion: { name: 'TestNode', version: 1 },
methodName: 'testMethod',
currentNodeParameters: {},
};
it('should call getLocalResourceMappingFields with correct parameters', async () => {
const req = { user: mockUser } as AuthenticatedRequest;
const expectedResult = { fields: [] };
service.getLocalResourceMappingFields.mockResolvedValue(expectedResult);
const result = await controller.getLocalResourceMappingFields(req, mock(), basePayload);
expect(service.getLocalResourceMappingFields).toHaveBeenCalledWith(
'testMethod',
'/test/path',
baseAdditionalData,
{ name: 'TestNode', version: 1 },
);
expect(result).toEqual(expectedResult);
});
});
describe('getActionResult', () => {
const basePayload: ActionResultRequestDto = {
path: '/test/path',
nodeTypeAndVersion: { name: 'TestNode', version: 1 },
handler: 'testHandler',
currentNodeParameters: {},
};
it('should call getActionResult with correct parameters', async () => {
const payload: ActionResultRequestDto = {
...basePayload,
payload: { test: 'value' },
};
const req = { user: mockUser } as AuthenticatedRequest;
const expectedResult: NodeParameterValueType = 'test result';
service.getActionResult.mockResolvedValue(expectedResult);
const result = await controller.getActionResult(req, mock(), payload);
expect(service.getActionResult).toHaveBeenCalledWith(
'testHandler',
'/test/path',
baseAdditionalData,
{ name: 'TestNode', version: 1 },
{},
{ test: 'value' },
undefined,
);
expect(result).toEqual(expectedResult);
});
});
});