chore: allow downloading the latest Chrome version (#9719)
This commit is contained in:
parent
84845e4901
commit
e3d8524738
@ -20,6 +20,7 @@ import {hideBin} from 'yargs/helpers';
|
|||||||
|
|
||||||
import {resolveRevision} from './browsers/browsers.js';
|
import {resolveRevision} from './browsers/browsers.js';
|
||||||
import {Browser, BrowserPlatform} from './browsers/types.js';
|
import {Browser, BrowserPlatform} from './browsers/types.js';
|
||||||
|
import {detectBrowserPlatform} from './detectPlatform.js';
|
||||||
import {fetch} from './fetch.js';
|
import {fetch} from './fetch.js';
|
||||||
import {computeExecutablePath, launch} from './launcher.js';
|
import {computeExecutablePath, launch} from './launcher.js';
|
||||||
|
|
||||||
@ -68,8 +69,13 @@ export class CLI {
|
|||||||
},
|
},
|
||||||
async argv => {
|
async argv => {
|
||||||
const args = argv as unknown as InstallArgs;
|
const args = argv as unknown as InstallArgs;
|
||||||
|
args.platform ??= detectBrowserPlatform();
|
||||||
|
if (!args.platform) {
|
||||||
|
throw new Error(`Could not resolve the current platform`);
|
||||||
|
}
|
||||||
args.browser.revision = await resolveRevision(
|
args.browser.revision = await resolveRevision(
|
||||||
args.browser.name,
|
args.browser.name,
|
||||||
|
args.platform,
|
||||||
args.browser.revision
|
args.browser.revision
|
||||||
);
|
);
|
||||||
await fetch({
|
await fetch({
|
||||||
|
@ -32,6 +32,7 @@ export {Browser, BrowserPlatform};
|
|||||||
|
|
||||||
export async function resolveRevision(
|
export async function resolveRevision(
|
||||||
browser: Browser,
|
browser: Browser,
|
||||||
|
platform: BrowserPlatform,
|
||||||
tag: string
|
tag: string
|
||||||
): Promise<string> {
|
): Promise<string> {
|
||||||
switch (browser) {
|
switch (browser) {
|
||||||
@ -40,6 +41,11 @@ export async function resolveRevision(
|
|||||||
case BrowserTag.LATEST:
|
case BrowserTag.LATEST:
|
||||||
return await firefox.resolveRevision('FIREFOX_NIGHTLY');
|
return await firefox.resolveRevision('FIREFOX_NIGHTLY');
|
||||||
}
|
}
|
||||||
|
case Browser.CHROME:
|
||||||
|
switch (tag as BrowserTag) {
|
||||||
|
case BrowserTag.LATEST:
|
||||||
|
return await chrome.resolveRevision(platform, 'latest');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// We assume the tag is the revision if it didn't match any keywords.
|
// We assume the tag is the revision if it didn't match any keywords.
|
||||||
return tag;
|
return tag;
|
||||||
|
@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
|
|
||||||
|
import {httpRequest} from '../httpUtil.js';
|
||||||
|
|
||||||
import {BrowserPlatform} from './types.js';
|
import {BrowserPlatform} from './types.js';
|
||||||
|
|
||||||
function archive(platform: BrowserPlatform, revision: string): string {
|
function archive(platform: BrowserPlatform, revision: string): string {
|
||||||
@ -79,3 +81,40 @@ export function relativeExecutablePath(
|
|||||||
return path.join('chrome-win', 'chrome.exe');
|
return path.join('chrome-win', 'chrome.exe');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function resolveRevision(
|
||||||
|
platform: BrowserPlatform,
|
||||||
|
// We will need it for other channels/keywords.
|
||||||
|
_channel: 'latest' = 'latest'
|
||||||
|
): Promise<string> {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
const request = httpRequest(
|
||||||
|
new URL(
|
||||||
|
`https://storage.googleapis.com/chromium-browser-snapshots/${folder(
|
||||||
|
platform
|
||||||
|
)}/LAST_CHANGE`
|
||||||
|
),
|
||||||
|
'GET',
|
||||||
|
response => {
|
||||||
|
let data = '';
|
||||||
|
if (response.statusCode && response.statusCode >= 400) {
|
||||||
|
return reject(new Error(`Got status code ${response.statusCode}`));
|
||||||
|
}
|
||||||
|
response.on('data', chunk => {
|
||||||
|
data += chunk;
|
||||||
|
});
|
||||||
|
response.on('end', () => {
|
||||||
|
try {
|
||||||
|
return resolve(String(data));
|
||||||
|
} catch {
|
||||||
|
return reject(new Error('Chrome version not found'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
false
|
||||||
|
);
|
||||||
|
request.on('error', err => {
|
||||||
|
reject(err);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
@ -83,4 +83,15 @@ describe('CLI', function () {
|
|||||||
'--platform=linux',
|
'--platform=linux',
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('should download latest Chrome binaries', async () => {
|
||||||
|
await new CLI(tmpDir).run([
|
||||||
|
'npx',
|
||||||
|
'@puppeteer/browsers',
|
||||||
|
'install',
|
||||||
|
`chrome@latest`,
|
||||||
|
`--path=${tmpDir}`,
|
||||||
|
'--platform=linux',
|
||||||
|
]);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user