chore(agnostic): Remove use of util.promisify (#6446)
In `src/common` we now use `fs.promises.X` which we can dynamically `import`. In a browser environment this code will never run because it's gated on `isNode` (in a future PR we will add tree-shaking to the bundle step such that this code is eliminated). By using `import`, we ensure TypeScript still can track types and give good type information. In `src/node` we continue to use `util.promisify` but that's not a concern as that code explicitly is never run in the browser.
This commit is contained in:
parent
96f3d439f5
commit
caa9a1cafa
@ -33,7 +33,7 @@
|
|||||||
"generate-docs": "npm run tsc && api-extractor run --local --verbose && api-documenter markdown -i temp -o new-docs",
|
"generate-docs": "npm run tsc && api-extractor run --local --verbose && api-documenter markdown -i temp -o new-docs",
|
||||||
"ensure-new-docs-up-to-date": "npm run generate-docs && git status && exit `git status --porcelain | head -255 | wc -l`",
|
"ensure-new-docs-up-to-date": "npm run generate-docs && git status && exit `git status --porcelain | head -255 | wc -l`",
|
||||||
"generate-dependency-graph": "echo 'Requires graphviz installed locally!' && depcruise --exclude 'api.ts' --do-not-follow '^node_modules' --output-type dot src/index.ts | dot -T png > dependency-chart.png",
|
"generate-dependency-graph": "echo 'Requires graphviz installed locally!' && depcruise --exclude 'api.ts' --do-not-follow '^node_modules' --output-type dot src/index.ts | dot -T png > dependency-chart.png",
|
||||||
"ensure-correct-devtools-protocol-revision": "ts-node scripts/ensure-correct-devtools-protocol-package"
|
"ensure-correct-devtools-protocol-revision": "ts-node -s scripts/ensure-correct-devtools-protocol-package"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"lib/",
|
"lib/",
|
||||||
|
6
scripts/tsconfig.json
Normal file
6
scripts/tsconfig.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"extends": "../tsconfig.json",
|
||||||
|
"compilerOptions": {
|
||||||
|
"module": "CommonJS"
|
||||||
|
}
|
||||||
|
}
|
@ -275,12 +275,8 @@ export class DOMWorld {
|
|||||||
'Cannot pass a filepath to addScriptTag in the browser environment.'
|
'Cannot pass a filepath to addScriptTag in the browser environment.'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
const fs = await import('fs');
|
||||||
const fs = require('fs');
|
let contents = await fs.promises.readFile(path, 'utf8');
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
||||||
const { promisify } = require('util');
|
|
||||||
const readFileAsync = promisify(fs.readFile);
|
|
||||||
let contents = await readFileAsync(path, 'utf8');
|
|
||||||
contents += '//# sourceURL=' + path.replace(/\n/g, '');
|
contents += '//# sourceURL=' + path.replace(/\n/g, '');
|
||||||
const context = await this.executionContext();
|
const context = await this.executionContext();
|
||||||
return (
|
return (
|
||||||
@ -361,12 +357,8 @@ export class DOMWorld {
|
|||||||
'Cannot pass a filepath to addStyleTag in the browser environment.'
|
'Cannot pass a filepath to addStyleTag in the browser environment.'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
const fs = await import('fs');
|
||||||
const fs = require('fs');
|
let contents = await fs.promises.readFile(path, 'utf8');
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
||||||
const { promisify } = require('util');
|
|
||||||
const readFileAsync = promisify(fs.readFile);
|
|
||||||
let contents = await readFileAsync(path, 'utf8');
|
|
||||||
contents += '/*# sourceURL=' + path.replace(/\n/g, '') + '*/';
|
contents += '/*# sourceURL=' + path.replace(/\n/g, '') + '*/';
|
||||||
const context = await this.executionContext();
|
const context = await this.executionContext();
|
||||||
return (
|
return (
|
||||||
|
@ -31,6 +31,7 @@ import {
|
|||||||
WrapElementHandle,
|
WrapElementHandle,
|
||||||
UnwrapPromiseLike,
|
UnwrapPromiseLike,
|
||||||
} from './EvalTypes.js';
|
} from './EvalTypes.js';
|
||||||
|
import { isNode } from '../environment.js';
|
||||||
|
|
||||||
export interface BoxModel {
|
export interface BoxModel {
|
||||||
content: Array<{ x: number; y: number }>;
|
content: Array<{ x: number; y: number }>;
|
||||||
@ -556,22 +557,22 @@ export class ElementHandle<
|
|||||||
'Multiple file uploads only work with <input type=file multiple>'
|
'Multiple file uploads only work with <input type=file multiple>'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (!isNode) {
|
||||||
|
throw new Error(
|
||||||
|
`JSHandle#uploadFile can only be used in Node environments.`
|
||||||
|
);
|
||||||
|
}
|
||||||
// This import is only needed for `uploadFile`, so keep it scoped here to avoid paying
|
// This import is only needed for `uploadFile`, so keep it scoped here to avoid paying
|
||||||
// the cost unnecessarily.
|
// the cost unnecessarily.
|
||||||
|
const path = await import('path');
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
||||||
const path = require('path');
|
const fs = await import('fs');
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
||||||
const fs = require('fs');
|
|
||||||
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
||||||
const { promisify } = require('util');
|
|
||||||
const access = promisify(fs.access);
|
|
||||||
|
|
||||||
// Locate all files and confirm that they exist.
|
// Locate all files and confirm that they exist.
|
||||||
const files = await Promise.all(
|
const files = await Promise.all(
|
||||||
filePaths.map(async (filePath) => {
|
filePaths.map(async (filePath) => {
|
||||||
const resolvedPath: string = path.resolve(filePath);
|
const resolvedPath: string = path.resolve(filePath);
|
||||||
try {
|
try {
|
||||||
await access(resolvedPath, fs.constants.R_OK);
|
await fs.promises.access(resolvedPath, fs.constants.R_OK);
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
if (error.code === 'ENOENT')
|
if (error.code === 'ENOENT')
|
||||||
throw new Error(`${filePath} does not exist or is not readable`);
|
throw new Error(`${filePath} does not exist or is not readable`);
|
||||||
|
@ -14,8 +14,6 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import * as fs from 'fs';
|
|
||||||
import { promisify } from 'util';
|
|
||||||
import { EventEmitter } from './EventEmitter.js';
|
import { EventEmitter } from './EventEmitter.js';
|
||||||
import {
|
import {
|
||||||
Connection,
|
Connection,
|
||||||
@ -57,8 +55,7 @@ import {
|
|||||||
UnwrapPromiseLike,
|
UnwrapPromiseLike,
|
||||||
} from './EvalTypes.js';
|
} from './EvalTypes.js';
|
||||||
import { PDFOptions, paperFormats } from './PDFOptions.js';
|
import { PDFOptions, paperFormats } from './PDFOptions.js';
|
||||||
|
import { isNode } from '../environment.js';
|
||||||
const writeFileAsync = promisify(fs.writeFile);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @public
|
* @public
|
||||||
@ -1750,7 +1747,13 @@ export class Page extends EventEmitter {
|
|||||||
options.encoding === 'base64'
|
options.encoding === 'base64'
|
||||||
? result.data
|
? result.data
|
||||||
: Buffer.from(result.data, 'base64');
|
: Buffer.from(result.data, 'base64');
|
||||||
if (options.path) await writeFileAsync(options.path, buffer);
|
if (!isNode && options.path) {
|
||||||
|
throw new Error(
|
||||||
|
'Screenshots can only be written to a file path in a Node environment.'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
const fs = await import('fs');
|
||||||
|
if (options.path) await fs.promises.writeFile(options.path, buffer);
|
||||||
return buffer;
|
return buffer;
|
||||||
|
|
||||||
function processClip(
|
function processClip(
|
||||||
|
@ -17,15 +17,10 @@ import { TimeoutError } from './Errors.js';
|
|||||||
import { debug } from './Debug.js';
|
import { debug } from './Debug.js';
|
||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import { CDPSession } from './Connection.js';
|
import { CDPSession } from './Connection.js';
|
||||||
import { promisify } from 'util';
|
|
||||||
import { Protocol } from 'devtools-protocol';
|
import { Protocol } from 'devtools-protocol';
|
||||||
import { CommonEventEmitter } from './EventEmitter.js';
|
import { CommonEventEmitter } from './EventEmitter.js';
|
||||||
import { assert } from './assert.js';
|
import { assert } from './assert.js';
|
||||||
|
|
||||||
const openAsync = promisify(fs.open);
|
|
||||||
const writeAsync = promisify(fs.write);
|
|
||||||
const closeAsync = promisify(fs.close);
|
|
||||||
|
|
||||||
export const debugError = debug('puppeteer:error');
|
export const debugError = debug('puppeteer:error');
|
||||||
|
|
||||||
function getExceptionMessage(
|
function getExceptionMessage(
|
||||||
@ -207,8 +202,10 @@ async function readProtocolStream(
|
|||||||
path?: string
|
path?: string
|
||||||
): Promise<Buffer> {
|
): Promise<Buffer> {
|
||||||
let eof = false;
|
let eof = false;
|
||||||
let file;
|
let fileHandle: fs.promises.FileHandle;
|
||||||
if (path) file = await openAsync(path, 'w');
|
if (path) {
|
||||||
|
fileHandle = await fs.promises.open(path, 'w');
|
||||||
|
}
|
||||||
const bufs = [];
|
const bufs = [];
|
||||||
while (!eof) {
|
while (!eof) {
|
||||||
const response = await client.send('IO.read', { handle });
|
const response = await client.send('IO.read', { handle });
|
||||||
@ -218,9 +215,9 @@ async function readProtocolStream(
|
|||||||
response.base64Encoded ? 'base64' : undefined
|
response.base64Encoded ? 'base64' : undefined
|
||||||
);
|
);
|
||||||
bufs.push(buf);
|
bufs.push(buf);
|
||||||
if (path) await writeAsync(file, buf);
|
if (path) await fs.promises.writeFile(fileHandle, buf);
|
||||||
}
|
}
|
||||||
if (path) await closeAsync(file);
|
if (path) await fileHandle.close();
|
||||||
await client.send('IO.close', { handle });
|
await client.send('IO.close', { handle });
|
||||||
let resultBuffer = null;
|
let resultBuffer = null;
|
||||||
try {
|
try {
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
{
|
{
|
||||||
"extends": "../tsconfig.base.json",
|
"extends": "../tsconfig.base.json",
|
||||||
|
"compilerOptions": {
|
||||||
|
"module": "CommonJS"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
"checkJs": true,
|
"checkJs": true,
|
||||||
"target": "ESNext",
|
"target": "ESNext",
|
||||||
"moduleResolution": "node",
|
"moduleResolution": "node",
|
||||||
|
"module": "ESNext",
|
||||||
"declaration": true,
|
"declaration": true,
|
||||||
"declarationMap": true,
|
"declarationMap": true,
|
||||||
"resolveJsonModule": true
|
"resolveJsonModule": true
|
||||||
|
Loading…
Reference in New Issue
Block a user