refactor: Overhaul nodes-testing setup - Part 1 (no-changelog) (#14303)

This commit is contained in:
कारतोफ्फेलस्क्रिप्ट™
2025-04-01 10:15:13 +02:00
committed by GitHub
parent f85b851851
commit 73e8d76e13
165 changed files with 3397 additions and 6453 deletions

View File

@@ -1,33 +1,22 @@
import type { INodeTypes } from 'n8n-workflow';
import { mock } from 'jest-mock-extended';
import type { Connection, QueryResult } from 'mysql2/promise';
import type { WorkflowTestData } from 'n8n-workflow';
import { executeWorkflow } from '@test/nodes/ExecuteWorkflow';
import { getResultNodeData, setup, workflowToTests } from '@test/nodes/Helpers';
import type { WorkflowTestData } from '@test/nodes/types';
import { getResultNodeData, workflowToTests } from '@test/nodes/Helpers';
const queryMock = jest.fn(async function () {
return [{ success: true }];
});
jest.mock('../../v1/GenericFunctions', () => {
const originalModule = jest.requireActual('../../v1/GenericFunctions');
return {
...originalModule,
createConnection: jest.fn(async function () {
return {
query: queryMock,
end: jest.fn(),
};
}),
};
});
const mockConnection = mock<Connection>();
const createConnection = jest.fn().mockReturnValue(mockConnection);
jest.mock('mysql2/promise', () => ({ createConnection }));
describe('Test MySqlV1, executeQuery', () => {
mockConnection.query.mockResolvedValue([{ success: true } as unknown as QueryResult, []]);
const workflows = ['nodes/MySql/test/v1/executeQuery.workflow.json'];
const tests = workflowToTests(workflows);
const nodeTypes = setup(tests);
const testNode = async (testData: WorkflowTestData, types: INodeTypes) => {
const { result } = await executeWorkflow(testData, types);
const testNode = async (testData: WorkflowTestData) => {
const { result } = await executeWorkflow(testData);
const resultNodeData = getResultNodeData(result, testData);
@@ -35,8 +24,8 @@ describe('Test MySqlV1, executeQuery', () => {
return expect(resultData).toEqual(testData.output.nodeData[nodeName]);
});
expect(queryMock).toHaveBeenCalledTimes(1);
expect(queryMock).toHaveBeenCalledWith(
expect(mockConnection.query).toHaveBeenCalledTimes(1);
expect(mockConnection.query).toHaveBeenCalledWith(
"select * from family_parents where (parent_email = 'parent1@mail.com' or parent_email = 'parent2@mail.com') and parent_email <> '';",
);
@@ -44,6 +33,6 @@ describe('Test MySqlV1, executeQuery', () => {
};
for (const testData of tests) {
test(testData.description, async () => await testNode(testData, nodeTypes));
test(testData.description, async () => await testNode(testData));
}
});