Ошибка setTimeout при модульном тестировании пользовательского узла в Node-RED с использованием Jest - PullRequest
0 голосов
/ 08 января 2020

Я заметил, что в целом тестирование пользовательских узлов в Node-RED не выполняется с помощью Jest - я не думаю, что есть какая-то конкретная причина, но это то, с чем я больше всего знаком, поэтому я все равно пробую .

Моя тестовая установка выглядит как

const n = require('../src/index.js');

describe('custom node', () => {
  const nodeType = 'custom node';

  beforeAll(done => {
    helper.startServer(done);
  });

  afterEach(() => {
    helper.unload();
  });

  afterAll(done => {
    helper.stopServer(done);
  });

  it('should be loaded', () =>
    new Promise((resolve, reject) => {
      const flow = [{ id: 'n1', type: nodeType, name: 'test name' }];

      helper.load(n, flow, () => {
        const n1 = helper.getNode('n1');
        try {
          expect(n1).toBeTruthy();
          expect(n1).toHaveProperty('name', 'test name');
          resolve();
        } catch (e) {
          reject(e);
        }
      });
    }));
});

, и выдается ошибка

console.error node_modules/jest-jasmine2/build/jasmine/Env.js:289
      Unhandled error
    console.error node_modules/jest-jasmine2/build/jasmine/Env.js:290
      TypeError: setTimeout(...).unref is not a function
          at Immediate.<anonymous> (/dev/custom_nodes/node-red-contrib-x/node_modules/stoppable/lib/stoppable.js:43:39)
          at processImmediate (internal/timers.js:439:21)
          at process.topLevelDomainCallback (domain.js:126:23)

1 Ответ

0 голосов
/ 08 января 2020

Решение оказалось простым: установите testEnvironment в конфигурации Jest на node, чтобы setTimeout не заменялся Jest на тот, который не имеет функции unref.

например, в jest. config. js

module.exports = {
  testEnvironment: 'node',
};
...