Quiero descargar datos de series temporales de un servicio de descanso. Actualmente, tengo la siguiente implementación.
async function getTimeSeriesQuery(i) { // Using this to show how gql is being used appollo.query(getChunkQueryOptions(i)) } var promises = [] for(var i = 0; i < numberChunks; i++) { promises.push(getTimeSeriesQuery(i)) }
const data = Promise.all(promises)
Esperaba que las promesas tomaran la misma cantidad de tiempo que una promesa, pero parece escalar con la cantidad de promesas que tengo en la lista de promesas.
El tiempo de ejecución de cada promesa no tiene nada que ver con el número de promesas en la lista ni con el tiempo de ejecución de otra promesa.
Promise.all no comienza la ejecución de Promises, solo espera a que finalicen. Si todas las Promesas ya se resolvieron antes (por ejemplo, si todas las solicitudes HTTP ya terminaron), Promise.all se resolverá en un valor casi de inmediato, porque simplemente no hay nada que esperar. Promise.all, da en una lista los resultados de cada promesa.
Ejemplo: Tenemos una lista de 2 promesas: - 1 toma 10s - 2 toma 1s Promise.all tomará 10s.
Como se mencionó, la duración de cada solicitud no se puede determinar de antemano.
Sin embargo, si desea esperar a que se complete todo, debe agregar las promesas en su matriz (lo que no hace el fragmento que publicó). Y si desea los datos en una variable, deberá usar .then
o await
los resultados.
Por lo tanto, debe devolver la promesa real de su getTimeSeriesQuery
async function getTimeSeriesQuery(i) { // Using this to show how gql is being used // was missing the return return appollo.query(getChunkQueryOptions(i)) } var promises = [] for(var i = 0; i < numberChunks; i++) { promises.push(getTimeSeriesQuery(i)) } const data = await Promise.all(promises)