Я получаю данные с console.log (data);но он не возвращает даже req.params._id изнутри метода findOne Но он возвращает извне метод findOne
unitMethodTest = async (req, res, next) => {
await this.model.findOne({ _id: req.params._id }).exec((err, data) => {
if (err) {
console.log('===++++++ failed ');
return req.params._id;
}
else {
console.log(' Ok ')
// console.log(data);
return req.params._id; // Getting Error <--
}
});
// return req.params._id; // Test--2 Working fine <--
}
и мой тестовый код здесь: -
const req = {
params: { _id: '5cc14019fa1c2c68ee7e17f9', },
body: 'body'
}, next = 'next', res = 'response';
test('First Method Testing Demo for req.params and req.body', () => {
// expect.assertions(1);
const dataTest = controller.unitMethodTest(req, res, next);
console.log(dataTest);
// console.log(dataTest);
expect(dataTest).toEqual("5cc14019fa1c2c68ee7e17f9");
})
Я получаюВывести как следует
expect(received).toEqual(expected) // deep equality
Expected: "5cc14019fa1c2c68ee7e17f9"
Received: {}
53 | // console.log(dataTest);
54 | // // const dataTest = 11257;
> 55 | expect(dataTest).toEqual("5cc14019fa1c2c68ee7e17f9");
| ^
56 | done();
57 | // return controller.unitMethodTest(req, res, next).catch(e => expect(e).toEqual("5cc14019fa1c2c68ee7e17f9"));
58 | })
at Object.<anonymous> (server/unitTesting/caseload.test.ts:55:25)
console.log server/unitTesting/caseload.test.ts:52
Promise { <pending> }
Test Suites: 1 failed, 1 total
Tests: 1 failed, 1 total
Snapshots: 0 total
Time: 18.606s
Cannot log after tests are done. Did you forget to wait for something
async in your test?
Attempted to log " Ok ".