将赛普拉斯与 vuetify 一起使用

Using cypress with vuetify

我有一个 Vue.js 项目 (Nuxt.js),作为 UI 我使用 Vuetify。 对于 e2e 测试,我使用 Cypress。

以下是我在 Cypress 中的测试场景:

我在为使用 v-autocomplete 组件的页面创建测试时遇到问题。 问题是我无法使用 Vuetify native classes 来获取我要测试的元素。 下面是一个带有 data-cy selector

的例子
   <v-autocomplete
      v-model="model"
      :items="items"
      item-text="Description"
      item-value="API"
      label="Public APIs"
      placeholder="Start typing to Search"
      data-cy="autocomplete"
    ></v-autocomplete> 

我在搜索输入中输入了一些文本。 然后在v-autocomplete中已经找到了搜索结果。 其中之一的示例如下:

...
    <div>
       <a class="v-list__tile v-list__tile--link theme--light">
         <div class="v-list__tile__content">
         <div class="v-list__tile__title">Result item
           <span class="v-list__tile__mask">result item</span>
         </div>
         </div>
       </a>
   </div>
...

然后我想要 select 通过单击找到的结果之一来搜索项目之一。 为此,我应该使用 Vuetify 的原生 classes,但它不稳定(.v-list__tile--link class ñ 由开发人员重命名)。 如何将 data-cy selector 添加到结果搜索 html 项中? 也许谁知道解决此问题的其他方法?

我不认为 v-list__tile--link 可以由开发人员更改,它似乎是在运行时添加的 DOM 由 Vuetify 库(除非你指的是 Vuetify 开发人员,然后确定它可以在版本)。

无论如何,如果您想在选择器中更加面向内容,请使用 Cypress .parent() 选择器

例如,

cy.contains('div', 'itemTextToSelect').parent('a').click()

如果可能,请确保 'itemTextToSelect' 确实与众不同(如果您可以在测试夹具中设置它)。


顺便说一句,在用户开始输入之前,自动完成列表是 display: none,因此您需要 .type('something') 输入,或者 .click({force: true}) 项目。