Sinon 存根不允许对实际功能进行测试覆盖
Sinon stub not allowing for test coverage on actual function
下面是被测函数:
export const callStoredProcedure = async (procedureName, procedureArgs)
=> {
let resultSet: any;
try {
await knexClient.transaction(async trx => {
await trx.raw(`CALL ${procedureName}(${procedureArgs});`).then(result => {
if (result[0] && result[0][0]) {
resultSet = JSON.stringify(result[0][0]);
}
});
});
} catch (err) {
console.log(err);
}
return resultSet;
};
这里我在 beforeEach 块中模拟 knexClient:
let knexClientMock;
beforeEach(() => {
// Stub Data source clients
const rawStub = sinon.stub().resolves([{ affectiveRows: 0, insertId: 0 }]);
knexClientMock = sinon.stub(knexClient, 'transaction').callsFake(
async (): Promise<any> => {
return {
raw: rawStub,
};
},
);
});
然而,当我 运行 我测试 if 语句时 if (result[0] && result[0][0])
从来没有 运行s 和 Jest 覆盖显示从 raw
语句到 catch
.
mock 似乎工作正常,因为它使用了 mock knexClient.transaction
,但未覆盖其余行。我想我只想用模拟承诺结果模拟 raw
函数,并允许 .then
函数 运行.
我如何才能仅模拟 knexClient.transaction.raw
函数并允许其余代码具有测试覆盖率?
问题是您的测试存根没有正确模拟正在使用的对象:
代码中的“事务”方法采用单个参数(回调函数)并调用此回调,将其传递给具有异步“原始”方法的事务执行器.
您的测试存根使“事务”方法 return 成为具有异步原始方法的对象。
为代码编写单元测试时,首先了解代码的工作原理非常重要。否则,很容易编写无法防止引入错误的无意义测试。
下面是被测函数:
export const callStoredProcedure = async (procedureName, procedureArgs)
=> {
let resultSet: any;
try {
await knexClient.transaction(async trx => {
await trx.raw(`CALL ${procedureName}(${procedureArgs});`).then(result => {
if (result[0] && result[0][0]) {
resultSet = JSON.stringify(result[0][0]);
}
});
});
} catch (err) {
console.log(err);
}
return resultSet;
};
这里我在 beforeEach 块中模拟 knexClient:
let knexClientMock;
beforeEach(() => {
// Stub Data source clients
const rawStub = sinon.stub().resolves([{ affectiveRows: 0, insertId: 0 }]);
knexClientMock = sinon.stub(knexClient, 'transaction').callsFake(
async (): Promise<any> => {
return {
raw: rawStub,
};
},
);
});
然而,当我 运行 我测试 if 语句时 if (result[0] && result[0][0])
从来没有 运行s 和 Jest 覆盖显示从 raw
语句到 catch
.
mock 似乎工作正常,因为它使用了 mock knexClient.transaction
,但未覆盖其余行。我想我只想用模拟承诺结果模拟 raw
函数,并允许 .then
函数 运行.
我如何才能仅模拟 knexClient.transaction.raw
函数并允许其余代码具有测试覆盖率?
问题是您的测试存根没有正确模拟正在使用的对象:
代码中的“事务”方法采用单个参数(回调函数)并调用此回调,将其传递给具有异步“原始”方法的事务执行器.
您的测试存根使“事务”方法 return 成为具有异步原始方法的对象。
为代码编写单元测试时,首先了解代码的工作原理非常重要。否则,很容易编写无法防止引入错误的无意义测试。