我想测试每个元素.elem1
是否包含元素.elem2
。试过这个,但似乎没有按预期工作:
expect(element.all(by.css('.elem1')).all(by.css('.elem2')).isDisplayed()).toBeTruthy();
答案 0 :(得分:2)
如何将elem1
元素的数量与内置elem1
元素的elem2
元素的数量进行比较:
var elem1count = element.all(by.xpath("//*[contains(@class, 'elem1')]")).count();
var elem1WithElem2count = element.all(by.xpath("//*[contains(@class, 'elem1') and .//*[contains(@class, 'elem2')]]")).count();
elem1WithElem2count.then(function (elem1WithElem2count) {
expect(elem1count).toEqual(elem1WithElem2count);
});
是的,那有点难看。
类似的想法,但使用filter()
:
var elem1count = element.all(by.css(".elem1")).count();
var elem1WithElem2count = element.all(by.css(".elem1")).filter(function (elem1) {
return elem1.element(by.css('.elem2')).isPresent();
}).count();
elem1WithElem2count.then(function (elem1WithElem2count) {
expect(elem1count).toEqual(elem1WithElem2count);
});
或者,您可以使用reduce()
解决问题:
var result = element.all(by.css('.elem1')).reduce(function(acc, elem1) {
return elem1.element(by.css('.elem2')).isPresent().then(function (isPresent) {
return acc && isPresent;
});
}, false);
expect(result).toBe(true);
这里,对于每个elem1
元素,我们得到一个布尔变量,指示是否存在elem2
元素,然后将所有布尔值减少为单个布尔值。
您也可以使用each()
并对expect
elem1
进行element.all(by.css('.elem1')).each(function(elem1) {
expect(elem1.element(by.css('.elem2')).isPresent()).toBe(true);
});
次检查:
public StatusBarNotification[] getActiveNotifications()