I like the async await syntax, and I use it a lot with mongoose.
So in my project there is plenty of :
const user = await User.findOne({
_id: req.params.id
})
Which works just as expected. However, in sonarqube, I have these errors :
Refactor this redundant 'await' on a non-promise.
And the sonarqube rule i :
It is possible to use await on values which are not Promises, but it's useless and misleading. The point of await is to pause execution until the Promise's asynchronous code has run to completion. With anything other than a Promise, there's nothing to wait for.
This rule raises an issue when an awaited value is guaranteed not to be a Promise.
Noncompliant Code Example
let x = 42;
await x; // Noncompliant
Compliant Solution
let x = new Promise(resolve => resolve(42));
await x;
let y = p ? 42 : new Promise(resolve => resolve(42));
await y;
I am using mongo 4.0 and mongoose 5.3.1
Since I can use the .then
, .catch
syntax I thought that I was dealing with promise so how could I fix that ?
I do not know much about SonarQube
. I just figured out SonarQube
is tool to check the code quality and get that it required await
only prefix with the promises
and there mongoose
fails even having .then
.
Mongoose queries do not return "fully-fledged" promise even they have .then()
. So in order to get "fully-fledged" promise you need to use .exec()
function.
const user = await User.findOne({ _id: req.params.id }).exec()
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With