Spectron с Jest для проверки открытия основного окна не работает

Я разрабатываю настольное приложение Electron с React. Пытаюсь настроить тестирование электронной части кода. У меня есть файл Launch.test.js, в котором я пытаюсь протестировать спектрон с помощью Jest. Когда я запускаю тестовый файл, он выдает ошибки. Проблемы с исправлением ошибок.

Моя файловая структура такая

node_modules
public
src
 --components
 --tests
   --Launch.test.js
main.js
package.json
README.md

И код для Launch.test.js выглядит следующим образом:

const Application = require('spectron').Application;
const path = require('path');

let electronPath = path.join(__dirname, '..', '..', 'node_modules', '.bin', 'electron');

if (process.platform === 'win32') {
     electronPath += '.cmd';
}

const appPath = path.join(__dirname, '..', '..');

const app = new Application({
  path: electronPath,
  args: [appPath],
});

describe('Test Example', () => {
  beforeEach(() => {
  return app.start();
});

afterEach(() => {
   return app.stop();
});

it('opens a window', () => {
  expect.assertions(1);
  return app.client.element('input').getValue().then((j) => {
    console.log('xxxx', j);
    expect(1).toEqual(1);
  });
});

});

Когда я запускаю его, я получаю следующие ошибки.

src/tests/Launch.test.js (12.74s)
Test Example
× opens a window (5253ms)

● Test Example › opens a window

Timeout - Async callback was not invoked within the 5000ms timeout specified by jest.setTimeout.

  at mapper (node_modules/jest-jasmine2/build/queue_runner.js:41:52)

● Test Example › opens a window

An element could not be located on the page using the given search parameters ("input").

  at execute(<Function>, "require") - C:/Users/CKE1LUD/Desktop/repos/leela/node_modules/spectron/lib/api.js:63:26

● Test Example › opens a window

Application not running

  21 |
  22 |   afterEach(() => {
> 23 |     return app.stop();
     |                ^
  24 |   });
  25 |
  26 |   it('opens a window', () => {

  at Application.Object.<anonymous>.Application.stop (node_modules/spectron/lib/application.js:59:48)
  at Object.stop (src/tests/Launch.test.js:23:16)

● Test Example › opens a window

expect.assertions(1)

Expected one assertion to be called but received zero assertion calls.

  25 |
  26 |   it('opens a window', () => {
> 27 |     expect.assertions(1);
     |            ^
  28 |     return app.client.element('input').getValue().then((j) => {
  29 |       console.log('xxxx', j);
  30 |       expect(1).toEqual(1);

  at Object.assertions (src/tests/Launch.test.js:27:12)

Test Suites: 1 failed, 1 total
Tests:       1 failed, 1 total
Snapshots:   0 total
Time:        15.316s

person user10518298    schedule 11.01.2019    source источник
comment
Где вы можете это решить?   -  person jayarjo    schedule 20.04.2019


Ответы (1)


Используйте jest.setTimeout(), чтобы увеличить время ожидания.

Иногда у вас есть много кода инициализации до того, как Electron действительно встанет, поэтому вы хотите подождать дольше, чем по умолчанию (5000).

person baruchiro    schedule 28.01.2020
comment
Я все еще получаю сообщение об ошибке ``` {Ошибка: неизвестная ошибка: не удалось запустить Chrome: аварийное завершение работы. (неизвестная ошибка: файл DevToolsActivePort не существует) (Процесс, запущенный из chrome location path-to-my-project/node_modules/spectron/lib/launcher.js, больше не работает, поэтому ChromeDriver предполагает, что Chrome потерпел крах.) ... ``` - person Federico Bellucci; 07.02.2020