量角器在下拉列表中选择错误的选项。我必须:选择第一个下拉列表打开另一个下拉列表(在我的情况下:选择付款方法(第一个下拉列表)打开第二个下拉列表-可用信用卡):重要时刻:如果第一个下拉列表有默认值-第二个下拉列表不可见。
我的代码有不同的变体:
let paymentDropdown = element(by.name("payment-method"));
let dynamicBlock = $$(".dynamic").first();
let useThisCardButton = element(by.name("do-add-payment-method»));
let paymentConfigBlock = element(by.id("payment-config-container"));
browser.wait(EC.visibilityOf(paymentDropdown), 5000);
$("#payment-method-0 > option:nth-child(2)").click();
browser.wait(EC.visibilityOf(dynamicBlock), 5000);
useThisCardButton.click();
browser.wait(EC.visibilityOf(paymentConfigBlock), 5000);因此,我尝试了第一个下拉列表:
1. $("#payment-method-0 > option:nth-child(2)").click();
2. element(by.name("payment-method"))
.all(by.tagName('option'))
.get(1)
.click();
3. element(by.cssContainingText('option', 'Credit Card')).click();
4. element(by.name("payment-method")).$('[value="cc"]').click();Html是:
<select name="payment-method" id="payment-method-0" style="display: inline-block;">
<option value="0">Select Payment Method</option>
<option value="cc">Credit Card</option>
</select>什么都没有!我不知道它是如何工作的,但是第一个下拉列表有默认值,第二个下拉列表是可见的!然后我点击«Use this method»按钮,结果失败了!10个测试中有1个测试选择了正确的第一个值,所以测试通过了。但是其他9次试验都失败了。为什么?如何正确操作,以及如何确保选择正确的选项?
发布于 2019-04-08 13:12:59
试试下面这个。在这里,您可以在不打开下拉的情况下选择值。
var firstDrop = element(by.css('#payment-method-0'));
browser.wait(EC.elementToBeClickable(firstDrop), 5000);
firstDrop.sendKeys('Credit Card');
browser.wait(EC.visibilityOf(dynamicBlock), 5000);希望能对你有所帮助
https://stackoverflow.com/questions/55553294
复制相似问题