Reputation: 1866
Task:
That was my task for the day. I have done all of that with writing the scenario test, selenium setup, go pipelines, and everything else needed.
The only problem is - I could not get a way to figure out how can I find a failing scenario step and take a screen shot of the page.
Problem details: I have the following code placed in my step definitions, which is run for every scenario step
//file: features/setpdefinitions/common.step.js
var commonWrapper = function commonWrapper() {
this.World = require('../support/world').World;
this.Before(function (next) {
this.initBrowser(next);
});
this.After(function (next) {
this.browser.quit(next);
});
this.StepResult(function (event, callback) {
var stepResult = event.getPayloadItem('stepResult');
console.log(stepResult.isFailed());
callback();
});
};
module.exports = commonWrapper;
the World
contains the browser initiation methods.
and, this is a sample feature scenario that I am testing
Feature: Forgot Password
As a user of Booking My account
I want to reset my password
So that I can login to my account when I forget my password
Scenario: On unsuccessful entering invalid email id
Given I am on forgot password page
When I enter invalid email "invalidemail-someDomain.com"
And click submit button
Then I should see validation message "Please enter a valid email."
the problem is with the context data. I somehow could not get the scenario
passed to the after/before method as the first argument. I tried the code given in the cucumberjs source but could not succeed. So, I moved onto adding the stepResult
method, which run every time a step is completed. A relatively similar approach.
As per documentation, the isFailed()
method returns a boolean based on the step result. but, I always get a false
no matter the step failed or passed. I tried its alter-ego isSuccessful()
which returns a true
no matter what.
so,
I'm relatively new to TDD, but hey it been a great experience so far.
Upvotes: 4
Views: 5354
Reputation: 1
Create afterhook.js and check for failing scenario You can use browser.saveScreenshot for saving the screenshot . While saving screenshot use a timestamp to the file name and also exclude the screenshots from version control
module.exports = function() {
this.After((scenario, callback) => {
if (scenario.isFailed()) {
const d = new Date();
browser.saveScreenshot(
`./e2e/screenshots/screenshot-${d.toISOString()}.png`
);
}
callback();
});
};
Upvotes: 0
Reputation: 11
You can get more details in (cucumberjs 1.x) https://github.com/cucumber/cucumber-js/blob/1.x/lib/cucumber/api/scenario.js#L27
getKeyword: function getKeyword() {
return astScenario.getKeyword();
},
getName: function getName() {
return astScenario.getName();
},
getDescription: function getDescription() {
return astScenario.getDescription();
},
getUri: function getUri() {
return astScenario.getUri();
},
getLine: function getLine() {
return astScenario.getLine();
},
getTags: function getTags() {
return astScenario.getTags();
},
isSuccessful: function isSuccessful() {
return scenarioResult.getStatus() === Cucumber.Status.PASSED;
},
isFailed: function isFailed() {
return scenarioResult.getStatus() === Cucumber.Status.FAILED;
},
isPending: function isPending() {
return scenarioResult.getStatus() === Cucumber.Status.PENDING;
},
isUndefined: function isUndefined() {
return scenarioResult.getStatus() === Cucumber.Status.UNDEFINED;
},
isSkipped: function isSkipped() {
return scenarioResult.getStatus() === Cucumber.Status.SKIPPED;
},
getException: function getException() {
return scenarioResult.getFailureException();
},
getAttachments: function getAttachments() {
return attachments;
},
clearAttachments: function clearAttachments() {
attachments = [];
},
Upvotes: 1
Reputation: 1754
What you need is an after hook
Create a file features/support/after_hooks.js
module.exports = function() {
this.After(function (scenario, callback) {
if (scenario.isFailed()) {
// Do your after stuff here
}
callback();
});
};
Note that this is only executed after every feature
Upvotes: 7