I have a async function that waits for an axios call to complete before proceeding. The problem is that I need to put a timeout on the axios call to half a second so that I don’t hit the shopify API call limit.
async function processMatchingSchools(customer_metafield_url) {
for (const item of customer_metafield_url) {
await axios.get(item).then((res) => {
for (key in res.data.metafields) {
if (res.data.metafields[key].value === schoolName) {
id_for_each_student.push(shopifyAdmin + "/customers/" + res.data.metafields[key].owner_id + "/metafields.json")
}
}
})
}
console.log("Customer metafields to search", id_for_each_student)
processOwnerIds(id_for_each_student)
}
when I try putting a setTimeout, it calls the setTimeout and moves on before completing the axios calls.
async function processMatchingSchools(customer_metafield_url) {
for (const item of customer_metafield_url) {
await setTimeout(function(item) {
axios.get(item).then((res) => {
for (key in res.data.metafields) {
if (res.data.metafields[key].value === schoolName) {
id_for_each_student.push(shopifyAdmin + "/customers/" + res.data.metafields[key].owner_id + "/metafields.json")
}
}
})
}, 500)
}
console.log("Customer metafields to search", id_for_each_student)
processOwnerIds(id_for_each_student)
}
Any help?
6
Answers
await
only works on promises.You need to wrap
setTimeout
in a promise:Create a
sleep
function that returns a promise that you can use, like so:And to use it in an async function:
setTimeout does not return a promise so cannot be
await
ed.You could create your own promise-based
setTimeout
and use that.setTimeout()
doesn’t return aPromise
, but you can wrap it in one like this. I also cleaned up the rest of your code a little.You need to to create new promise for example like that
And then use it in your code before calling API
I created
setTimeout2
function that works the same just as a promise:So, altogether (noticed the setTimeout2 change):