mirror of
				https://github.com/microsoft/playwright.git
				synced 2025-06-26 21:40:17 +00:00 
			
		
		
		
	 505d94ab1a
			
		
	
	
		505d94ab1a
		
			
		
	
	
	
	
		
			
			This patch: - drops dependency on playwright-core in all our packages. Instead of the dependency, packages are now built with `//packages/build_package.sh` script. - unifies `browsers.json` - now there's a single `//browsers.json` file that is used to manage browser revisions. This patch temporary switches canary publishing to `--dryn-run` from CI/CD so that we can verify that it does sane things. We'll unify all our package management scripts under `//packages/` in a follow-up. Fixes #2268
		
			
				
	
	
		
			175 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			175 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env node
 | |
| /**
 | |
|  * Copyright (c) Microsoft Corporation.
 | |
|  *
 | |
|  * 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 fs = require('fs');
 | |
| const path = require('path');
 | |
| const rmSync = require('rimraf').sync;
 | |
| const ncp = require('ncp');
 | |
| const {spawnSync} = require('child_process');
 | |
| const util = require('util');
 | |
| 
 | |
| const writeFileAsync = util.promisify(fs.writeFile.bind(fs));
 | |
| const cpAsync = util.promisify(ncp);
 | |
| 
 | |
| const SCRIPT_NAME = path.basename(__filename);
 | |
| const ROOT_PATH = path.join(__dirname, '..');
 | |
| 
 | |
| const PACKAGE_FILES = ['lib', 'types', 'NOTICE', 'LICENSE', '.npmignore'];
 | |
| 
 | |
| const PACKAGES = {
 | |
|   'playwright': {
 | |
|     description: 'A high-level API to automate web browsers',
 | |
|     whitelistedBrowsers: ['chromium', 'firefox', 'webkit'],
 | |
|     // We copy README.md additionally for Playwright so that it looks nice on NPM.
 | |
|     files: [...PACKAGE_FILES, 'README.md'],
 | |
|   },
 | |
|   'playwright-core': {
 | |
|     description: 'A high-level API to automate web browsers',
 | |
|     whitelistedBrowsers: [],
 | |
|     files: PACKAGE_FILES,
 | |
|   },
 | |
|   'playwright-webkit': {
 | |
|     description: 'A high-level API to automate WebKit',
 | |
|     whitelistedBrowsers: ['webkit'],
 | |
|     files: PACKAGE_FILES,
 | |
|   },
 | |
|   'playwright-firefox': {
 | |
|     description: 'A high-level API to automate Firefox',
 | |
|     whitelistedBrowsers: ['firefox'],
 | |
|     files: PACKAGE_FILES,
 | |
|   },
 | |
|   'playwright-chromium': {
 | |
|     description: 'A high-level API to automate Chromium',
 | |
|     whitelistedBrowsers: ['chromium'],
 | |
|     files: PACKAGE_FILES,
 | |
|   },
 | |
| };
 | |
| 
 | |
| const cleanupPaths = [];
 | |
| 
 | |
| // 1. Parse CLI arguments
 | |
| const args = process.argv.slice(2);
 | |
| if (args.some(arg => arg === '--help')) {
 | |
|   console.log(usage());
 | |
|   process.exit(1);
 | |
| } else if (args.length < 1) {
 | |
|   console.log(`Please specify package name, e.g. 'playwright' or 'playwright-chromium'.`);
 | |
|   console.log(`Try running ${SCRIPT_NAME} --help`);
 | |
|   process.exit(1);
 | |
| } else if (args.length < 2) {
 | |
|   console.log(`Please specify output path`);
 | |
|   console.log(`Try running ${SCRIPT_NAME} --help`);
 | |
|   process.exit(1);
 | |
| }
 | |
| 
 | |
| // 2. Setup cleanup if needed
 | |
| if (!args.some(arg => arg === '--no-cleanup')) {
 | |
|   process.on('exit', () => { 
 | |
|     cleanupPaths.forEach(cleanupPath => rmSync(cleanupPath, {}));
 | |
|   });
 | |
|   process.on('SIGINT', () => process.exit(2));
 | |
|   process.on('SIGHUP', () => process.exit(3));
 | |
|   process.on('SIGTERM', () => process.exit(4));
 | |
|   process.on('uncaughtException', error => {
 | |
|     console.error(error);
 | |
|     process.exit(5);
 | |
|   });
 | |
|   process.on('unhandledRejection', error => {
 | |
|     console.error(error);
 | |
|     process.exit(6);
 | |
|   });
 | |
| }
 | |
| 
 | |
| const packageName = args[0];
 | |
| const outputPath = path.resolve(args[1]);
 | |
| const packagePath = path.join(__dirname, packageName);
 | |
| const package = PACKAGES[packageName];
 | |
| if (!package) {
 | |
|   console.log(`ERROR: unknown package ${packageName}`);
 | |
|   process.exit(1);
 | |
| }
 | |
| 
 | |
| (async () => {
 | |
|   // 3. Copy package files.
 | |
|   for (const file of package.files)
 | |
|     await copyToPackage(file);
 | |
| 
 | |
|   // 4. Generate package.json
 | |
|   const packageJSON = require(path.join(ROOT_PATH, 'package.json'));
 | |
|   await writeToPackage('package.json', JSON.stringify({
 | |
|     name: packageName,
 | |
|     version: packageJSON.version,
 | |
|     description: package.description,
 | |
|     repository: packageJSON.repository,
 | |
|     engines: packageJSON.engines,
 | |
|     homepage: packageJSON.homepage,
 | |
|     main: 'index.js',
 | |
|     scripts: {
 | |
|       install: 'node install.js',
 | |
|     },
 | |
|     author: packageJSON.author,
 | |
|     license: packageJSON.license,
 | |
|     dependencies: packageJSON.dependencies
 | |
|   }, null, 2));
 | |
| 
 | |
|   // 5. Generate browsers.json
 | |
|   const browsersJSON = require(path.join(ROOT_PATH, 'browsers.json'));
 | |
|   browsersJSON.browsers = browsersJSON.browsers.filter(browser => package.whitelistedBrowsers.includes(browser.name));
 | |
|   await writeToPackage('browsers.json', JSON.stringify(browsersJSON, null, 2));
 | |
| 
 | |
|   // 6. Run npm pack
 | |
|   const {stdout, stderr, status} = spawnSync('npm', ['pack'], {cwd: packagePath, encoding: 'utf8'});
 | |
|   if (status !== 0) {
 | |
|     console.log(`ERROR: "npm pack" failed`);
 | |
|     console.log(stderr);
 | |
|     process.exit(1);
 | |
|   }
 | |
|   const tgzName = stdout.trim();
 | |
| 
 | |
|   // 7. Move result to the outputPath
 | |
|   fs.renameSync(path.join(packagePath, tgzName), outputPath);
 | |
|   console.log(outputPath);
 | |
| })();
 | |
| 
 | |
| async function writeToPackage(fileName, content) {
 | |
|   const toPath = path.join(packagePath, fileName);
 | |
|   cleanupPaths.push(toPath);
 | |
|   console.error(`- generating: //${path.relative(ROOT_PATH, toPath)}`);
 | |
|   await writeFileAsync(toPath, content);
 | |
| }
 | |
| 
 | |
| async function copyToPackage(fileOrDirectoryName) {
 | |
|   const fromPath = path.join(ROOT_PATH, fileOrDirectoryName);
 | |
|   const toPath = path.join(packagePath, fileOrDirectoryName);
 | |
|   cleanupPaths.push(toPath);
 | |
|   console.error(`- copying: //${path.relative(ROOT_PATH, fromPath)} -> //${path.relative(ROOT_PATH, toPath)}`);
 | |
|   await cpAsync(fromPath, toPath);
 | |
| }
 | |
| 
 | |
| function usage() {
 | |
|   return `
 | |
| usage: ${SCRIPT_NAME} <package-name> <output-path> [--no-cleanup]
 | |
| 
 | |
| Creates a .tgz of the package and saves it at the given output path
 | |
| 
 | |
|   --no-cleanup    skip cleaning up generated files from package directory
 | |
| 
 | |
| Example:
 | |
|   ${SCRIPT_NAME} playwright ./playwright.tgz
 | |
| `;
 | |
| }
 | |
| 
 |