gpt4 book ai didi

javascript - es6 模块中其他函数使用的 stub 函数

转载 作者:行者123 更新时间:2023-11-28 20:28:51 24 4
gpt4 key购买 nike

我一直在考虑如何测试同一文件中其他函数使用的特定函数。

例如,假设我在一个文件中有两个函数:

// validators.js
export const required = ...;
export const containsUppercase = ...;
export const containsNumber = ...;

export const password = (val) => [required, containsUppercase, containsNumber].every(f => f(val));

很明显,密码验证器依赖于requiredcontainsUppercasecontainsNumber 函数。但是,如果我想将它们 stub 怎么办,这样我的测试实际上就不必关心这些函数或它们如何验证。

这是一个简单、愚蠢的例子,但我在更复杂的场景中遇到了同样的问题。

例如,如果我尝试用 sinon 执行此操作,我可能会尝试这样做:

import * as validators from './validators';

sinon.stub(validators, 'required').returns(false);
sinon.stub(validators, 'containsUppercase').returns(true);
sinon.stub(validators, 'containsNumber').returns(true);

// test
expect(validators.password('notImportant')).toBe(false);

我试过这样做,但我无法让它工作。我发现如果我这样做的话,我可以让它工作,尽管我还没有测试过它。

const required = ...;
const containsUppercase = ...;
const containsNumber = ...;

const password = (val) => [ex.required, ex.containsUppercase, ex.containsNumber].every(f => f(val));

export default ex = {
required,
containsUppercase,
containsNumber,
password,
}

这个解决方案也很丑陋,因为我现在不得不担心在正确的地方导出函数,并通过导出对象引用它。

有没有更简洁的方法来做到这一点?或者更确切地说,测试这些功能的最佳方法是什么?

最佳答案

第二个片段中的模式是正确的。 password 应该引用对象方法,以便在 validators.js 范围之外模拟它们。

在 JS 中自然实现这种行为的方法是使用 this:

export class Validators {
required = (...) => { ... }
...
password = (val) => [this.required, ...].every(...);
}

export default new Validators;

或者,使用普通(非箭头)函数:

export default {
required(...) {
...
}
...
password(val) {
[this.required, ...].every(...);
}
}

在第二种情况下,required 等方法在像 [this.required, ...] .every(...).

关于javascript - es6 模块中其他函数使用的 stub 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39368476/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com