From 3bbc45af8b36171c14fd0bfba739d1c468a42199 Mon Sep 17 00:00:00 2001 From: Andrey Lushnikov Date: Mon, 29 Jul 2019 14:29:50 -0700 Subject: [PATCH] chore: improve //utils/check_availability.js (#4770) This patch teaches `//utils/check_availability.js` to break when it is run with no arguments and it finds an available revision. --- utils/check_availability.js | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/utils/check_availability.js b/utils/check_availability.js index f839adb2ed002..c4b0b1d1ba884 100755 --- a/utils/check_availability.js +++ b/utils/check_availability.js @@ -64,7 +64,7 @@ Running command without arguments will check against omahaproxy revisions.`); const fromRevision = parseInt(process.argv[2], 10); const toRevision = parseInt(process.argv[3], 10); -checkRangeAvailability(fromRevision, toRevision); +checkRangeAvailability(fromRevision, toRevision, false /* stopWhenAllAvailable */); async function checkOmahaProxyAvailability() { const lastchanged = (await Promise.all([ @@ -74,25 +74,30 @@ async function checkOmahaProxyAvailability() { fetch('https://storage.googleapis.com/chromium-browser-snapshots/Win_x64/LAST_CHANGE'), ])).map(s => parseInt(s, 10)); const from = Math.max(...lastchanged); - checkRangeAvailability(from, 0); + checkRangeAvailability(from, 0, true /* stopWhenAllAvailable */); } /** * @param {number} fromRevision * @param {number} toRevision + * @param {boolean} stopWhenAllAvailable */ -async function checkRangeAvailability(fromRevision, toRevision) { +async function checkRangeAvailability(fromRevision, toRevision, stopWhenAllAvailable) { const table = new Table([10, 7, 7, 7, 7]); table.drawRow([''].concat(SUPPORTER_PLATFORMS)); const inc = fromRevision < toRevision ? 1 : -1; - for (let revision = fromRevision; revision !== toRevision; revision += inc) - await checkAndDrawRevisionAvailability(table, '', revision); + for (let revision = fromRevision; revision !== toRevision; revision += inc) { + const allAvailable = await checkAndDrawRevisionAvailability(table, '', revision); + if (allAvailable && stopWhenAllAvailable) + break; + } } /** * @param {!Table} table * @param {string} name * @param {number} revision + * @return {boolean} */ async function checkAndDrawRevisionAvailability(table, name, revision) { const promises = fetchers.map(fetcher => fetcher.canDownload(revision)); @@ -105,6 +110,7 @@ async function checkAndDrawRevisionAvailability(table, name, revision) { values.push(color + decoration + colors.reset); } table.drawRow(values); + return allAvailable; } /**