/** * Copyright 2023 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. */ import fs from 'fs'; import path from 'path'; import {Browser, BrowserPlatform} from './browser-data/browser-data.js'; /** * The cache used by Puppeteer relies on the following structure: * * - rootDir * -- | browserRoot(browser1) * ---- - | installationDir() * ------ the browser-platform-buildId * ------ specific structure. * -- | browserRoot(browser2) * ---- - | installationDir() * ------ the browser-platform-buildId * ------ specific structure. * @internal */ export class Cache { #rootDir: string; constructor(rootDir: string) { this.#rootDir = rootDir; } browserRoot(browser: Browser): string { // Chromium is a special case for backward compatibility: we install it in // the Chrome folder so that Puppeteer can find it. return path.join( this.#rootDir, browser === Browser.CHROMIUM ? Browser.CHROME : browser ); } installationDir( browser: Browser, platform: BrowserPlatform, buildId: string ): string { return path.join(this.browserRoot(browser), `${platform}-${buildId}`); } clear(): void { fs.rmSync(this.#rootDir, { force: true, recursive: true, maxRetries: 10, retryDelay: 200, }); } }