Is it possible to run a for loop in .then using Protractor?

Is it possible to run a for loop in .then using Protractor? I am trying to do something like this:

element.all(by.css('.select2-results li')).then(function(item) {
    for(i = 0; i < item.lenght; i++){
        browser.actions().mouseMove(item[i]).perform(); 
        browser.sleep(500); 
    }
});

      

But it seems like Protractor is ignoring the for loop, can you please help me?

I used .each, but when I ran it I got it:

StaleElementReferenceError: stale element reference: element is not attached to the page document
      (Session info: chrome=43.0.2357.130)
      (Driver info: chromedriver=2.13.307647 (5a7d0541ebc58e69994a6fb2ed930f45261f3c
    29),platform=Windows NT 6.2 x86_64) (WARNING: The server did not provide any sta
    cktrace information)
    Command duration or timeout: 7 milliseconds
    For documentation on this error, please visit: http://seleniumhq.org/exceptions/
    stale_element_reference.html
    Build info: version: '2.44.0', revision: '76d78cf', time: '2014-10-23 20:02:37'
    System info: host: 'AVANTEK-PC01', ip: '192.168.56.1', os.name: 'Windows 8', os.
    arch: 'amd64', os.version: '6.2', java.version: '1.7.0_51'
    Session ID: 3f5e0df8acf94705c936176f21bb05bd
    Driver info: org.openqa.selenium.chrome.ChromeDriver
    Capabilities [{platform=WIN8, acceptSslCerts=true, javascriptEnabled=true, brows
    erName=chrome, chrome={userDataDir=C:\Users\MARCEL~1.ORT\AppData\Local\Temp\scop
    ed_dir208_14914}, rotatable=false, locationContextEnabled=true, mobileEmulationE
    nabled=false, version=43.0.2357.130, takesHeapSnapshot=true, cssSelectorsEnabled
    =true, databaseEnabled=false, handlesAlerts=true, browserConnectionEnabled=false
    , webStorageEnabled=true, nativeEvents=true, applicationCacheEnabled=false, take
    sScreenshot=true}]

      

The code I use is:

  element.all(by.css('.select2-results li')).each(function(elm) {
         browser.actions().mouseMove(elm).perform();
         browser.sleep(500);
         var el = elm.getAttribute('class');
         expect(el).toContain('select2-results-dept-0 select2-result select2-result-selectable select2-highlighted');
         expect(elm.getCssValue('background-color')).toEqual('rgba(114, 101, 91, 1)');
         elm.click();
    });

      

+3


source to share


1 answer


Instead of a for loop, a more "protractor" solution would be to use each()

:

Calls an input function on each ElementFinder that is represented by an ElementArrayFinder.



element.all(by.css('.select2-results li')).each(function(elm) {
    browser.actions().mouseMove(elm).perform(); 
    browser.sleep(500); 
});

      

0


source







All Articles