javascript - Nightwatch .element() 总是使用数组中的最后一个值
问题描述
我有一个守夜测试,我正在测试移动应用内容 RSS、CSS 和 HTML“提要”的 url 列表。它们位于数组中,例如:
var rssFeeds = [
'https://www.example.com/rss/feed1',
'https://www.example.com/rss/feed2',
]
在我的测试中,我使用 for 循环遍历数组中的每个 url 以进行测试,例如:
var urlToTest = ''; //< -- this is always 'https://www.example.com/rss/feed2' in .element check below
// rss Feeds
for (var i = 0; i < rssFeeds.length; i++) {
urlToTest = rssFeeds[i].toString()
browser
.url('https://validator.w3.org/feed/')
.waitForElementVisible('body', 'W3C RSS Validator page loaded... https://validator.w3.org/feed/ \n')
.setValue('#url', urlToTest)
.click('a[class="submit"]')
.element('css selector', 'img[title="Valid RSS"]', function (result) {
if (result.value && result.value.ELEMENT) {
// Element is present, do the appropriate tests
console.log('valid RSS...')
browser.perform(function () {
browser.verify.ok(1 == 1, urlToTest + ' valid RSS...') //<-- HERE
})
} else {
// Element is not present.
console.log('invalid RSS...')
browser.verify.ok(1 != 1, urlToTest + ' invalid RSS...') //<-- AND HERE
}
})
}
在每次.url()
调用中,它会依次正确输入 feed1、feed2 等,但是,在.element()
调用中它始终是数组中的最后一个值,因此报告看起来是错误的。它总是看起来像:
✓ 应用内容
TC004-AppContent
✓ W3C RSS 验证器页面已加载... https://validator.w3.org/feed/
✓ 通过 [ok]:https ://www.example.com/rss/feed2有效 RSS...
✓ W3C RSS 验证器页面已加载... https://validator.w3.org/feed/
✓ 通过 [ok]:https ://www.example.com/rss/feed2有效 RSS..
因此,由于urlToTest
始终是最后一个数组值,因此该报告现在不是很有帮助,因为不区分什么 url 是好/坏。我尝试在调用中包装代码的不同部分,perform()
试图让它在需要时准确运行,但无济于事。
我也看到了帖子,.execute()
但我就是不明白...
任何想法都非常感谢。
解决方案
根据此处描述的 javascript 问题,我必须将.element()
调用移动到循环外的函数中
所以,现在的代码是:
var urlToTest = '';
// rss Feeds
for (var i = 0; i < rssFeeds.length; i++) {
urlToTest = rssFeeds[i].toString()
browser
.url('https://validator.w3.org/feed/')
.waitForElementVisible('body', 'W3C RSS Validator page loaded... https://validator.w3.org/feed/')
.setValue('#url', urlToTest)
.click('a[class="submit"]')
.waitForElementVisible('body', 'W3C results page loaded...')
checkElement(browser, 'img[title="Valid RSS"]', urlToTest)
}
和
// must call from outside loop in order to maintain proper syncronous execution
function checkElement(browser, elem, url) {
browser.element('css selector', elem, function (result) {
if (result.value && result.value.ELEMENT) {
// Element is present, do the appropriate tests
browser.verify.ok(1 == 1, url + ' valid feed...')
} else {
// Element is not present.
browser.verify.ok(1 != 1, url + ' invalid feed...')
}
})
}
推荐阅读
- c++ - 0-1 大重量背包
- java - 如何通过 Spring-Expression-Language 或其他方式根据 jobParameters 有条件地注入 bean?
- android - 使用 SQLLite、imageViews 和可回收的 RecyclerView 性能 = false
- python - 是否有可能在 Python 中只获得一定数量的组合?
- java - 为什么我有一个将 int 转换为 Integer JAVA 的 ClassCastException
- python - ModuleNotFoundError:没有名为“xgboost.sklearn”的模块
- ios - 如何为每个伊斯兰祈祷倒计时
- c# - 将数组的元素除以 2 次 k 次,以使数组的和最小化
- sql - 如何修复 ER-Diagram 中的冗余?
- gnuplot - 如何使用gnuplot添加带有标签的垂直线?