【问题标题】:Dynamically generate tests in Jest在 Jest 中动态生成测试
【发布时间】:2018-06-19 21:11:04
【问题描述】:

我正在寻找一种在 Jest 中生成测试并运行它们的方法。我正在测试一个 API,并且测试用例是从一个 CSV 文件中导入的,并从中生成测试。

目前我得到的是一组参数,我想从中生成测试并运行它们。这就是我认为它的工作方式:

let testFn =  (testName, request, expected) => it(test.testName, (request, expected) => {
    return new Promise((resolve, reject) => {
        http.post(request, (err, res) => {
            if (err) {
                reject(err);
            } else {
                resolve(res);
            }
        })
    }).then((res) => {
        expect(res.result).toBe(expected['result']);
        return response;
    })
});

上面的代码是我的测试函数。如我所见,应该调用它来执行测试。它根据 3 个参数生成测试:

  • testName 是他的测试名称,显示在控制台中
  • request 是发送到 API 的请求
  • expected 是预期结果。

结构始终相同:res.result 应该是 参数expect

我从 CSV 获得的带有测试的数组元素示例如下:

const oneTest = {
    testName: 'the request should return 10',
    request: {
        input: 10
    },
    expected: {
        result: 10
    }
}

在这里,我们遍历测试数组并运行所有测试。这是我无法完成的部分。

for (let test in tests) {
    testFn.apply(this, [test.testName, test.request, test.expected])
}

由此产生的预期结果是,我将从数组中生成所有测试,运行并在控制台中显示结果。

我希望我解释清楚我的问题是什么,但如果不是这样,请不要犹豫(毕竟你是在帮助我!)

PS:这是我第一次使用 Jest,所以我可能会以错误的方式假设很多事情。如果你看到一些完全的愚蠢,请注意它,我很高兴学习! :)

【问题讨论】:

  • 感谢您的编辑,迈克!

标签: javascript testing code-generation jestjs


【解决方案1】:

我认为这不需要摩卡。也许诀窍是您不必在测试中嵌套测试生成函数,只需在顶层运行它:

这是一个完整的文件,其中包含两个失败的测试和一个通过的测试。

// demo.test.js
const tests = [1, 2, 3];

tests.forEach(value =>
  it(`Expects ${value} to equal 2`, () => expect(value).toEqual(2))
);

及其输出:

Test Suites: 1 failed, 1 total
Tests:       2 failed, 1 passed, 3 total
Snapshots:   0 total
Time:        0.712s
Ran all test suites related to changed files.

【讨论】:

  • 如果我必须异步加载 [1, 2, 3](例如从 fs),我该怎么做?
  • 不回答你的问题@mspoulsen 但如果你只是从 fs 阅读,也许 readFileSync 是一个很好的回避
  • 是的,我在其他地方也得到了这个提示……它解决了我的问题。谢谢!
【解决方案2】:

原来 Jest 中的默认测试运行器是 Jasmine 2,它不支持嵌套的 it() 语句。我的解决方案是改用 Mocha,确实如此。

【讨论】:

    猜你喜欢
    • 2020-08-05
    • 1970-01-01
    • 1970-01-01
    • 2016-06-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-02-24
    • 2022-09-27
    相关资源
    最近更新 更多