量角器 - 按钮单击会比预期更快地调用回调

时间:2015-07-19 05:11:25

标签: javascript angularjs selenium-webdriver jasmine protractor

我对登录页面进行了量角器测试,提交了信用卡并检查是否加载了索引页面。我将回调函数传递给按钮单击的then函数,假设在click函数返回的承诺解析后将调用回调函数。

var protractor = require('protractor')
describe('E2E: main page', function() {
  beforeEach(function() {
    browser.get('http://localhost:8001/login.html/');
  });
  it("login in the portal", function(){
    var d = protractor.promise.defer();
    element(by.model('loginParams.email')).sendKeys('saravana0209@r.com');
    element(by.model('loginParams.password')).sendKeys('password');
    element(by.name('normalLogin')).click().then(function(){
        //it crashes here before selecting the sub menu item
        element(by.xpath('//a[@title="subMenuItem"]')).click()
        console.log("sub-menu item has been chosen in the ribbon")
        setTimeout(function() { d.fulfill('ok')}, 50000)
    })
    expect(d).toBe('ok');
  })
});

但是当页面加载正在进行并且它崩溃了测试时,回调被调用,因为仍然没有加载titlesubMenuItem的元素。 错误是,

Error: Failed: invalid selector: Unable to locate an element with the xpath expression //a[@title="Venues"] because of the following error:
TypeError: Failed to execute 'createNSResolver' on 'Document': parameter 1 is not of type 'Node'.

2 个答案:

答案 0 :(得分:8)

在点击之前,您可以等待子菜单可见

var EC = protractor.ExpectedConditions;

element(by.name('normalLogin')).click().then(function() {
    var subMenu = element(by.xpath('//a[@title="subMenuItem"]'));

    browser.wait(EC.visibilityOf(subMenu), 5000);
    subMenu.click();

    console.log("sub-menu item has been chosen in the ribbon");
    setTimeout(function() { d.fulfill('ok')}, 50000);
});

因为看起来所有的问题都来自手动角度引导,你会have to use browser.driver.get()

  

如果您的页面执行手动引导,则Protractor将无法加载   您的页面使用browser.get。而是使用基本webdriver实例    - browser.driver.get。这意味着Protractor不知道您的页面何时完全加载,并且您可能需要添加一个wait语句   确保你的测试避免竞争条件。

这可能会导致类似:

element(by.name('normalLogin')).click(); 
browser.sleep(3000); 
browser.driver.get("index.html");

登录,让它通过延迟登录(睡眠不好,是的)并手动获取索引页面。

您也可以通过设置browser.ignoreSynchronization = true;来处理量角器和角度之间禁用的同步,但这有很多缺点 - 您必须开始大量使用显式等待(browser.wait())。您可以尝试使用此标记并暂时将其设置为true,然后再加载页面并在之后重新设置为false

答案 1 :(得分:1)

你试过这个吗?:

 element(by.name('normalLogin')).click()
    browser.wait(function() {
      return browser.driver.isElementPresent(by.xpath('//a[@title="Venues"]'))
    }).then(function(){
         var venueLink = by.xpath('//a[@title="Venues"]')
         browser.driver.isElementPresent(venueLink).then(function(){
           console.log("tenant login process successful")
           element(venueLink).click()
        })
    });

量角器异步工作,所以

var venueLink = by.xpath('//a[@title="Venues"]')

将执行

browser.wait(function() {
      return browser.driver.isElementPresent(by.xpath('//a[@title="Venues"]'))
    })