feat(browser): add a method to get installed browsers (#10057)

This commit is contained in:
Alex Rudenko 2023-04-21 11:34:03 +02:00 committed by GitHub
parent 704624eb20
commit e16e2a9728
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 63 additions and 18 deletions

View File

@ -19,6 +19,16 @@ import path from 'path';
import {Browser, BrowserPlatform} from './browser-data/browser-data.js'; import {Browser, BrowserPlatform} from './browser-data/browser-data.js';
/**
* @public
*/
export type InstalledBrowser = {
path: string;
browser: Browser;
buildId: string;
platform: BrowserPlatform;
};
/** /**
* The cache used by Puppeteer relies on the following structure: * The cache used by Puppeteer relies on the following structure:
* *
@ -65,4 +75,50 @@ export class Cache {
retryDelay: 500, retryDelay: 500,
}); });
} }
getInstalledBrowsers(): InstalledBrowser[] {
if (!fs.existsSync(this.#rootDir)) {
return [];
}
const types = fs.readdirSync(this.#rootDir);
const browsers = types.filter((t): t is Browser => {
return (Object.values(Browser) as string[]).includes(t);
});
return browsers.flatMap(browser => {
const files = fs.readdirSync(this.browserRoot(browser));
return files
.map(file => {
const result = parseFolderPath(
path.join(this.browserRoot(browser), file)
);
if (!result) {
return null;
}
return {
path: path.join(this.browserRoot(browser), file),
browser,
platform: result.platform,
buildId: result.buildId,
};
})
.filter((item): item is InstalledBrowser => {
return item !== null;
});
});
}
}
function parseFolderPath(
folderPath: string
): {platform: string; buildId: string} | undefined {
const name = path.basename(folderPath);
const splits = name.split('-');
if (splits.length !== 2) {
return;
}
const [platform, buildId] = splits;
if (!buildId || !platform) {
return;
}
return {platform, buildId};
} }

View File

@ -25,7 +25,7 @@ import {
BrowserPlatform, BrowserPlatform,
downloadUrls, downloadUrls,
} from './browser-data/browser-data.js'; } from './browser-data/browser-data.js';
import {Cache} from './Cache.js'; import {Cache, InstalledBrowser} from './Cache.js';
import {debug} from './debug.js'; import {debug} from './debug.js';
import {detectBrowserPlatform} from './detectPlatform.js'; import {detectBrowserPlatform} from './detectPlatform.js';
import {unpackArchive} from './fileUtil.js'; import {unpackArchive} from './fileUtil.js';
@ -97,16 +97,6 @@ export interface InstallOptions {
unpack?: boolean; unpack?: boolean;
} }
/**
* @public
*/
export type InstalledBrowser = {
path: string;
browser: Browser;
buildId: string;
platform: BrowserPlatform;
};
/** /**
* @public * @public
*/ */

View File

@ -26,12 +26,7 @@ export {
WEBDRIVER_BIDI_WEBSOCKET_ENDPOINT_REGEX, WEBDRIVER_BIDI_WEBSOCKET_ENDPOINT_REGEX,
Process, Process,
} from './launch.js'; } from './launch.js';
export { export {install, canDownload, InstallOptions} from './install.js';
install,
canDownload,
InstallOptions,
InstalledBrowser,
} from './install.js';
export {detectBrowserPlatform} from './detectPlatform.js'; export {detectBrowserPlatform} from './detectPlatform.js';
export { export {
resolveBuildId, resolveBuildId,
@ -42,4 +37,4 @@ export {
ProfileOptions, ProfileOptions,
} from './browser-data/browser-data.js'; } from './browser-data/browser-data.js';
export {CLI, makeProgressCallback} from './CLI.js'; export {CLI, makeProgressCallback} from './CLI.js';
export {Cache} from './Cache.js'; export {Cache, InstalledBrowser} from './Cache.js';

View File

@ -100,6 +100,10 @@ describe('Chrome install', () => {
}); });
assert.strictEqual(browser.path, expectedOutputPath); assert.strictEqual(browser.path, expectedOutputPath);
assert.ok(fs.existsSync(expectedOutputPath)); assert.ok(fs.existsSync(expectedOutputPath));
// Should discover installed browsers.
const cache = new Cache(tmpDir);
const installed = cache.getInstalledBrowsers();
assert.deepStrictEqual(browser, installed[0]);
}); });
it('throws on invalid URL', async function () { it('throws on invalid URL', async function () {