4

这是我在使用 Protractor 测试 Angular 应用程序时尝试做的事情。我想得到某个元素,有点像这样:

<div class="someClass">
   <p>{{textFromBoundModel}}</p>
</div>

然后获取它的 html,并检查它是否包含我期望它具有的文本。

我尝试通过该cssContainingText方法首先获取此元素,但效果不佳(不知道为什么;可能是因为段落中的文本是动态生成的)。所以现在我只使用by.css定位器来获取这个元素。接下来,我正在检查它是否包含我正在测试的文本:

// this is Cucumber.js    

this.Then(/^Doing my step"$/, function(callback){
    var el = element(by.css('.someClass'));            
    expect(el).to.contain("some interesting string");
    callback();
 });
});

但这不起作用。问题是,el是某种定位器对象,我不知道如何获取它找到的元素的 html 以便针对这个 html 进行测试。尝试了 .getText(),但没有成功。

有什么建议么?

4

2 回答 2

5

做:

expect(el.getText()).to.eventually.contain("some interesting string");

工作?

我相信您需要.eventually等待承诺解决,并且您需要.getText()获取div.

请参阅黄瓜样品开头的 chai-as-promised 内容。

于 2015-03-13T04:44:22.613 回答
5

尝试以下对我

有用的 解决方案解决方案 1:

expect(page.getTitleText()).toContain('my app is running!');

解决方案 2:

expect<any>(page.getTitleText()).toEqual('my app is running!');
于 2019-09-20T05:26:14.923 回答