mirror of
				https://github.com/microsoft/playwright.git
				synced 2025-06-26 21:40:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			175 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			175 lines
		
	
	
		
			5.1 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 browserFetcher = require('../lib/install/browserFetcher.js');
 | |
| const https = require('https');
 | |
| const SUPPORTER_PLATFORMS = ['linux', 'mac', 'win32', 'win64'];
 | |
| 
 | |
| const fetcherOptions = SUPPORTER_PLATFORMS.map(platform => platform === 'mac' ? 'mac10.15' : 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([15, 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, 'chromium', revision);
 | |
|     if (allAvailable && stopWhenAllAvailable)
 | |
|       break;
 | |
|   }
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @param {!Table} table
 | |
|  * @param {string} name
 | |
|  * @param {number} revision
 | |
|  * @return {boolean}
 | |
|  */
 | |
| async function checkAndDrawRevisionAvailability(table, name, revision) {
 | |
|   const promises = fetcherOptions.map(platform => browserFetcher.canDownload(name, revision, platform));
 | |
|   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);
 | |
| }
 | 
