I have a protractor-jasmine test where I am trying to check that all the fields on the page are blank. I wrote a simple test using for loop that works. Now, my problem is that I am trying to adhere to protractor/jasmine best practices which say to have only one test per expect conditions. How do I change this code to only one expect conditions?
Here is the test I wrote:
it("should check that all input fields are blank", function() {
allInputs.then(function(elements) {
elements.forEach(function(element){
expect(element.getText()).toEqual("");
});
});
});
I have a protractor-jasmine test where I am trying to check that all the fields on the page are blank. I wrote a simple test using for loop that works. Now, my problem is that I am trying to adhere to protractor/jasmine best practices which say to have only one test per expect conditions. How do I change this code to only one expect conditions?
Here is the test I wrote:
it("should check that all input fields are blank", function() {
allInputs.then(function(elements) {
elements.forEach(function(element){
expect(element.getText()).toEqual("");
});
});
});
Share
Improve this question
asked Mar 8, 2017 at 13:02
RaviRavi
1011 silver badge12 bronze badges
1 Answer
Reset to default 3In Short: You can just do this - expect(allInputs.getText()).toEqual("")
.
More Details: element.all().getText()
returns an array containing the text values of all the child elements and since you are expecting the values to be blank, Just check if the total string is blank.
To answer you generic question of
"How do we handle a scenario when we have need multiple validations to be performed"
Expected Conditions provide conditional options - like OR, AND etc. Refer the official documentation here
var EC = protractor.ExpectedConditions;
var titleContainsFoo = EC.titleContains('Foo');
var titleIsNotFooBar = EC.not(EC.titleIs('FooBar'));
// Waits for title to contain 'Foo', but is not 'FooBar'
browser.wait(EC.and(titleContainsFoo, titleIsNotFooBar), 5000);
In case you would like to group multiple expects
Promise.all[
expect(allInputs.getText()).toEqual(""),
expect(allOutputs.getText()).toEqual("")
].then(function(){
done();
})
UPDATE 1: Promise.all
syntax above was incorrect. It should be Promise.all([Array of Promises])
where I had the curled braces missing.
This is the correct way of doing it
describe('Describe something', function() {
it('check check', function(done) {
browser.get('http://www.protractortest/#/')
Promise.all([
expect(browser.getCurrentUrl()).toContain('protractortest'),
expect(browser.getCurrentUrl()).toContain('org')]).then(function() {
done();
}).catch(function() {
done.fail('somehow the Url is incorrect');
})
browser.sleep(10000)
});
});
This gives us the flexibility to group all the validations in a test case into a single Promise(provide all promises returned by expects in an Array). This will help us group all the assertions and Pass/Fail the test case and throw a custom error message for all the set of Validations
UPDATE 2: As I mentioned above. element.all().getText()
returns an array and to pare, I incorrectly pared an Array object to String object.We need to do a array.join()
and pare
allInputs.getText().then(function(values){
expect(values.join('')).toEqual('')
})
发布者:admin,转转请注明出处:http://www.yc00.com/questions/1745158768a4614281.html
评论列表(0条)