如何解决无法使用leftOf选中复选框
我试图单击文本(作为服务器)左侧的复选框。
我的HTML代码如下。
<td>
<input type="checkbox" ng-model="asset.isChecked" ng-change="selectEntity(filteredTableElements,asset.id)" class="ng-valid ng-dirty ng-valid-parse ng-empty ng-touched">
</td>
<td class="ng-binding">as-server</td>
我浏览了空手道文档,并尝试了多种情况,但是没有一个能够找到该复选框。
场景1:
* leftOf('{}as-server').find('input[type="checkbox"]').click
()
输出:评估(js)失败:leftOf('{} as-server')。find('input [type =“ checkbox”]')。click(),java.lang.RuntimeException:找不到: {}作为服务器,向左输入[type =“ checkbox”] 堆栈跟踪:com.intuit.karate.driver.ElementFinder.find(ElementFinder.java:120)
场景2:
* leftOf('{}as-server').click()
输出:评估(js)失败:leftOf('{} as-server')。click(),java.lang.RuntimeException:找不到:{} as-server,LEFT,INPUT 堆栈跟踪:com.intuit.karate.driver.ElementFinder.find(ElementFinder.java:120)
我在这里错过了什么吗?空手道还有其他方法吗?
谢谢!
解决方法
UI测试并不容易。可能有很多原因,例如您使用的Angular可能会在页面上做一些额外的事情并隐藏元素区域。方便的位置是“友好的定位器”,但是如果无法立即使用,则应该花一些时间进行故障排除。如果您遵循此过程,以便我们可以改善框架,那就太好了:https://github.com/intuit/karate/tree/develop/examples/ui-test
因此,也许您应该尝试其他方法,而空手道会给您带来很多好处。例如:
* locate('{}as-server').previousSibling.firstChild.click()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。