如何使用 cypress.io 检查嵌套阴影元素

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)