javascript - 为网站自动化生成 JavaScript 测试对象的最佳方法是什么

标签 javascript html-parsing functional-testing

背景介绍: 该团队正在使用 C# 编写 QUnit UI 测试浏览器自动化测试。我想创建一个可以在两者之间共享的 JSON 对象。这样,如果类名发生更改,配置文件只需要在一处进行更新。

该站点使用模板非常动态,因此这些测试对象配置文件必须在运行时创建,不能只解析静态 html。

我可以手动生成数据结构或编写一个工具来帮助我捕获 ID/类,然后修改生成的数据结构。我不想手动编写代码,因为我的团队正在测试的网站有数百个控件。

测试将利用这些测试对象来简化维护,因为站点经常变动,我们当前的测试每天都会中断。一旦所有测试都引用相同的测试对象,则只需要修复该对象配置。

目前我正在考虑创建一个 JavaScript 函数,它接受一个选择器并为该元素及其子元素生成所有属性。我可以在运行时调用传递控件的函数,我想抓取、剪切和粘贴输出以供以后使用。有没有更好的方法来生成这些对象?

插图:

带有子项 A、B、C 的导航栏。可以选择一个。

<div id="nav-bar">
    <div class="a selected">A</div>
    <div class="b">B</div>
    <div class="c">C</div>
</div>

我想创建以下代码(jQuery 样式选择器):

var nav_bar = {
    selector: "#nav-bar",
    children: {
        a: { selector: ".a" },
        b: { selector: ".b" },
        c: { selector: ".c" },
    }
}

然后我可以手动添加一些特殊属性,例如 selectedItem:

var nav_bar = {
    selector: "#nav-bar",
    children: {
        a: { selector: ".a" },
        b: { selector: ".b" },
        c: { selector: ".c" },
        selectedItem: { selector: ".selected" }
    }
}

这样我就可以解析 nav_bar 对象来创建一个有用的测试对象:

var nav = createTestObject(nav_bar);
// var nav = {a: $(".a", "#nav-bar"), b: $(".b", "#nav-bar"), selectedItem: function() { return $(".selected", "#nav-bar"); }}
// Can automate a simple test at this point...could use some more helper functions
// Click b if not already selected
if(nav.b[0] != nav.selectedItem()[0])
{
   nav.b.click(); // assumes clicking causes selected class to change
}

如果类“.selected”发生变化,我不必在整个测试代码中搜索和替换,只需更新 selectedItem.selector 的配置文件即可。

提前致谢, 乔

最佳答案

我不明白你试图通过生成测试对象来实现什么。执行 nav.b.click() 后,您是否要测试 b 现在是所选类?

您应该考虑使用 PhantomJS或使用 Zombie.js 进行测试.

关于javascript - 为网站自动化生成 JavaScript 测试对象的最佳方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10696076/

相关文章:

javascript - 如何在不删除的情况下隐藏一段 HTML?

javascript - 如何在 Javascript 中删除字符串中的所有非数字字符(不包括减号、点和逗号)?

html-parsing - 使用 JSoup 解析输入元素

php - 如何使用 Symfony 爬虫组件和 PHPUnit 测试提交错误值的表单?

ios - EarlGrey - 如何检查屏幕上是否显示多个对象

javascript - 如何使用 CSS 滤镜或 colorMatrix 对图像应用 VIBRANCE 效果

javascript - 没有再生器的 babel-plugin-transform-async-to-module-method

python - 使用 Python 替换 HTML 文档中的 HTML 标记,而不修改文档的其余部分

html - 任何主流浏览器是否都有内置的 HTML 验证器?

go - 在端点上运行测试之前,无法在BeforeSuit中启动应用程序服务器