Тест огурца с использованием таблицы завершается с ошибкой «Невозможно прочитать свойство, выделенное жирным шрифтом из неопределенного» - PullRequest
0 голосов
/ 11 мая 2019

Использование codeceptJs 2.1.1 с французским тестом Gherkin 5.1.0 Я пытаюсь проверить наличие всех полей в форме, используя данные для предоставления имени поля.

Вот тест Геркина:

@tabletest
Scénario: Les champs
Alors je vois les champs :
| coteComplete   |
| typeOptionCote |

Вот соответствующий шаг:

Then('je vois les champs( de saisie) :', (name) => {
  I.say('name', name);
  I.seeElement(`input[name=${name}], select[name=${name}], textearea[name=${name}]`);
});

Вот трассировка стека:

$ npx codeceptjs run --grep "tabletest" --debug --verbose
CodeceptJS v2.1.1
Using test root "C:\PISTARD\diffusion\dev\pistard-diffusion"
Helpers: Protractor
Plugins: screenshotOnFail, wdio

Recherche par cote @PDIFF-56 --
    Emitted | suite.before ([object Object])
 » Started SeleniumStandaloneLauncher
 » [Session] Starting singleton browser session
  Les champs @tabletest
    Emitted | test.before ([object Object])
    Emitted | hook.start ([object Object])
    Emitted | step.before (I am on page "recherche-avancee")
    Emitted | step.after (I am on page "recherche-avancee")
    Emitted | step.start (I am on page "recherche-avancee")
    Etant donné que je suis sur la page "recherche avancee"
      I am on page "recherche-avancee"
      » Visited http://localhost:4200/recherche-avancee
    Emitted | step.passed (I am on page "recherche-avancee")
    Emitted | step.finish (I am on page "recherche-avancee")
    Emitted | hook.passed ([object Object])
    Emitted | test.start ([object Object])
    [1] Error | TypeError: Cannot read property 'bold' of undefined
    [1] Starting <teardown> session
    Emitted | test.failed ([object Object])
    Emitted | test.finish ([object Object])
    [1] <teardown> Stopping recording promises
 » <screenshotOnFail> Test failed, saving screenshot
 » Screenshot has been saved to C:\PISTARD\diffusion\dev\pistard-diffusion\codeceptjs-output\Les_champs_1557763592.failed.png
  × FAILED in 287ms

    [2] Starting recording promises
    Emitted | test.after ([object Object])
    Emitted | suite.after ([object Object])

-- FAILURES:

  1) Recherche par cote @PDIFF-56
       Les champs @tabletest:
     Cannot read property 'bold' of undefined
  ypeError: Cannot read property 'bold' of undefined
      at Object.say (node_modules\codeceptjs\lib\output.js:139:53)
      at recorder.add (node_modules\codeceptjs\lib\actor.js:40:78)
      at process.internalTickCallback (internal/process/next_tick.js:77:7)


  FAIL  | 0 passed, 1 failed   // 5s
    Emitted | global.result ([object Object])
    Emitted | global.after ([object Object])
 » Stopped SeleniumStandaloneLauncher

1 Ответ

0 голосов
/ 13 мая 2019

С помощью инспектора узлов я смог увидеть дальнейшее в трассировке. Добавьте аргумент --node-arg=--inspect-brk в команду

npx --node-arg=--inspect-brk codeceptjs run --grep "tabletest" --debug 

Затем откройте nodejsinspector из ваших chrome devtools, щелкнув значок узла:

enter image description here

Что касается "жирный шрифт неопределенного" ошибка, это

I.say("InputName:" + name);

О полученных переменных, которые я мог видеть, тест на самом деле получает объект, содержащий массив значений, а не фактическое значение. Фактическое значение доступно так:

let name = dataTest.rows[0].cells[0].value

, поэтому вам придется вручную зацикливаться в полученном массиве, чтобы получить каждое значение и проверить его

Then('je vois les champs( de saisie)( :)', (dataTest) => {
  let name;
  dataTest.rows.forEach(element => {
    name = element.cells[0].value;
    I.seeElement(`input[name=${name}], select[name=${name}], textearea[name=${name}]`);
  });
  debugger;
});
...