黄瓜方案的Javascript console.log状态

时间:2018-10-10 17:03:26

标签: javascript cucumber cucumberjs

我想使用 afterScenario 钩子打印每个黄瓜方案的状态。

我尝试打印出case.status(下面的代码),但它打印出“未定义”

afterScenario: (scenario) => {
    console.log(scenario.status);
}

仅打印场景时,我看不到状态。

Scenario {
  feature: 
   Feature {
     description: undefined,
     keyword: 'Feature',
     line: 1,
     name: 'Sample Test',
     tags: [],
     uri: '/Users/Daredevil/e2e/features/sampleProject/intro.feature',
     scenarios: [ [Circular] ] },
  keyword: 'Scenario',
  lines: [ 15, 7 ],
  name: 'Getting test status',
  tags: 
   [ Tag { line: 6, name: '@WIP' }],
  uri: '/Users/Daredevil/e2e/features/sampleProject/intro.feature',
  line: 15,
  description: undefined,
  steps: 
   [ Step {
       arguments: [],
       line: 4,
       name: 'I am on the app',
       scenario: [Circular],
       uri: '/Users/Daredevil/e2e/features/sampleProject/intro.feature',
       isBackground: true,
       keyword: 'Given ',
       keywordType: 'precondition' },
     Step {
       arguments: [],
       line: 8,
       name: 'I am viewing the splash screen',
       scenario: [Circular],
       uri: '/Users/Daredevil/e2e/features/sampleProject/intro.feature',
       isBackground: false,
       keyword: 'Given ',
       keywordType: 'precondition' } ] }

我通读了https://docs.cucumber.io/cucumber/api/#hooks,该书(根据我的理解)建议执行scenario.failed,但是我仍然不确定。 谁能告诉我如何获得方案的状态?

我正在使用黄瓜v3.2.1和wdio-cucumber-framework v1.0.3。

3 个答案:

答案 0 :(得分:0)

以下应该可以工作- (尝试使用wdio-黄瓜)

After(function (scenarioResult) {
        const scenario = scenarioResult.scenario;
        console.log('SCENARIO EXECUTION COMPLETED:',scenario.name);
    });

答案 1 :(得分:0)

这不仅仅是一个建议。我将研究如何构建report.json,因为该报告包含所有方案及其结果。

cumber.js文件中还有另一个指针,用于设置您要进度的报告格式,该格式将进度输出到控制台。

看看https://github.com/cucumber/cucumber-js/blob/master/docs/cli.md#Formats

答案 2 :(得分:0)

答案很简单,您应该在控制台中记录“ scenario.result.status ”,而不是scenario.status。

希望这个答案对您有帮助!