mirror of
https://github.com/puppeteer/puppeteer
synced 2024-06-14 14:02:48 +00:00
203 lines
5.2 KiB
JavaScript
Executable File
203 lines
5.2 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
/**
|
|
* Copyright 2017 Google Inc. All rights reserved.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
const assert = require('assert');
|
|
const puppeteer = require('..');
|
|
const https = require('https');
|
|
const SUPPORTER_PLATFORMS = ['linux', 'mac', 'win32', 'win64'];
|
|
|
|
const fetchers = SUPPORTER_PLATFORMS.map((platform) =>
|
|
puppeteer.createBrowserFetcher({ platform })
|
|
);
|
|
|
|
const colors = {
|
|
reset: '\x1b[0m',
|
|
red: '\x1b[31m',
|
|
green: '\x1b[32m',
|
|
yellow: '\x1b[33m',
|
|
};
|
|
|
|
class Table {
|
|
/**
|
|
* @param {!Array<number>} columnWidths
|
|
*/
|
|
constructor(columnWidths) {
|
|
this.widths = columnWidths;
|
|
}
|
|
|
|
/**
|
|
* @param {!Array<string>} values
|
|
*/
|
|
drawRow(values) {
|
|
assert(values.length === this.widths.length);
|
|
let row = '';
|
|
for (let i = 0; i < values.length; ++i)
|
|
row += padCenter(values[i], this.widths[i]);
|
|
console.log(row);
|
|
}
|
|
}
|
|
|
|
if (process.argv.length === 2) {
|
|
checkOmahaProxyAvailability();
|
|
return;
|
|
}
|
|
if (process.argv.length !== 4) {
|
|
console.log(`
|
|
Usage: node check_revisions.js [fromRevision] [toRevision]
|
|
|
|
This script checks availability of different prebuild chromium revisions.
|
|
Running command without arguments will check against omahaproxy revisions.`);
|
|
return;
|
|
}
|
|
|
|
const fromRevision = parseInt(process.argv[2], 10);
|
|
const toRevision = parseInt(process.argv[3], 10);
|
|
checkRangeAvailability(
|
|
fromRevision,
|
|
toRevision,
|
|
false /* stopWhenAllAvailable */
|
|
);
|
|
|
|
async function checkOmahaProxyAvailability() {
|
|
const lastchanged = (
|
|
await Promise.all([
|
|
fetch(
|
|
'https://storage.googleapis.com/chromium-browser-snapshots/Mac/LAST_CHANGE'
|
|
),
|
|
fetch(
|
|
'https://storage.googleapis.com/chromium-browser-snapshots/Linux_x64/LAST_CHANGE'
|
|
),
|
|
fetch(
|
|
'https://storage.googleapis.com/chromium-browser-snapshots/Win/LAST_CHANGE'
|
|
),
|
|
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, true /* stopWhenAllAvailable */);
|
|
}
|
|
|
|
/**
|
|
* @param {number} fromRevision
|
|
* @param {number} toRevision
|
|
* @param {boolean} stopWhenAllAvailable
|
|
*/
|
|
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) {
|
|
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));
|
|
const availability = await Promise.all(promises);
|
|
const allAvailable = availability.every((e) => !!e);
|
|
const values = [
|
|
name +
|
|
' ' +
|
|
(allAvailable ? colors.green + revision + colors.reset : revision),
|
|
];
|
|
for (let i = 0; i < availability.length; ++i) {
|
|
const decoration = availability[i] ? '+' : '-';
|
|
const color = availability[i] ? colors.green : colors.red;
|
|
values.push(color + decoration + colors.reset);
|
|
}
|
|
table.drawRow(values);
|
|
return allAvailable;
|
|
}
|
|
|
|
/**
|
|
* @param {string} url
|
|
* @return {!Promise<?string>}
|
|
*/
|
|
function fetch(url) {
|
|
let resolve;
|
|
const promise = new Promise((x) => (resolve = x));
|
|
https
|
|
.get(url, (response) => {
|
|
if (response.statusCode !== 200) {
|
|
resolve(null);
|
|
return;
|
|
}
|
|
let body = '';
|
|
response.on('data', function (chunk) {
|
|
body += chunk;
|
|
});
|
|
response.on('end', function () {
|
|
resolve(body);
|
|
});
|
|
})
|
|
.on('error', function (e) {
|
|
console.error('Error fetching json: ' + e);
|
|
resolve(null);
|
|
});
|
|
return promise;
|
|
}
|
|
|
|
/**
|
|
* @param {number} size
|
|
* @return {string}
|
|
*/
|
|
function spaceString(size) {
|
|
return new Array(size).fill(' ').join('');
|
|
}
|
|
|
|
/**
|
|
* @param {string} text
|
|
* @return {string}
|
|
*/
|
|
function filterOutColors(text) {
|
|
for (const colorName in colors) {
|
|
const color = colors[colorName];
|
|
text = text.replace(color, '');
|
|
}
|
|
return text;
|
|
}
|
|
|
|
/**
|
|
* @param {string} text
|
|
* @param {number} length
|
|
* @return {string}
|
|
*/
|
|
function padCenter(text, length) {
|
|
const printableCharacters = filterOutColors(text);
|
|
if (printableCharacters.length >= length) return text;
|
|
const left = Math.floor((length - printableCharacters.length) / 2);
|
|
const right = Math.ceil((length - printableCharacters.length) / 2);
|
|
return spaceString(left) + text + spaceString(right);
|
|
}
|