mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-03 17:07:29 -08:00
test: Fix task runner tests on node 18 and 22 (#12243)
This commit is contained in:
parent
2ce1644d01
commit
271401d882
|
@ -1,5 +1,6 @@
|
||||||
/** @type {import('jest').Config} */
|
/** @type {import('jest').Config} */
|
||||||
module.exports = {
|
module.exports = {
|
||||||
...require('../../../jest.config'),
|
...require('../../../jest.config'),
|
||||||
|
setupFilesAfterEnv: ['n8n-workflow/test/setup.ts'],
|
||||||
testTimeout: 10_000,
|
testTimeout: 10_000,
|
||||||
};
|
};
|
||||||
|
|
|
@ -36,7 +36,11 @@ describe('ExecutionError', () => {
|
||||||
|
|
||||||
it('should serialize correctly', () => {
|
it('should serialize correctly', () => {
|
||||||
const error = new Error('a.unknown is not a function');
|
const error = new Error('a.unknown is not a function');
|
||||||
error.stack = defaultStack;
|
Object.defineProperty(error, 'stack', {
|
||||||
|
value: defaultStack,
|
||||||
|
enumerable: true,
|
||||||
|
});
|
||||||
|
// error.stack = defaultStack;
|
||||||
|
|
||||||
const executionError = new ExecutionError(error, 1);
|
const executionError = new ExecutionError(error, 1);
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,6 @@ export class ExecutionError extends SerializableError {
|
||||||
|
|
||||||
context: { itemIndex: number } | undefined = undefined;
|
context: { itemIndex: number } | undefined = undefined;
|
||||||
|
|
||||||
stack = '';
|
|
||||||
|
|
||||||
lineNumber: number | undefined = undefined;
|
lineNumber: number | undefined = undefined;
|
||||||
|
|
||||||
constructor(error: ErrorLike, itemIndex?: number) {
|
constructor(error: ErrorLike, itemIndex?: number) {
|
||||||
|
@ -22,7 +20,12 @@ export class ExecutionError extends SerializableError {
|
||||||
this.context = { itemIndex: this.itemIndex };
|
this.context = { itemIndex: this.itemIndex };
|
||||||
}
|
}
|
||||||
|
|
||||||
this.stack = error.stack ?? '';
|
// Override the stack trace with the given error's stack trace. Since
|
||||||
|
// node v22 it's not writable, so we can't assign it directly
|
||||||
|
Object.defineProperty(this, 'stack', {
|
||||||
|
value: error.stack,
|
||||||
|
enumerable: true,
|
||||||
|
});
|
||||||
|
|
||||||
this.populateFromStack();
|
this.populateFromStack();
|
||||||
}
|
}
|
||||||
|
@ -31,7 +34,7 @@ export class ExecutionError extends SerializableError {
|
||||||
* Populate error `message` and `description` from error `stack`.
|
* Populate error `message` and `description` from error `stack`.
|
||||||
*/
|
*/
|
||||||
private populateFromStack() {
|
private populateFromStack() {
|
||||||
const stackRows = this.stack.split('\n');
|
const stackRows = (this.stack ?? '').split('\n');
|
||||||
|
|
||||||
if (stackRows.length === 0) {
|
if (stackRows.length === 0) {
|
||||||
this.message = 'Unknown error';
|
this.message = 'Unknown error';
|
||||||
|
|
5
packages/@n8n/task-runner/src/polyfills.ts
Normal file
5
packages/@n8n/task-runner/src/polyfills.ts
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
// WebCrypto Polyfill for older versions of Node.js 18
|
||||||
|
if (!globalThis.crypto?.getRandomValues) {
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-var-requires, @typescript-eslint/no-unsafe-member-access
|
||||||
|
globalThis.crypto = require('node:crypto').webcrypto;
|
||||||
|
}
|
|
@ -1,3 +1,4 @@
|
||||||
|
import './polyfills';
|
||||||
import type { ErrorReporter } from 'n8n-core';
|
import type { ErrorReporter } from 'n8n-core';
|
||||||
import { ensureError, setGlobalState } from 'n8n-workflow';
|
import { ensureError, setGlobalState } from 'n8n-workflow';
|
||||||
import Container from 'typedi';
|
import Container from 'typedi';
|
||||||
|
|
Loading…
Reference in a new issue