Home > database >  Nodejs async/await not working as expected
Nodejs async/await not working as expected

Time:02-20

I have an express API that reads from my fauna database. I have a class setup called Database that handles all my fauna queries, and an async method called getQuotes that essentially gets a fauna document, the general structure is like this:

async getQuotes() {
    // note, `query` is an async function
    const doc = this.client.query(...).then((res) => {
        const data = ...; // to keep this short I'm not gonna show this
        console.log("faunadb handler: "   data); // just for debug
        return Promise.resolve(data);
    })
}

Then when I start the express API, I have it call the getQuotes method and log the data (just for debug).

const quotes = db.getQuotes().then((quotes) => {
    console.log("fauna consumer: "   quotes);
})

Now, when I run the app, I get the following output:

starting server on port.... ussual stuff
fauna consumer: undefined
faunadb handler: { ... }

The fauna consumer code runs before we actually get the promise from the fauna query API. I need to use .then because node for some reason doesn't allow me to use await. Does anyone know how to solve this? Thank you! (using node version v16.14.0, running on Arch Linux)

CodePudding user response:

You aren't returning anything from your getQuotes() function. The return in your callback is only going to return from the callback, not from the enclosing function. You also aren't awaiting anywhere, which means your async function is not going to actual wait on the result of your query.

CodePudding user response:

Don't mix up await and then. Either use one or another.
I'd recommend to go with await.

async getQuotes() {
    // note, `query` is an async function
    const res = await this.client.query(...)
    const doc = ...; // to keep this short I'm not gonna show this
    console.log("faunadb handler: "   doc); // just for debug
    return doc;
}

CodePudding user response:

try to use await

async getQuotes() {
    const res = await this.client.query(...);
    const data = ...;
    console.log("faunadb handler: "   data); // just for debug
    return data;
}
// must be in async function
const quotes = await db.getQuotes();
console.log("fauna consumer: "   quotes);

CodePudding user response:

The problem is that you need to return data fromgetQuotesPlease just change the code as follows (replace the placeholders):

  async getQuotes() {
    // note, `query` is an async function
    const res = await this.client.query(...)
    const data = ...; // to keep this short I'm not gonna show this
    console.log("faunadb handler: "   data); // just for debug
    return data
  }

CodePudding user response:

getQuotes function should return the result like this.

async getQuotes() {
    // note, `query` is an async function
    return this.client.query(...).then((res) => {
        const data = ...; // to keep this short I'm not gonna show this
        console.log("faunadb handler: "   data); // just for debug
        return Promise.resolve(data);
    })
}

or

async getQuotes() {
    // note, `query` is an async function
    const doc = await this.client.query(...);
    const data = ...; // to keep this short I'm not gonna show this
    console.log("faunadb handler: "   data); // just for debug
    return Promise.resolve(data);
}
  • Related