javascript - Protractor, when should I use then() after a click() - Stack Overflow

admin2025-02-19  1

I'm running an Angular app and when testing on protractor a click(), I don't know when should I resolve the promise with a then().

I found this on Protractor API:

A promise that will be resolved when the click mand has pleted.

So, should I use click().then() in every click?

I'm running an Angular app and when testing on protractor a click(), I don't know when should I resolve the promise with a then().

I found this on Protractor API:

A promise that will be resolved when the click mand has pleted.

So, should I use click().then() in every click?

Share Improve this question asked Oct 30, 2015 at 17:08 Joao FalcaoJoao Falcao 2741 gold badge3 silver badges12 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 10

So, should I use click().then() in every click?

Definitely not.

It's not needed because Protractor/WebDriverJS has this mechanism called "Control Flow" which is basically a queue of promises that need to be resolved:

WebDriverJS maintains a queue of pending promises, called the control flow, to keep execution organized.

and Protractor waits for Angular naturally and out-of-the-box:

You no longer need to add waits and sleeps to your test. Protractor can automatically execute the next step in your test the moment the webpage finishes pending tasks, so you don’t have to worry about waiting for your test and webpage to sync.

Which leads to a quite straight-forward testing code:

var elementToBePresent = element(by.css(".anotherelementclass")).isPresent();

expect(elementToBePresent.isPresent()).toBe(false);
element(by.css("#mybutton")).click();
expect(elementToBePresent.isPresent()).toBe(true);

Sometimes though, if you experience synchronization/timing issues, or your app under test is non-Angular, you may solve it by resolving the click() explicitly with then() and continue inside the click callback:

expect(elementToBePresent.isPresent()).toBe(false);
element(by.css("#mybutton")).click().then(function () {
    expect(elementToBePresent.isPresent()).toBe(true);
});

There are also Explicit Waits to the rescue in these cases, but it's not relevant here.

Yes, you should. Maybe right now it's not necessary, but maybe in next versions it is. So, if click return a promise, you should use it.

http://www.protractortest/#/api?view=webdriver.WebElement.prototype.click

转载请注明原文地址:http://conceptsofalgorithm.com/Algorithm/1739934568a112308.html

最新回复(0)