如何使用Cypress将没有id属性的嵌套输入作为目标?

2022-03-13 00:00:00 reactjs html css cypress end-to-end

我正在为Reaction项目编写一个Cypress测试。我需要能够将嵌套在<label>中的<input>作为目标,这样我才能在该输入字段中键入内容。<input>%s没有类ID。

这是我的HTML。

    <label class="Input">
        <div class="label">LABEL TEXT</div>
        <input type="text">
    </label>

我有许多相同表单中的输入,与上面显示的HTML完全相同。它们的区别仅在于<div>中的文本(即标签文本)。

我将<input>放在标签标签中的原因是,我希望用户能够通过单击标签文本或输入周围的任何位置来确定输入的目标。仅仅为了Cypress测试,向输入添加类对我们的代码库没有意义。我不能使用伪选择器,例如:Firstcy.get('input[type="text"]:first'),因为如果我向表单添加其他输入,我不希望测试失败。

我尝试了以下操作,但它尝试在标签中而不是输入中键入内容。

  cy.contains('LABEL TEXT')
      .click()
      .type('test')

即使它将焦点放在Cypress测试运行器中,它仍会尝试键入<div>,而不是焦点输入。

因为我对Cypress和断言非常陌生,所以我只能挠头。我感兴趣的是一种解决方案(如果可能的话),它不会仅仅为了Cypress测试而向我的输入中添加类。我希望这只是我在CSS、Cypress或断言知识方面的不足。

谢谢

div

我刚刚复制了与您完全相同的场景,即有几个相同的标签,只是内部推荐答案的文本不同。Miguel Carvajal的答案很接近,但需要进行一些调整。以下代码工作正常:

cy.get("div[class='label']").contains("LABEL TEXT2").parent().within(() => {
   cy.get("input[type='text']").type("StackOverflowHelp")
})

在以下HTML上测试:

<label class="Input">
  <div class="label">LABEL TEXT1</div>
  <input type="text">
</label>
<label class="Input">
  <div class="label">LABEL TEXT2</div>
  <input type="text">
</label>

结果:

相关文章