Dha*_*amo 2 javascript automated-tests shadow-dom cypress
如何定位位于嵌套影子 DOM 内的搜索框?
到目前为止,我已经尝试了几种不同的方法来定位,下面是其中之一,但它不起作用:
定位器:
//Shadow roots
const SDW_MAINAPP_G1 = "main-app"
const SDW_VOYAGETOPBAR_G2A = "voyage-topbar"
const SDW_VOYAGEPANEL_G2B = "voyage-float-panel"
const SDW_VESSELLIST_G3B = "voyage-vessel-list"
const SDW_VOYAGEFILTER_G4B1 = "voyage-filter"
const SDW_LISTSORT_G4B2 = "voyage-vessel-list-sort"
//Left Panel - Search Box
const INP_SEARCH_VESSEL = "#filter"
Run Code Online (Sandbox Code Playgroud)
实际代码:
class SearchComponents {
static validateSearchBar() {
cy.get(SDW_MAINAPP_G1)
.shadow()
.find(SDW_VOYAGEPANEL_G2B)
.find(SDW_VESSELLIST_G3B)
.find(SDW_VOYAGEFILTER_G4B1)
.find(INP_SEARCH_VESSEL)
.should('be.visible')
.should('be.enabled')
}
//...
}
Run Code Online (Sandbox Code Playgroud)
小智 6
嵌套的 Shadow-root 使得很难确定应该添加命令的位置,但您可以在配置(cypress.json).shadow()中全局启用 Shadow DOM 搜索
包括ShadowDom
是否遍历shadow DOM边界并在查询命令的结果中包含shadow DOM内的元素(例如cy.get())
赛普拉斯.json
{
...
includeShadowDom: true
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1834 次 |
| 最近记录: |