mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
adds tests
This commit is contained in:
parent
a66a55aa10
commit
b422e2d7aa
|
@ -1,11 +1,88 @@
|
||||||
|
import {
|
||||||
|
NodeOperationError,
|
||||||
|
type IExecuteFunctions,
|
||||||
|
type IDataObject,
|
||||||
|
NodeExecutionOutput,
|
||||||
|
type INodeExecutionData,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
import { testWorkflows, getWorkflowFilenames } from '@test/nodes/Helpers';
|
import { testWorkflows, getWorkflowFilenames } from '@test/nodes/Helpers';
|
||||||
import { NodeOperationError, type IExecuteFunctions, type IDataObject } from 'n8n-workflow';
|
|
||||||
|
import { Summarize } from '../Summarize.node';
|
||||||
import { checkIfFieldExists, type Aggregations } from '../utils';
|
import { checkIfFieldExists, type Aggregations } from '../utils';
|
||||||
|
|
||||||
const workflows = getWorkflowFilenames(__dirname);
|
const workflows = getWorkflowFilenames(__dirname);
|
||||||
|
|
||||||
describe('Test Summarize Node', () => testWorkflows(workflows));
|
describe('Test Summarize Node', () => testWorkflows(workflows));
|
||||||
|
|
||||||
|
jest.mock('n8n-workflow', () => ({
|
||||||
|
...jest.requireActual('n8n-workflow'),
|
||||||
|
NodeExecutionOutput: jest.fn().mockImplementation((data) => ({
|
||||||
|
data,
|
||||||
|
at(index: number): INodeExecutionData {
|
||||||
|
return (this.data as INodeExecutionData[])[index];
|
||||||
|
},
|
||||||
|
})),
|
||||||
|
}));
|
||||||
|
|
||||||
|
describe('Test Summarize Node, execute', () => {
|
||||||
|
testWorkflows(workflows);
|
||||||
|
|
||||||
|
let summarizeNode: Summarize;
|
||||||
|
let mockExecuteFunctions: IExecuteFunctions;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
summarizeNode = new Summarize();
|
||||||
|
mockExecuteFunctions = {
|
||||||
|
getNode: jest.fn().mockReturnValue({ name: 'test-node' }),
|
||||||
|
getNodeParameter: jest.fn(),
|
||||||
|
getInputData: jest.fn(),
|
||||||
|
} as unknown as IExecuteFunctions;
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should handle field not found with hints in version 1.1', async () => {
|
||||||
|
const node = new Summarize();
|
||||||
|
const context = {
|
||||||
|
getNodeParameter: jest
|
||||||
|
.fn()
|
||||||
|
.mockReturnValueOnce({}) // options
|
||||||
|
.mockReturnValueOnce('') // fieldsToSplitBy
|
||||||
|
.mockReturnValueOnce([{ field: 'nonexistentField', aggregation: 'sum' }]), // fieldsToSummarize
|
||||||
|
getInputData: jest.fn().mockReturnValue([{ json: { someField: 1 } }]),
|
||||||
|
getNode: jest.fn().mockReturnValue({ typeVersion: 1.1 }),
|
||||||
|
} as unknown as IExecuteFunctions;
|
||||||
|
|
||||||
|
await node.execute.call(context);
|
||||||
|
|
||||||
|
expect(NodeExecutionOutput).toHaveBeenCalledWith(
|
||||||
|
expect.any(Array),
|
||||||
|
expect.arrayContaining([
|
||||||
|
expect.objectContaining({
|
||||||
|
message: expect.stringContaining('nonexistentField'),
|
||||||
|
location: 'outputPane',
|
||||||
|
}),
|
||||||
|
]),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should throw error if node version is < 1.1 and fields not found', async () => {
|
||||||
|
mockExecuteFunctions.getNode = jest.fn().mockReturnValue({ typeVersion: 1 });
|
||||||
|
const items = [{ a: 1 }, { b: 2 }, { c: 3 }];
|
||||||
|
const aggregations: Aggregations = [
|
||||||
|
{ aggregation: 'sum', field: 'b' },
|
||||||
|
{ aggregation: 'count', field: 'd' },
|
||||||
|
];
|
||||||
|
mockExecuteFunctions.getInputData = jest.fn().mockReturnValue(items);
|
||||||
|
mockExecuteFunctions.getNodeParameter = jest
|
||||||
|
.fn()
|
||||||
|
.mockReturnValueOnce({}) // options
|
||||||
|
.mockReturnValueOnce('') // fieldsToSplitBy
|
||||||
|
.mockReturnValueOnce(aggregations); // fieldsToSummarize
|
||||||
|
await expect(async () => {
|
||||||
|
await summarizeNode.execute.bind(mockExecuteFunctions)();
|
||||||
|
}).rejects.toThrow(NodeOperationError);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('Test Summarize Node, checkIfFieldExists', () => {
|
describe('Test Summarize Node, checkIfFieldExists', () => {
|
||||||
let mockExecuteFunctions: IExecuteFunctions;
|
let mockExecuteFunctions: IExecuteFunctions;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue