如何解决Testcafe - 如何从 testcafe 中的主类调用 excel 数据驱动类?
获取“无法读取“forEach”未定义。我已经按照你说的执行了。但是,我仍然遇到错误。请给出解决方案
//单独类中的数据驱动脚本
import xlsx from "node-xlsx"
// read logic of excel
export function readDataFromExcelFile(filePath) {
const excelFile = xlsx.parse(filePath)
const excelSheet = excelFile.find((sheets) => sheets.name ==
"sheetname")
const excelSheetData = excelSheet.data
const headers = excelSheetData.shift()
const dataSet = excelSheetData.map((row) => {
const user = {}
row.forEach((data,idx) => (user[headers[idx]] = data))
return user
})
}
解决方法
如果我猜对了,您基本上是在尝试使用 TestCafé 实施数据驱动的测试。在您的情况下,数据源似乎是 Excel 文件。假设您有从一个 JavaScript 文件中的 excel 文件读取的代码:
// This is your file that contains your excel reading code,such as excel.js
import xlsx from "node-xlsx"
// the export keyword is necessary for the function so that it can be imported within other files
export function readDataFromExcelFile(filePath) {
// your excel file reading code goes here
}
将以下代码添加到包含测试代码的 JavaScript 文件中,以迭代您之前从 Excel 文件中检索到的数据集,并根据您的数据执行您需要执行的任何操作和断言:
import { readDataFromExcelFile} from './excel.js'; // import excel reading function from excel.js
// Create a fixture (test-suite) for your your data-driven tests
fixture `My data-driven tests`
.page `https://www.mySampleUrl/further/stuff/`;
const dataSet = readDataFromExcelFile("path/to/your/excel.xlsx")
// iterate over the dataSet that was previously returned from your readDataFromExcelFile function
dataSet.forEach(data => {
// Create & execute a test for each dataSet entry
test(`Test for'${data.someTestIdentifier}'`,async t => {
// Your test specific content. Test actions and assertions/validations come here
await t.expect(Selector("h1").textContent).eql(data.someDataEntry);
});
});
使用 TestCafé here 进一步了解数据驱动的测试。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。