1

在某些操作后,我需要以某种方式捕获 ngToast 消息。我尝试了该站点的不同解决方案,但它们没有帮助我,我也不知道为什么。有没有人有一个可行的解决方案?我最后一次尝试是这样的:

var HomePage = require('./home.pageObject');

describe('Home Page tests', function () {
  var homePage = new HomePage();
  var EC = protractor.ExpectedConditions;

  beforeEach(function () {
      browser.get('/#/');
  });

  it('should fail login', function () {
      var toast = $('.ng-toast');
      homePage.signinBtn.click();
      homePage.login('admin', 'Password')
          .then(function () {
              var toast = $('.alert');
              browser.wait(EC.visibilityOf(toast), 3000);
          });
  });
});

谢谢。

4

2 回答 2

1

显示后检查 toast 元素,然后尝试使用 css 获取消息。

在我们使用 angular-toastr 的一个项目中,这可以解决问题:

element(by.css('#toast-container .toast-message')
于 2016-11-26T17:24:53.827 回答
1

您可以使用此函数并在测试中调用它:首先我在 dom 中等待存在,然后是可见性,然后我返回文本:

this.returnToastText= function(){

    browser.wait(EC.presenceOf(element(by.css(".alert"))), 3000).then(function () {
        browser.wait(EC.visibilityOf(element(by.css(".alert"))), 3000).then(function () {
            return toastText= element(by.css(".alert")).getText();
        })
    })

};
于 2016-11-28T09:39:24.607 回答