我倾向于通过建立一个行人版本来了解正在发生的事情,只需说我被困在一个必须检查executor
函数是否已传递给{{ 1}}有constructor
和resolve
作为参数。
这是测试。
reject
到目前为止我所拥有的:
it('gets called with two different functions (funception!), resolve and reject', function() {
var promise = new $Promise(executor); // eslint-disable-line no-unused-vars
var argsPassedIntoExecutor = executor.calls.argsFor(0);
expect(argsPassedIntoExecutor.length).toBe(2);
var resolve = argsPassedIntoExecutor[0];
var reject = argsPassedIntoExecutor[1];
expect(typeof resolve).toBe('function');
expect(typeof reject).toBe('function');
expect(resolve).not.toBe(reject);
});
这是我尝试过的(摘自上文),但无济于事:
function $Promise(fnc) {
if (typeof arguments[0] !== 'function') {
throw new TypeError('Sorry argument passed to $Promise should an executor function');
}
function ArgumentsToArray(args) {
return [].slice.apply(args);
}
console.log(ArgumentsToArray.apply(fnc));
this._state = 'pending';
this._value = null;
this._internalResolve = function(data) {
if (this._state !== 'pending') return;
this._value = data;
this._state = 'fulfilled';
};
this._internalReject = function(data) {
if (this._state !== 'pending') return;
this._value = data;
this._state = 'rejected';
};
return fnc();
}
任何帮助将不胜感激!
答案 0 :(得分:1)
对于你的问题,javascript中不存在命名参数,我们所拥有的是具有length
属性和参数解构的函数arity(带有警告)。所以没有办法测试参数的名称和#34;。对于您的测试,您可以这样做:
const spy = ( resolve, reject ) => {
expect(typeof resolve).toBe("function");
expect(typeof resolve).toBe("function");
};
并将此间谍传递给您的构造函数。
这是一项有趣的尝试,但您应该尝试从规范开始。规范引入的Promise
构造函数主要用于发现(具有constructor
属性)。
以下是规范:https://promisesaplus.com/,只是尝试理解并重新实现一个简单的resolve
启动程序,规范确实有一个测试套件来帮助你(作为npm包分发)。 / p>