- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个选项/按钮列表,我需要确保它们都设置为特定值。每个包装器都可以有多个按钮,但第一个按钮始终是我想要在运行测试之前设置的按钮。
因此我需要循环这些包装器并定位每个包装器的第一个子/按钮。
通常情况下,each()
会出现这种情况,但第一次点击后 Cypress 会出错 - DOM 重新呈现,Cypress 无法找到剩余的按钮。
因此我需要一个替代解决方案。其中之一是经典的 for
循环。这是代码:
<div>
<div class="ab-test-switch__experiment">
<div class="ab-test-switch__buttons"><button type="button" class="button ab-test-switch__button button--primary button--lg" data-variant="49_a">
49_a
</button><button type="button" class="button ab-test-switch__button button--secondary button--lg" data-variant="49_b">
49_b
</button>
</div>
</div>
<div class="ab-test-switch__experiment">
<div class="ab-test-switch__experiment__title">
<div class="v-popover">
<div class="trigger" style="display: inline-block;">
<p data-v-d7151c42="">(detail)</p>
</div>
</div>
</div>
<div class="ab-test-switch__buttons"><button data-v-7fea8896="" data-v-d7151c42="" type="button" class="button ab-test-switch__button button--secondary button--lg" data-variant="old_business_section" data-v-5c4d7450="">
old_business_section
</button><button data-v-7fea8896="" data-v-d7151c42="" type="button" class="button ab-test-switch__button button--primary button--lg" data-variant="new_business_section" data-v-5c4d7450="">
new_business_section
</button>
</div>
</div>
<div class="ab-test-switch__experiment">
<div class="ab-test-switch__experiment__title">
<h2 data-v-d7151c42="" data-v-5c4d7450="">53_mobile_banner</h2>
<div data-v-d7151c42="" class="v-popover" data-v-5c4d7450="">
<div class="trigger" style="display: inline-block;">
<p data-v-d7151c42="">(detail)</p>
</div>
</div>
</div>
<div class="ab-test-switch__buttons"><button type="button" class="button ab-test-switch__button button--secondary button--lg" data-variant="none" data-v-5c4d7450="">
none
</button><button type="button" class="button ab-test-switch__button button--primary button--lg" data-variant="mobile_banner" data-v-5c4d7450="">
mobile_banner
</button>
</div>
</div>
<div class="ab-test-switch__experiment">
<div class="ab-test-switch__experiment__title">
<div class="v-popover">
<div class="trigger" style="display: inline-block;">
<p>(detail)</p>
</div>
</div>
</div>
<div class="ab-test-switch__buttons"><button type="button" class="button ab-test-switch__button button--primary button--lg" data-v-5c4d7450="">
explore_a
</button><button type="button" class="button ab-test-switch__button button--secondary button--lg">
explore_b
</button>
</div>
</div>
</div>
// this fails as the DOM changes after each click
cy.get('.ab-test-switch__buttons > :nth-child(1)').each(($el) => {
cy.wrap($el).click()
cy.wait(1000) // didn't help, there's no race condition here
})
before(() => {
cy.visit('/company_profile_frontend/ab-test-switch')
// cy.get('.ab-test-switch__buttons > :nth-child(1)').click({ multiple: true, force: true }) (this didn't work either)
const numberOfAbTests = document.getElementsByClassName('ab-test-switch__buttons').length
for (let i = 1; i <= numberOfAbTests; i += 1) {
cy.get(`.ab-test-switch__buttons > :nth-child(${i})`).click().pause()
}
// cy.get('.ab-test-switch__buttons > :nth-child(1)').each(($el) => {
// cy.wrap($el).click().pause()
// // eslint-disable-next-line cypress/no-unnecessary-waiting
// cy.wait(1000)
// }) (another failed attempt)
})
还有其他方法吗?
最佳答案
只要在测试开始时知道 numberOfAbTests
并且不是从上一个命令计算或异步获取,for 循环就可以工作。
it('clicks buttons which become detached', () => {
const numberOfAbTests = 2;
...
for (let i = 1; i <= numberOfAbTests; i += 1) { // nth-child is 1-based not 0-based
cy.get(`.ab-test-switch__buttons > :nth-child(${i})`)
.click()
}
})
相当于
it('clicks all the buttons', () => {
cy.get('.ab-test-switch__buttons > :nth-child(1)').click()
cy.get('.ab-test-switch__buttons > :nth-child(2)').click()
})
因为 Cypress 运行循环并将按钮单击命令排队,然后如您所说,异步运行。
当 numberOfAbTests
不是静态已知时,您需要像@RosenMihaylov 所说的那样使用递归,但他的实现遗漏了一个关键因素 - 您必须在按钮分离的情况下重新查询它们/替换。
it('clicks all the buttons', () => {
cy.get('.ab-test-switch__buttons')
.then(buttons => {
const count = buttons.length; // button count not known before the test starts
clickButtonsInSuccession();
function clickButtonsInSuccession(i = 1) {
if (buttonIndex <= count) {
const buttonSelector = `.ab-test-switch__buttons > :nth-child(${i})`;
cy.get(buttonSelector) // re-query required here
.click()
clickButtonsInSuccession(i +1);
}
}
})
})
这假设 .ab-test-switch__buttons
是按钮的容器,所以 DOM 的结构类似于这样
<div class=".ab-test-switch__buttons">
<button>one</button>
<button>two</button>
</div>
查看扩展代码
您需要在 DOM 加载后通过查询来获取测试计数,但是
const numberOfAbTests = document.getElementsByClassName('ab-test-switch__buttons').length;
是同步代码,它在 之前运行任何命令,包括 cy.visit()
,因此它返回 0。
将测试分两步运行,第一步运行所有同步代码,然后运行命令。
异常是回调中的同步代码,例如 .then(callbackFn)
有效地将 callbackFn
插入命令队列以在命令之间顺序运行。
您可以使用命令查询 numberOfAbTests
并将值传递到 .then()
cy.get('.ab-test-switch__buttons')
.its('length')
.then(numberOfAbTests => {
for (let i = 1; i <= numberOfAbTests; i += 1) {
...
}
})
或者在before()
中访问并计数,然后在it()
中循环,
let numberOfAbTests;
before(() => {
// All commands here run before it() starts
cy.visit('../app/ab-test-switch.html').then(() => {
numberOfAbTests = Cypress.$('.ab-test-switch__buttons').length;
})
})
it('tests the button', () => {
for (let i = 1; i <= numberOfAbTests; i += 1) {
...
}
})
或者忘记计算测试,只使用 .each()
cy.get('.ab-test-switch__buttons')
.each($abTest => {
cy.wrap($abTest).find('button')
.each($button => {
cy.wrap($button).click();
})
})
选择器
选择器 .ab-test-switch__buttons > :nth-child(${i})
是有问题的,因为索引 i
指的是 abTest 按钮组,但是您正在尝试使用它来单击各个按钮。
所以使用for循环,
for (let i = 0; i < numberOfAbTests; i += 1) { // NB :nth() is 0-based
// in contrast to :nth-child()
// which is 1-based
cy.get(`.ab-test-switch__buttons:nth(${i}) > button`)
.eq(0).click() // click button A
cy.get(`.ab-test-switch__buttons:nth(${i}) > button`)
.eq(1).click() // click button B
}
关于html - 使用 for 循环单击 Cypress 上的元素列表而不使用每个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67488307/
我是 PHP 新手。我一直在脚本中使用 for 循环、while 循环、foreach 循环。我想知道 哪个性能更好? 选择循环的标准是什么? 当我们在另一个循环中循环时应该使用哪个? 我一直想知道要
我在高中的编程课上,我的作业是制作一个基本的小计和顶级计算器,但我在一家餐馆工作,所以制作一个只能让你在一种食物中读到。因此,我尝试让它能够接收多种食品并将它们添加到一个价格变量中。抱歉,如果某些代码
这是我正在学习的一本教科书。 var ingredients = ["eggs", "milk", "flour", "sugar", "baking soda", "baking powder",
我正在从字符串中提取数字并将其传递给函数。我想给它加 1,然后返回字符串,同时保留前导零。我可以使用 while 循环来完成此操作,但不能使用 for 循环。 for 循环只是跳过零。 var add
编辑:我已经在程序的输出中进行了编辑。 该程序要求估计给定值 mu。用户给出一个值 mu,同时还提供了四个不等于 1 的不同数字(称为 w、x、y、z)。然后,程序尝试使用 de Jaeger 公式找
我正在编写一个算法,该算法对一个整数数组从末尾到开头执行一个大循环,其中包含一个 if 条件。第一次条件为假时,循环可以终止。 因此,对于 for 循环,如果条件为假,它会继续迭代并进行简单的变量更改
现在我已经习惯了在内存非常有限的情况下进行编程,但我没有答案的一个问题是:哪个内存效率更高;- for(;;) 或 while() ?还是它们可以平等互换?如果有的话,还要对效率问题发表评论! 最佳答
这个问题已经有答案了: How do I compare strings in Java? (23 个回答) 已关闭 8 年前。 我正在尝试创建一个小程序,我可以在其中读取该程序的单词。如果单词有 6
这个问题在这里已经有了答案: python : list index out of range error while iteratively popping elements (12 个答案) 关
我正在尝试向用户请求 4 到 10 之间的整数。如果他们回答超出该范围,它将进入循环。当用户第一次正确输入数字时,它不会中断并继续执行 else 语句。如果用户在 else 语句中正确输入数字,它将正
我尝试创建一个带有嵌套 foreach 循环的列表。第一个循环是循环一些数字,第二个循环是循环日期。我想给一个日期写一个数字。所以还有另一个功能来检查它。但结果是数字多次写入日期。 Out 是这样的:
我想要做的事情是使用循环创建一个数组,然后在另一个类中调用该数组,这不会做,也可能永远不会做。解决这个问题最好的方法是什么?我已经寻找了所有解决方案,但它们无法编译。感谢您的帮助。 import ja
我尝试创建一个带有嵌套 foreach 循环的列表。第一个循环是循环一些数字,第二个循环是循环日期。我想给一个日期写一个数字。所以还有另一个功能来检查它。但结果是数字多次写入日期。 Out 是这样的:
我正在模拟一家快餐店三个多小时。这三个小时分为 18 个间隔,每个间隔 600 秒。每个间隔都会输出有关这 600 秒内发生的情况的统计信息。 我原来的结构是这样的: int i; for (i=0;
这个问题已经有答案了: IE8 for...in enumerator (3 个回答) How do I check if an object has a specific property in J
哪个对性能更好?这可能与其他编程语言不一致,所以如果它们不同,或者如果你能用你对特定语言的知识回答我的问题,请解释。 我将使用 c++ 作为示例,但我想知道它在 java、c 或任何其他主流语言中的工
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我是 C 编程和编写代码的新手,以确定 M 测试用例的质因数分解。如果我一次只扫描一次,该功能本身就可以工作,但是当我尝试执行 M 次时却惨遭失败。 我不知道为什么 scanf() 循环有问题。 in
这个问题已经有答案了: JavaScript by reference vs. by value [duplicate] (4 个回答) 已关闭 3 年前。 我在使用 TSlint 时遇到问题,并且理
我尝试在下面的代码中添加 foreach 或 for 循环,以便为 Charts.js 创建多个数据集。这将允许我在此折线图上创建多条线。 我有一个 PHP 对象,我可以对其进行编码以稍后填充变量,但
我是一名优秀的程序员,十分优秀!