chore: use braces in function bodies (#8525)
This commit is contained in:
parent
570087ea94
commit
ce0dd25349
@ -23,6 +23,8 @@ module.exports = {
|
||||
rules: {
|
||||
// Brackets keep code readable.
|
||||
curly: [2, 'all'],
|
||||
// Brackets keep code readable and `return` intentions clear.
|
||||
'arrow-body-style': ['error', 'always'],
|
||||
// Error if files are not formatted with Prettier correctly.
|
||||
'prettier/prettier': 2,
|
||||
// syntax preferences
|
||||
@ -134,6 +136,8 @@ module.exports = {
|
||||
rules: {
|
||||
// Brackets keep code readable.
|
||||
curly: [2, 'all'],
|
||||
// Brackets keep code readable and `return` intentions clear.
|
||||
'arrow-body-style': ['error', 'always'],
|
||||
// Error if comments do not adhere to `tsdoc`.
|
||||
'tsdoc/syntax': 2,
|
||||
'no-unused-vars': 0,
|
||||
|
@ -38,7 +38,12 @@ function sniffDetector() {
|
||||
const page = await browser.newPage();
|
||||
await page.evaluateOnNewDocument(sniffDetector);
|
||||
await page.goto('https://www.google.com', { waitUntil: 'networkidle2' });
|
||||
console.log('Sniffed: ' + (await page.evaluate(() => !!navigator.sniffed)));
|
||||
console.log(
|
||||
'Sniffed: ' +
|
||||
(await page.evaluate(() => {
|
||||
return !!navigator.sniffed;
|
||||
}))
|
||||
);
|
||||
|
||||
await browser.close();
|
||||
})();
|
||||
|
@ -23,7 +23,9 @@ async function attachFrame(frameId, url) {
|
||||
frame.src = url;
|
||||
frame.id = frameId;
|
||||
document.body.appendChild(frame);
|
||||
await new Promise((x) => (frame.onload = x));
|
||||
await new Promise((x) => {
|
||||
return (frame.onload = x);
|
||||
});
|
||||
return frame;
|
||||
}
|
||||
|
||||
|
@ -30,7 +30,13 @@ for (const [depKey, depValue] of Object.entries(allDeps)) {
|
||||
|
||||
if (invalidDeps.size > 0) {
|
||||
console.error('Found non-pinned dependencies in package.json:');
|
||||
console.log([...invalidDeps.keys()].map((k) => ` ${k}`).join('\n'));
|
||||
console.log(
|
||||
[...invalidDeps.keys()]
|
||||
.map((k) => {
|
||||
return ` ${k}`;
|
||||
})
|
||||
.join('\n')
|
||||
);
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
|
@ -171,9 +171,9 @@ function testProject(folder: string) {
|
||||
const result = compileAndCatchErrors(projectLocation);
|
||||
const expectedErrors = EXPECTED_ERRORS.get(folder) || [];
|
||||
if (
|
||||
result.tsErrorMesssage.find(
|
||||
(line) => line.includes('good.ts') || line.includes('good.js')
|
||||
)
|
||||
result.tsErrorMesssage.find((line) => {
|
||||
return line.includes('good.ts') || line.includes('good.js');
|
||||
})
|
||||
) {
|
||||
console.error(
|
||||
`Error for ${projectLocation} contained unexpected failures in good.ts/good.js:\n${result.tsErrorMesssage.join(
|
||||
@ -182,9 +182,9 @@ function testProject(folder: string) {
|
||||
);
|
||||
process.exit(1);
|
||||
}
|
||||
const errorsInTsMessage = result.tsErrorMesssage.filter(
|
||||
(line) => line.includes('bad.ts') || line.includes('bad.js')
|
||||
);
|
||||
const errorsInTsMessage = result.tsErrorMesssage.filter((line) => {
|
||||
return line.includes('bad.ts') || line.includes('bad.js');
|
||||
});
|
||||
const expectedErrorsThatHaveOccurred = new Set<string>();
|
||||
const unexpectedErrors = errorsInTsMessage.filter((message) => {
|
||||
const isExpected = expectedErrors.some((expectedError) => {
|
||||
|
@ -193,9 +193,9 @@ export class Accessibility {
|
||||
const defaultRoot = AXNode.createTree(nodes);
|
||||
let needle: AXNode | null = defaultRoot;
|
||||
if (backendNodeId) {
|
||||
needle = defaultRoot.find(
|
||||
(node) => node.payload.backendDOMNodeId === backendNodeId
|
||||
);
|
||||
needle = defaultRoot.find((node) => {
|
||||
return node.payload.backendDOMNodeId === backendNodeId;
|
||||
});
|
||||
if (!needle) {
|
||||
return null;
|
||||
}
|
||||
@ -455,8 +455,9 @@ class AXNode {
|
||||
'roledescription',
|
||||
'valuetext',
|
||||
];
|
||||
const getUserStringPropertyValue = (key: UserStringProperty): string =>
|
||||
properties.get(key) as string;
|
||||
const getUserStringPropertyValue = (key: UserStringProperty): string => {
|
||||
return properties.get(key) as string;
|
||||
};
|
||||
|
||||
for (const userStringProperty of userStringProperties) {
|
||||
if (!properties.has(userStringProperty)) {
|
||||
@ -487,8 +488,9 @@ class AXNode {
|
||||
'required',
|
||||
'selected',
|
||||
];
|
||||
const getBooleanPropertyValue = (key: BooleanProperty): boolean =>
|
||||
properties.get(key) as boolean;
|
||||
const getBooleanPropertyValue = (key: BooleanProperty): boolean => {
|
||||
return properties.get(key) as boolean;
|
||||
};
|
||||
|
||||
for (const booleanProperty of booleanProperties) {
|
||||
// RootWebArea's treat focus differently than other nodes. They report whether
|
||||
@ -521,8 +523,9 @@ class AXNode {
|
||||
'valuemax',
|
||||
'valuemin',
|
||||
];
|
||||
const getNumericalPropertyValue = (key: NumbericalProperty): number =>
|
||||
properties.get(key) as number;
|
||||
const getNumericalPropertyValue = (key: NumbericalProperty): number => {
|
||||
return properties.get(key) as number;
|
||||
};
|
||||
for (const numericalProperty of numericalProperties) {
|
||||
if (!properties.has(numericalProperty)) {
|
||||
continue;
|
||||
@ -541,8 +544,9 @@ class AXNode {
|
||||
'invalid',
|
||||
'orientation',
|
||||
];
|
||||
const getTokenPropertyValue = (key: TokenProperty): string =>
|
||||
properties.get(key) as string;
|
||||
const getTokenPropertyValue = (key: TokenProperty): string => {
|
||||
return properties.get(key) as string;
|
||||
};
|
||||
for (const tokenProperty of tokenProperties) {
|
||||
const value = getTokenPropertyValue(tokenProperty);
|
||||
if (!value || value === 'false') {
|
||||
|
@ -33,14 +33,16 @@ async function queryAXTree(
|
||||
role,
|
||||
});
|
||||
const filteredNodes: Protocol.Accessibility.AXNode[] = nodes.filter(
|
||||
(node: Protocol.Accessibility.AXNode) =>
|
||||
!node.role || node.role.value !== 'StaticText'
|
||||
(node: Protocol.Accessibility.AXNode) => {
|
||||
return !node.role || node.role.value !== 'StaticText';
|
||||
}
|
||||
);
|
||||
return filteredNodes;
|
||||
}
|
||||
|
||||
const normalizeValue = (value: string): string =>
|
||||
value.replace(/ +/g, ' ').trim();
|
||||
const normalizeValue = (value: string): string => {
|
||||
return value.replace(/ +/g, ' ').trim();
|
||||
};
|
||||
const knownAttributes = new Set(['name', 'role']);
|
||||
const attributeRegexp =
|
||||
/\[\s*(?<attribute>\w+)\s*=\s*(?<quote>"|')(?<value>\\.|.*?(?=\k<quote>))\k<quote>\s*\]/g;
|
||||
@ -109,12 +111,13 @@ const waitFor = async (
|
||||
},
|
||||
};
|
||||
return domWorld._waitForSelectorInPage(
|
||||
(_: Element, selector: string) =>
|
||||
(
|
||||
(_: Element, selector: string) => {
|
||||
return (
|
||||
globalThis as any as unknown as {
|
||||
ariaQuerySelector(selector: string): void;
|
||||
}
|
||||
).ariaQuerySelector(selector),
|
||||
).ariaQuerySelector(selector);
|
||||
},
|
||||
selector,
|
||||
options,
|
||||
binding
|
||||
@ -129,7 +132,9 @@ const queryAll = async (
|
||||
const { name, role } = parseAriaSelector(selector);
|
||||
const res = await queryAXTree(exeCtx._client, element, name, role);
|
||||
return Promise.all(
|
||||
res.map((axNode) => exeCtx._adoptBackendNodeId(axNode.backendDOMNodeId))
|
||||
res.map((axNode) => {
|
||||
return exeCtx._adoptBackendNodeId(axNode.backendDOMNodeId);
|
||||
})
|
||||
);
|
||||
};
|
||||
|
||||
@ -139,10 +144,9 @@ const queryAllArray = async (
|
||||
): Promise<JSHandle> => {
|
||||
const elementHandles = await queryAll(element, selector);
|
||||
const exeCtx = element.executionContext();
|
||||
const jsHandle = exeCtx.evaluateHandle(
|
||||
(...elements) => elements,
|
||||
...elementHandles
|
||||
);
|
||||
const jsHandle = exeCtx.evaluateHandle((...elements) => {
|
||||
return elements;
|
||||
}, ...elementHandles);
|
||||
return jsHandle;
|
||||
};
|
||||
|
||||
|
@ -280,7 +280,11 @@ export class Browser extends EventEmitter {
|
||||
this.#screenshotTaskQueue = new TaskQueue();
|
||||
this.#connection = connection;
|
||||
this.#closeCallback = closeCallback || function (): void {};
|
||||
this.#targetFilterCallback = targetFilterCallback || ((): boolean => true);
|
||||
this.#targetFilterCallback =
|
||||
targetFilterCallback ||
|
||||
((): boolean => {
|
||||
return true;
|
||||
});
|
||||
this.#setIsPageTargetCallback(isPageTargetCallback);
|
||||
|
||||
this.#defaultContext = new BrowserContext(this.#connection, this);
|
||||
@ -293,9 +297,9 @@ export class Browser extends EventEmitter {
|
||||
}
|
||||
|
||||
this.#targets = new Map();
|
||||
this.#connection.on(ConnectionEmittedEvents.Disconnected, () =>
|
||||
this.emit(BrowserEmittedEvents.Disconnected)
|
||||
);
|
||||
this.#connection.on(ConnectionEmittedEvents.Disconnected, () => {
|
||||
return this.emit(BrowserEmittedEvents.Disconnected);
|
||||
});
|
||||
this.#connection.on('Target.targetCreated', this.#targetCreated.bind(this));
|
||||
this.#connection.on(
|
||||
'Target.targetDestroyed',
|
||||
@ -423,7 +427,9 @@ export class Browser extends EventEmitter {
|
||||
const target = new Target(
|
||||
targetInfo,
|
||||
context,
|
||||
() => this.#connection.createSession(targetInfo),
|
||||
() => {
|
||||
return this.#connection.createSession(targetInfo);
|
||||
},
|
||||
this.#ignoreHTTPSErrors,
|
||||
this.#defaultViewport ?? null,
|
||||
this.#screenshotTaskQueue,
|
||||
@ -542,18 +548,18 @@ export class Browser extends EventEmitter {
|
||||
* an array with all the targets in all browser contexts.
|
||||
*/
|
||||
targets(): Target[] {
|
||||
return Array.from(this.#targets.values()).filter(
|
||||
(target) => target._isInitialized
|
||||
);
|
||||
return Array.from(this.#targets.values()).filter((target) => {
|
||||
return target._isInitialized;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* The target associated with the browser.
|
||||
*/
|
||||
target(): Target {
|
||||
const browserTarget = this.targets().find(
|
||||
(target) => target.type() === 'browser'
|
||||
);
|
||||
const browserTarget = this.targets().find((target) => {
|
||||
return target.type() === 'browser';
|
||||
});
|
||||
if (!browserTarget) {
|
||||
throw new Error('Browser target is not found');
|
||||
}
|
||||
@ -581,7 +587,9 @@ export class Browser extends EventEmitter {
|
||||
const { timeout = 30000 } = options;
|
||||
let resolve: (value: Target | PromiseLike<Target>) => void;
|
||||
let isResolved = false;
|
||||
const targetPromise = new Promise<Target>((x) => (resolve = x));
|
||||
const targetPromise = new Promise<Target>((x) => {
|
||||
return (resolve = x);
|
||||
});
|
||||
this.on(BrowserEmittedEvents.TargetCreated, check);
|
||||
this.on(BrowserEmittedEvents.TargetChanged, check);
|
||||
try {
|
||||
@ -614,10 +622,14 @@ export class Browser extends EventEmitter {
|
||||
*/
|
||||
async pages(): Promise<Page[]> {
|
||||
const contextPages = await Promise.all(
|
||||
this.browserContexts().map((context) => context.pages())
|
||||
this.browserContexts().map((context) => {
|
||||
return context.pages();
|
||||
})
|
||||
);
|
||||
// Flatten array.
|
||||
return contextPages.reduce((acc, x) => acc.concat(x), []);
|
||||
return contextPages.reduce((acc, x) => {
|
||||
return acc.concat(x);
|
||||
}, []);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -750,9 +762,9 @@ export class BrowserContext extends EventEmitter {
|
||||
* An array of all active targets inside the browser context.
|
||||
*/
|
||||
targets(): Target[] {
|
||||
return this.#browser
|
||||
.targets()
|
||||
.filter((target) => target.browserContext() === this);
|
||||
return this.#browser.targets().filter((target) => {
|
||||
return target.browserContext() === this;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
@ -776,10 +788,9 @@ export class BrowserContext extends EventEmitter {
|
||||
predicate: (x: Target) => boolean | Promise<boolean>,
|
||||
options: { timeout?: number } = {}
|
||||
): Promise<Target> {
|
||||
return this.#browser.waitForTarget(
|
||||
(target) => target.browserContext() === this && predicate(target),
|
||||
options
|
||||
);
|
||||
return this.#browser.waitForTarget((target) => {
|
||||
return target.browserContext() === this && predicate(target);
|
||||
}, options);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -792,17 +803,22 @@ export class BrowserContext extends EventEmitter {
|
||||
async pages(): Promise<Page[]> {
|
||||
const pages = await Promise.all(
|
||||
this.targets()
|
||||
.filter(
|
||||
(target) =>
|
||||
.filter((target) => {
|
||||
return (
|
||||
target.type() === 'page' ||
|
||||
(target.type() === 'other' &&
|
||||
this.#browser._getIsPageTargetCallback()?.(
|
||||
target._getTargetInfo()
|
||||
))
|
||||
)
|
||||
.map((target) => target.page())
|
||||
);
|
||||
return pages.filter((page): page is Page => !!page);
|
||||
})
|
||||
.map((target) => {
|
||||
return target.page();
|
||||
})
|
||||
);
|
||||
return pages.filter((page): page is Page => {
|
||||
return !!page;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -119,7 +119,9 @@ export async function _connectToBrowser(
|
||||
ignoreHTTPSErrors,
|
||||
defaultViewport,
|
||||
undefined,
|
||||
() => connection.send('Browser.close').catch(debugError),
|
||||
() => {
|
||||
return connection.send('Browser.close').catch(debugError);
|
||||
},
|
||||
targetFilter,
|
||||
isPageTarget
|
||||
);
|
||||
|
@ -20,9 +20,9 @@ export class BrowserWebSocketTransport implements ConnectionTransport {
|
||||
return new Promise((resolve, reject) => {
|
||||
const ws = new WebSocket(url);
|
||||
|
||||
ws.addEventListener('open', () =>
|
||||
resolve(new BrowserWebSocketTransport(ws))
|
||||
);
|
||||
ws.addEventListener('open', () => {
|
||||
return resolve(new BrowserWebSocketTransport(ws));
|
||||
});
|
||||
ws.addEventListener('error', reject);
|
||||
});
|
||||
}
|
||||
|
@ -130,7 +130,9 @@ export class Connection extends EventEmitter {
|
||||
|
||||
async #onMessage(message: string): Promise<void> {
|
||||
if (this.#delay) {
|
||||
await new Promise((f) => setTimeout(f, this.#delay));
|
||||
await new Promise((f) => {
|
||||
return setTimeout(f, this.#delay);
|
||||
});
|
||||
}
|
||||
debugProtocolReceive(message);
|
||||
const object = JSON.parse(message);
|
||||
|
@ -480,5 +480,7 @@ function convertToDisjointRanges(
|
||||
}
|
||||
}
|
||||
// Filter out empty ranges.
|
||||
return results.filter((range) => range.end - range.start > 1);
|
||||
return results.filter((range) => {
|
||||
return range.end - range.start > 1;
|
||||
});
|
||||
}
|
||||
|
@ -108,8 +108,9 @@ export class DOMWorld {
|
||||
return this.#boundFunctions;
|
||||
}
|
||||
|
||||
static #bindingIdentifier = (name: string, contextId: number) =>
|
||||
`${name}_${contextId}`;
|
||||
static #bindingIdentifier = (name: string, contextId: number) => {
|
||||
return `${name}_${contextId}`;
|
||||
};
|
||||
|
||||
constructor(
|
||||
client: CDPSession,
|
||||
@ -444,7 +445,9 @@ export class DOMWorld {
|
||||
script.id = id;
|
||||
}
|
||||
let error = null;
|
||||
script.onerror = (e) => (error = e);
|
||||
script.onerror = (e) => {
|
||||
return (error = e);
|
||||
};
|
||||
document.head.appendChild(script);
|
||||
if (error) {
|
||||
throw error;
|
||||
@ -843,7 +846,9 @@ export class DOMWorld {
|
||||
}
|
||||
|
||||
async title(): Promise<string> {
|
||||
return this.evaluate(() => document.title);
|
||||
return this.evaluate(() => {
|
||||
return document.title;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@ -933,10 +938,9 @@ export class WaitTask {
|
||||
const timeoutError = new TimeoutError(
|
||||
`waiting for ${options.title} failed: timeout ${options.timeout}ms exceeded`
|
||||
);
|
||||
this.#timeoutTimer = setTimeout(
|
||||
() => this.terminate(timeoutError),
|
||||
options.timeout
|
||||
);
|
||||
this.#timeoutTimer = setTimeout(() => {
|
||||
return this.terminate(timeoutError);
|
||||
}, options.timeout);
|
||||
}
|
||||
this.rerun();
|
||||
}
|
||||
@ -987,7 +991,13 @@ export class WaitTask {
|
||||
// throw an error - ignore this predicate run altogether.
|
||||
if (
|
||||
!error &&
|
||||
(await this.#domWorld.evaluate((s) => !s, success).catch(() => true))
|
||||
(await this.#domWorld
|
||||
.evaluate((s) => {
|
||||
return !s;
|
||||
}, success)
|
||||
.catch(() => {
|
||||
return true;
|
||||
}))
|
||||
) {
|
||||
if (!success) {
|
||||
throw new Error('Assertion: result handle is not available');
|
||||
@ -1053,7 +1063,9 @@ async function waitForPredicatePageFunction(
|
||||
const predicate = new Function('...args', predicateBody);
|
||||
let timedOut = false;
|
||||
if (timeout) {
|
||||
setTimeout(() => (timedOut = true), timeout);
|
||||
setTimeout(() => {
|
||||
return (timedOut = true);
|
||||
}, timeout);
|
||||
}
|
||||
switch (polling) {
|
||||
case 'raf':
|
||||
@ -1073,7 +1085,9 @@ async function waitForPredicatePageFunction(
|
||||
}
|
||||
|
||||
let fulfill = (_?: unknown) => {};
|
||||
const result = new Promise((x) => (fulfill = x));
|
||||
const result = new Promise((x) => {
|
||||
return (fulfill = x);
|
||||
});
|
||||
const observer = new MutationObserver(async () => {
|
||||
if (timedOut) {
|
||||
observer.disconnect();
|
||||
@ -1100,7 +1114,9 @@ async function waitForPredicatePageFunction(
|
||||
|
||||
async function pollRaf(): Promise<unknown> {
|
||||
let fulfill = (_?: unknown): void => {};
|
||||
const result = new Promise((x) => (fulfill = x));
|
||||
const result = new Promise((x) => {
|
||||
return (fulfill = x);
|
||||
});
|
||||
await onRaf();
|
||||
return result;
|
||||
|
||||
@ -1122,7 +1138,9 @@ async function waitForPredicatePageFunction(
|
||||
|
||||
async function pollInterval(pollInterval: number): Promise<unknown> {
|
||||
let fulfill = (_?: unknown): void => {};
|
||||
const result = new Promise((x) => (fulfill = x));
|
||||
const result = new Promise((x) => {
|
||||
return (fulfill = x);
|
||||
});
|
||||
await onTimeout();
|
||||
return result;
|
||||
|
||||
|
@ -166,9 +166,9 @@ export class FrameManager extends EventEmitter {
|
||||
this.#handleFrameTree(client, frameTree);
|
||||
await Promise.all([
|
||||
client.send('Page.setLifecycleEventsEnabled', { enabled: true }),
|
||||
client
|
||||
.send('Runtime.enable')
|
||||
.then(() => this._ensureIsolatedWorld(client, UTILITY_WORLD_NAME)),
|
||||
client.send('Runtime.enable').then(() => {
|
||||
return this._ensureIsolatedWorld(client, UTILITY_WORLD_NAME);
|
||||
}),
|
||||
// TODO: Network manager is not aware of OOP iframes yet.
|
||||
client === this.#client
|
||||
? this.#networkManager.initialize()
|
||||
@ -443,16 +443,18 @@ export class FrameManager extends EventEmitter {
|
||||
// Frames might be removed before we send this.
|
||||
await Promise.all(
|
||||
this.frames()
|
||||
.filter((frame) => frame._client() === session)
|
||||
.map((frame) =>
|
||||
session
|
||||
.filter((frame) => {
|
||||
return frame._client() === session;
|
||||
})
|
||||
.map((frame) => {
|
||||
return session
|
||||
.send('Page.createIsolatedWorld', {
|
||||
frameId: frame._id,
|
||||
worldName: name,
|
||||
grantUniveralAccess: true,
|
||||
})
|
||||
.catch(debugError)
|
||||
)
|
||||
.catch(debugError);
|
||||
})
|
||||
);
|
||||
}
|
||||
|
||||
@ -1281,9 +1283,9 @@ export class Frame {
|
||||
return this.waitForSelector(string, options);
|
||||
}
|
||||
if (isNumber(selectorOrFunctionOrTimeout)) {
|
||||
return new Promise((fulfill) =>
|
||||
setTimeout(fulfill, selectorOrFunctionOrTimeout)
|
||||
);
|
||||
return new Promise((fulfill) => {
|
||||
return setTimeout(fulfill, selectorOrFunctionOrTimeout);
|
||||
});
|
||||
}
|
||||
if (typeof selectorOrFunctionOrTimeout === 'function') {
|
||||
return this.waitForFunction(
|
||||
|
@ -269,10 +269,9 @@ export class HTTPRequest {
|
||||
* the request interception.
|
||||
*/
|
||||
async finalizeInterceptions(): Promise<void> {
|
||||
await this.#interceptHandlers.reduce(
|
||||
(promiseChain, interceptAction) => promiseChain.then(interceptAction),
|
||||
Promise.resolve()
|
||||
);
|
||||
await this.#interceptHandlers.reduce((promiseChain, interceptAction) => {
|
||||
return promiseChain.then(interceptAction);
|
||||
}, Promise.resolve());
|
||||
const { action } = this.interceptResolutionState();
|
||||
switch (action) {
|
||||
case 'abort':
|
||||
@ -576,7 +575,9 @@ export class HTTPRequest {
|
||||
const value = response.headers[header];
|
||||
|
||||
responseHeaders[header.toLowerCase()] = Array.isArray(value)
|
||||
? value.map((item) => String(item))
|
||||
? value.map((item) => {
|
||||
return String(item);
|
||||
})
|
||||
: String(value);
|
||||
}
|
||||
}
|
||||
@ -738,7 +739,11 @@ function headersArray(
|
||||
if (!Object.is(value, undefined)) {
|
||||
const values = Array.isArray(value) ? value : [value];
|
||||
|
||||
result.push(...values.map((value) => ({ name, value: value + '' })));
|
||||
result.push(
|
||||
...values.map((value) => {
|
||||
return { name, value: value + '' };
|
||||
})
|
||||
);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
|
@ -277,7 +277,9 @@ export class Keyboard {
|
||||
await this.press(char, { delay });
|
||||
} else {
|
||||
if (delay) {
|
||||
await new Promise((f) => setTimeout(f, delay));
|
||||
await new Promise((f) => {
|
||||
return setTimeout(f, delay);
|
||||
});
|
||||
}
|
||||
await this.sendCharacter(char);
|
||||
}
|
||||
@ -311,7 +313,9 @@ export class Keyboard {
|
||||
const { delay = null } = options;
|
||||
await this.down(key, options);
|
||||
if (delay) {
|
||||
await new Promise((f) => setTimeout(f, options.delay));
|
||||
await new Promise((f) => {
|
||||
return setTimeout(f, options.delay);
|
||||
});
|
||||
}
|
||||
await this.up(key);
|
||||
}
|
||||
@ -453,7 +457,9 @@ export class Mouse {
|
||||
if (delay !== null) {
|
||||
await this.move(x, y);
|
||||
await this.down(options);
|
||||
await new Promise((f) => setTimeout(f, delay));
|
||||
await new Promise((f) => {
|
||||
return setTimeout(f, delay);
|
||||
});
|
||||
await this.up(options);
|
||||
} else {
|
||||
await this.move(x, y);
|
||||
@ -535,9 +541,9 @@ export class Mouse {
|
||||
*/
|
||||
async drag(start: Point, target: Point): Promise<Protocol.Input.DragData> {
|
||||
const promise = new Promise<Protocol.Input.DragData>((resolve) => {
|
||||
this.#client.once('Input.dragIntercepted', (event) =>
|
||||
resolve(event.data)
|
||||
);
|
||||
this.#client.once('Input.dragIntercepted', (event) => {
|
||||
return resolve(event.data);
|
||||
});
|
||||
});
|
||||
await this.move(start.x, start.y);
|
||||
await this.down();
|
||||
@ -608,7 +614,9 @@ export class Mouse {
|
||||
await this.dragEnter(target, data);
|
||||
await this.dragOver(target, data);
|
||||
if (delay) {
|
||||
await new Promise((resolve) => setTimeout(resolve, delay));
|
||||
await new Promise((resolve) => {
|
||||
return setTimeout(resolve, delay);
|
||||
});
|
||||
}
|
||||
await this.drop(target, data);
|
||||
await this.up();
|
||||
|
@ -86,8 +86,15 @@ export function _createJSHandle(
|
||||
return new JSHandle(context, context._client, remoteObject);
|
||||
}
|
||||
|
||||
const applyOffsetsToQuad = (quad: Point[], offsetX: number, offsetY: number) =>
|
||||
quad.map((part) => ({ x: part.x + offsetX, y: part.y + offsetY }));
|
||||
const applyOffsetsToQuad = (
|
||||
quad: Point[],
|
||||
offsetX: number,
|
||||
offsetY: number
|
||||
) => {
|
||||
return quad.map((part) => {
|
||||
return { x: part.x + offsetX, y: part.y + offsetY };
|
||||
});
|
||||
};
|
||||
|
||||
/**
|
||||
* Represents an in-page JavaScript object. JSHandles can be created with the
|
||||
@ -634,12 +641,18 @@ export class ElementHandle<
|
||||
layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
|
||||
const { offsetX, offsetY } = await this.#getOOPIFOffsets(this.#frame);
|
||||
const quads = result.quads
|
||||
.map((quad) => this.#fromProtocolQuad(quad))
|
||||
.map((quad) => applyOffsetsToQuad(quad, offsetX, offsetY))
|
||||
.map((quad) =>
|
||||
this.#intersectQuadWithViewport(quad, clientWidth, clientHeight)
|
||||
)
|
||||
.filter((quad) => computeQuadArea(quad) > 1);
|
||||
.map((quad) => {
|
||||
return this.#fromProtocolQuad(quad);
|
||||
})
|
||||
.map((quad) => {
|
||||
return applyOffsetsToQuad(quad, offsetX, offsetY);
|
||||
})
|
||||
.map((quad) => {
|
||||
return this.#intersectQuadWithViewport(quad, clientWidth, clientHeight);
|
||||
})
|
||||
.filter((quad) => {
|
||||
return computeQuadArea(quad) > 1;
|
||||
});
|
||||
if (!quads.length) {
|
||||
throw new Error('Node is either not clickable or not an HTMLElement');
|
||||
}
|
||||
@ -683,9 +696,9 @@ export class ElementHandle<
|
||||
const params: Protocol.DOM.GetBoxModelRequest = {
|
||||
objectId: this._remoteObject.objectId,
|
||||
};
|
||||
return this._client
|
||||
.send('DOM.getBoxModel', params)
|
||||
.catch((error) => debugError(error));
|
||||
return this._client.send('DOM.getBoxModel', params).catch((error) => {
|
||||
return debugError(error);
|
||||
});
|
||||
}
|
||||
|
||||
#fromProtocolQuad(quad: number[]): Point[] {
|
||||
@ -702,10 +715,12 @@ export class ElementHandle<
|
||||
width: number,
|
||||
height: number
|
||||
): Point[] {
|
||||
return quad.map((point) => ({
|
||||
return quad.map((point) => {
|
||||
return {
|
||||
x: Math.min(Math.max(point.x, 0), width),
|
||||
y: Math.min(Math.max(point.y, 0), height),
|
||||
}));
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
@ -930,9 +945,9 @@ export class ElementHandle<
|
||||
* Calls {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus | focus} on the element.
|
||||
*/
|
||||
async focus(): Promise<void> {
|
||||
await (this as ElementHandle<HTMLElement>).evaluate((element) =>
|
||||
element.focus()
|
||||
);
|
||||
await (this as ElementHandle<HTMLElement>).evaluate((element) => {
|
||||
return element.focus();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -214,9 +214,9 @@ export class LifecycleWatcher {
|
||||
}
|
||||
const errorMessage =
|
||||
'Navigation timeout of ' + this.#timeout + ' ms exceeded';
|
||||
await new Promise(
|
||||
(fulfill) => (this.#maximumTimer = setTimeout(fulfill, this.#timeout))
|
||||
);
|
||||
await new Promise((fulfill) => {
|
||||
return (this.#maximumTimer = setTimeout(fulfill, this.#timeout));
|
||||
});
|
||||
return new TimeoutError(errorMessage);
|
||||
}
|
||||
|
||||
|
@ -554,49 +554,67 @@ export class Page extends EventEmitter {
|
||||
this.emit(PageEmittedEvents.WorkerDestroyed, worker);
|
||||
});
|
||||
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameAttached, (event) =>
|
||||
this.emit(PageEmittedEvents.FrameAttached, event)
|
||||
);
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameDetached, (event) =>
|
||||
this.emit(PageEmittedEvents.FrameDetached, event)
|
||||
);
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameNavigated, (event) =>
|
||||
this.emit(PageEmittedEvents.FrameNavigated, event)
|
||||
);
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameAttached, (event) => {
|
||||
return this.emit(PageEmittedEvents.FrameAttached, event);
|
||||
});
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameDetached, (event) => {
|
||||
return this.emit(PageEmittedEvents.FrameDetached, event);
|
||||
});
|
||||
this.#frameManager.on(FrameManagerEmittedEvents.FrameNavigated, (event) => {
|
||||
return this.emit(PageEmittedEvents.FrameNavigated, event);
|
||||
});
|
||||
|
||||
const networkManager = this.#frameManager.networkManager();
|
||||
networkManager.on(NetworkManagerEmittedEvents.Request, (event) =>
|
||||
this.emit(PageEmittedEvents.Request, event)
|
||||
);
|
||||
networkManager.on(NetworkManagerEmittedEvents.Request, (event) => {
|
||||
return this.emit(PageEmittedEvents.Request, event);
|
||||
});
|
||||
networkManager.on(
|
||||
NetworkManagerEmittedEvents.RequestServedFromCache,
|
||||
(event) => this.emit(PageEmittedEvents.RequestServedFromCache, event)
|
||||
);
|
||||
networkManager.on(NetworkManagerEmittedEvents.Response, (event) =>
|
||||
this.emit(PageEmittedEvents.Response, event)
|
||||
);
|
||||
networkManager.on(NetworkManagerEmittedEvents.RequestFailed, (event) =>
|
||||
this.emit(PageEmittedEvents.RequestFailed, event)
|
||||
);
|
||||
networkManager.on(NetworkManagerEmittedEvents.RequestFinished, (event) =>
|
||||
this.emit(PageEmittedEvents.RequestFinished, event)
|
||||
(event) => {
|
||||
return this.emit(PageEmittedEvents.RequestServedFromCache, event);
|
||||
}
|
||||
);
|
||||
networkManager.on(NetworkManagerEmittedEvents.Response, (event) => {
|
||||
return this.emit(PageEmittedEvents.Response, event);
|
||||
});
|
||||
networkManager.on(NetworkManagerEmittedEvents.RequestFailed, (event) => {
|
||||
return this.emit(PageEmittedEvents.RequestFailed, event);
|
||||
});
|
||||
networkManager.on(NetworkManagerEmittedEvents.RequestFinished, (event) => {
|
||||
return this.emit(PageEmittedEvents.RequestFinished, event);
|
||||
});
|
||||
this.#fileChooserInterceptors = new Set();
|
||||
|
||||
client.on('Page.domContentEventFired', () =>
|
||||
this.emit(PageEmittedEvents.DOMContentLoaded)
|
||||
);
|
||||
client.on('Page.loadEventFired', () => this.emit(PageEmittedEvents.Load));
|
||||
client.on('Runtime.consoleAPICalled', (event) => this.#onConsoleAPI(event));
|
||||
client.on('Runtime.bindingCalled', (event) => this.#onBindingCalled(event));
|
||||
client.on('Page.javascriptDialogOpening', (event) => this.#onDialog(event));
|
||||
client.on('Runtime.exceptionThrown', (exception) =>
|
||||
this.#handleException(exception.exceptionDetails)
|
||||
);
|
||||
client.on('Inspector.targetCrashed', () => this.#onTargetCrashed());
|
||||
client.on('Performance.metrics', (event) => this.#emitMetrics(event));
|
||||
client.on('Log.entryAdded', (event) => this.#onLogEntryAdded(event));
|
||||
client.on('Page.fileChooserOpened', (event) => this.#onFileChooser(event));
|
||||
client.on('Page.domContentEventFired', () => {
|
||||
return this.emit(PageEmittedEvents.DOMContentLoaded);
|
||||
});
|
||||
client.on('Page.loadEventFired', () => {
|
||||
return this.emit(PageEmittedEvents.Load);
|
||||
});
|
||||
client.on('Runtime.consoleAPICalled', (event) => {
|
||||
return this.#onConsoleAPI(event);
|
||||
});
|
||||
client.on('Runtime.bindingCalled', (event) => {
|
||||
return this.#onBindingCalled(event);
|
||||
});
|
||||
client.on('Page.javascriptDialogOpening', (event) => {
|
||||
return this.#onDialog(event);
|
||||
});
|
||||
client.on('Runtime.exceptionThrown', (exception) => {
|
||||
return this.#handleException(exception.exceptionDetails);
|
||||
});
|
||||
client.on('Inspector.targetCrashed', () => {
|
||||
return this.#onTargetCrashed();
|
||||
});
|
||||
client.on('Performance.metrics', (event) => {
|
||||
return this.#emitMetrics(event);
|
||||
});
|
||||
client.on('Log.entryAdded', (event) => {
|
||||
return this.#onLogEntryAdded(event);
|
||||
});
|
||||
client.on('Page.fileChooserOpened', (event) => {
|
||||
return this.#onFileChooser(event);
|
||||
});
|
||||
this.#target._isClosedPromise.then(() => {
|
||||
this.emit(PageEmittedEvents.Close);
|
||||
this.#closed = true;
|
||||
@ -662,9 +680,9 @@ export class Page extends EventEmitter {
|
||||
const wrap =
|
||||
this.#handlerMap.get(handler) ||
|
||||
((event: HTTPRequest) => {
|
||||
event.enqueueInterceptAction(() =>
|
||||
handler(event as PageEventObject[K])
|
||||
);
|
||||
event.enqueueInterceptAction(() => {
|
||||
return handler(event as PageEventObject[K]);
|
||||
});
|
||||
});
|
||||
|
||||
this.#handlerMap.set(handler, wrap);
|
||||
@ -727,7 +745,9 @@ export class Page extends EventEmitter {
|
||||
|
||||
const { timeout = this.#timeoutSettings.timeout() } = options;
|
||||
let callback!: (value: FileChooser | PromiseLike<FileChooser>) => void;
|
||||
const promise = new Promise<FileChooser>((x) => (callback = x));
|
||||
const promise = new Promise<FileChooser>((x) => {
|
||||
return (callback = x);
|
||||
});
|
||||
this.#fileChooserInterceptors.add(callback);
|
||||
return waitWithTimeout<FileChooser>(
|
||||
promise,
|
||||
@ -808,7 +828,9 @@ export class Page extends EventEmitter {
|
||||
#onLogEntryAdded(event: Protocol.Log.EntryAddedEvent): void {
|
||||
const { level, text, args, source, url, lineNumber } = event.entry;
|
||||
if (args) {
|
||||
args.map((arg) => releaseObject(this.#client, arg));
|
||||
args.map((arg) => {
|
||||
return releaseObject(this.#client, arg);
|
||||
});
|
||||
}
|
||||
if (source !== 'worker') {
|
||||
this.emit(
|
||||
@ -1455,7 +1477,9 @@ export class Page extends EventEmitter {
|
||||
source: expression,
|
||||
});
|
||||
await Promise.all(
|
||||
this.frames().map((frame) => frame.evaluate(expression).catch(debugError))
|
||||
this.frames().map((frame) => {
|
||||
return frame.evaluate(expression).catch(debugError);
|
||||
})
|
||||
);
|
||||
}
|
||||
|
||||
@ -1585,7 +1609,9 @@ export class Page extends EventEmitter {
|
||||
event.executionContextId,
|
||||
this.#client
|
||||
);
|
||||
const values = event.args.map((arg) => _createJSHandle(context, arg));
|
||||
const values = event.args.map((arg) => {
|
||||
return _createJSHandle(context, arg);
|
||||
});
|
||||
this.#addConsoleMessage(event.type, values, event.stackTrace);
|
||||
}
|
||||
|
||||
@ -1636,7 +1662,9 @@ export class Page extends EventEmitter {
|
||||
stackTrace?: Protocol.Runtime.StackTrace
|
||||
): void {
|
||||
if (!this.listenerCount(PageEmittedEvents.Console)) {
|
||||
args.forEach((arg) => arg.dispose());
|
||||
args.forEach((arg) => {
|
||||
return arg.dispose();
|
||||
});
|
||||
return;
|
||||
}
|
||||
const textTokens = [];
|
||||
@ -1882,11 +1910,11 @@ export class Page extends EventEmitter {
|
||||
|
||||
#sessionClosePromise(): Promise<Error> {
|
||||
if (!this.#disconnectPromise) {
|
||||
this.#disconnectPromise = new Promise((fulfill) =>
|
||||
this.#client.once(CDPSessionEmittedEvents.Disconnected, () =>
|
||||
fulfill(new Error('Target closed'))
|
||||
)
|
||||
);
|
||||
this.#disconnectPromise = new Promise((fulfill) => {
|
||||
return this.#client.once(CDPSessionEmittedEvents.Disconnected, () => {
|
||||
return fulfill(new Error('Target closed'));
|
||||
});
|
||||
});
|
||||
}
|
||||
return this.#disconnectPromise;
|
||||
}
|
||||
@ -2010,7 +2038,9 @@ export class Page extends EventEmitter {
|
||||
});
|
||||
|
||||
let idleTimer: NodeJS.Timeout;
|
||||
const onIdle = () => idleResolveCallback();
|
||||
const onIdle = () => {
|
||||
return idleResolveCallback();
|
||||
};
|
||||
|
||||
const cleanup = () => {
|
||||
idleTimer && clearTimeout(idleTimer);
|
||||
@ -2031,8 +2061,15 @@ export class Page extends EventEmitter {
|
||||
return false;
|
||||
};
|
||||
|
||||
const listenToEvent = (event: symbol) =>
|
||||
waitForEvent(networkManager, event, eventHandler, timeout, abortPromise);
|
||||
const listenToEvent = (event: symbol) => {
|
||||
return waitForEvent(
|
||||
networkManager,
|
||||
event,
|
||||
eventHandler,
|
||||
timeout,
|
||||
abortPromise
|
||||
);
|
||||
};
|
||||
|
||||
const eventPromises = [
|
||||
listenToEvent(NetworkManagerEmittedEvents.Request),
|
||||
@ -2080,8 +2117,9 @@ export class Page extends EventEmitter {
|
||||
|
||||
let predicate: (frame: Frame) => Promise<boolean>;
|
||||
if (isString(urlOrPredicate)) {
|
||||
predicate = (frame: Frame) =>
|
||||
Promise.resolve(urlOrPredicate === frame.url());
|
||||
predicate = (frame: Frame) => {
|
||||
return Promise.resolve(urlOrPredicate === frame.url());
|
||||
};
|
||||
} else {
|
||||
predicate = (frame: Frame) => {
|
||||
const value = urlOrPredicate(frame);
|
||||
@ -2799,9 +2837,9 @@ export class Page extends EventEmitter {
|
||||
'Expected options.clip.height not to be 0.'
|
||||
);
|
||||
}
|
||||
return this.#screenshotTaskQueue.postTask(() =>
|
||||
this.#screenshotTask(screenshotType, options)
|
||||
);
|
||||
return this.#screenshotTaskQueue.postTask(() => {
|
||||
return this.#screenshotTask(screenshotType, options);
|
||||
});
|
||||
}
|
||||
|
||||
async #screenshotTask(
|
||||
|
@ -78,7 +78,9 @@ function makeQueryHandler(handler: CustomQueryHandler): InternalQueryHandler {
|
||||
domWorld: DOMWorld,
|
||||
selector: string,
|
||||
options: WaitForSelectorOptions
|
||||
) => domWorld._waitForSelectorInPage(queryOne, selector, options);
|
||||
) => {
|
||||
return domWorld._waitForSelectorInPage(queryOne, selector, options);
|
||||
};
|
||||
}
|
||||
|
||||
if (handler.queryAll) {
|
||||
@ -99,7 +101,9 @@ function makeQueryHandler(handler: CustomQueryHandler): InternalQueryHandler {
|
||||
internalHandler.queryAllArray = async (element, selector) => {
|
||||
const resultHandle = await element.evaluateHandle(queryAll, selector);
|
||||
const arrayHandle = await resultHandle.evaluateHandle(
|
||||
(res: Element[] | NodeListOf<Element>) => Array.from(res)
|
||||
(res: Element[] | NodeListOf<Element>) => {
|
||||
return Array.from(res);
|
||||
}
|
||||
);
|
||||
return arrayHandle;
|
||||
};
|
||||
@ -109,10 +113,12 @@ function makeQueryHandler(handler: CustomQueryHandler): InternalQueryHandler {
|
||||
}
|
||||
|
||||
const _defaultHandler = makeQueryHandler({
|
||||
queryOne: (element: Element | Document, selector: string) =>
|
||||
element.querySelector(selector),
|
||||
queryAll: (element: Element | Document, selector: string) =>
|
||||
element.querySelectorAll(selector),
|
||||
queryOne: (element: Element | Document, selector: string) => {
|
||||
return element.querySelector(selector);
|
||||
},
|
||||
queryAll: (element: Element | Document, selector: string) => {
|
||||
return element.querySelectorAll(selector);
|
||||
},
|
||||
});
|
||||
|
||||
const pierceHandler = makeQueryHandler({
|
||||
@ -205,7 +211,9 @@ export function _unregisterCustomQueryHandler(name: string): void {
|
||||
* @internal
|
||||
*/
|
||||
export function _customQueryHandlerNames(): string[] {
|
||||
return [...queryHandlers.keys()].filter((name) => !builtInHandlers.has(name));
|
||||
return [...queryHandlers.keys()].filter((name) => {
|
||||
return !builtInHandlers.has(name);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -84,9 +84,9 @@ export class Target {
|
||||
this.#defaultViewport = defaultViewport ?? undefined;
|
||||
this.#screenshotTaskQueue = screenshotTaskQueue;
|
||||
this._isPageTargetCallback = isPageTargetCallback;
|
||||
this._initializedPromise = new Promise<boolean>(
|
||||
(fulfill) => (this._initializedCallback = fulfill)
|
||||
).then(async (success) => {
|
||||
this._initializedPromise = new Promise<boolean>((fulfill) => {
|
||||
return (this._initializedCallback = fulfill);
|
||||
}).then(async (success) => {
|
||||
if (!success) {
|
||||
return false;
|
||||
}
|
||||
@ -102,9 +102,9 @@ export class Target {
|
||||
openerPage.emit(PageEmittedEvents.Popup, popupPage);
|
||||
return true;
|
||||
});
|
||||
this._isClosedPromise = new Promise<void>(
|
||||
(fulfill) => (this._closedCallback = fulfill)
|
||||
);
|
||||
this._isClosedPromise = new Promise<void>((fulfill) => {
|
||||
return (this._closedCallback = fulfill);
|
||||
});
|
||||
this._isInitialized =
|
||||
!this._isPageTargetCallback(this.#targetInfo) ||
|
||||
this.#targetInfo.url !== '';
|
||||
@ -132,15 +132,15 @@ export class Target {
|
||||
*/
|
||||
async page(): Promise<Page | null> {
|
||||
if (this._isPageTargetCallback(this.#targetInfo) && !this.#pagePromise) {
|
||||
this.#pagePromise = this.#sessionFactory().then((client) =>
|
||||
Page._create(
|
||||
this.#pagePromise = this.#sessionFactory().then((client) => {
|
||||
return Page._create(
|
||||
client,
|
||||
this,
|
||||
this.#ignoreHTTPSErrors,
|
||||
this.#defaultViewport ?? null,
|
||||
this.#screenshotTaskQueue
|
||||
)
|
||||
);
|
||||
});
|
||||
}
|
||||
return (await this.#pagePromise) ?? null;
|
||||
}
|
||||
@ -157,15 +157,14 @@ export class Target {
|
||||
}
|
||||
if (!this.#workerPromise) {
|
||||
// TODO(einbinder): Make workers send their console logs.
|
||||
this.#workerPromise = this.#sessionFactory().then(
|
||||
(client) =>
|
||||
new WebWorker(
|
||||
this.#workerPromise = this.#sessionFactory().then((client) => {
|
||||
return new WebWorker(
|
||||
client,
|
||||
this.#targetInfo.url,
|
||||
() => {} /* consoleAPICalled */,
|
||||
() => {} /* exceptionThrown */
|
||||
)
|
||||
);
|
||||
});
|
||||
}
|
||||
return this.#workerPromise;
|
||||
}
|
||||
|
@ -24,8 +24,12 @@ export class TaskQueue {
|
||||
postTask<T>(task: () => Promise<T>): Promise<T> {
|
||||
const result = this.#chain.then(task);
|
||||
this.#chain = result.then(
|
||||
() => undefined,
|
||||
() => undefined
|
||||
() => {
|
||||
return undefined;
|
||||
},
|
||||
() => {
|
||||
return undefined;
|
||||
}
|
||||
);
|
||||
return result;
|
||||
}
|
||||
|
@ -94,9 +94,15 @@ export class Tracing {
|
||||
}
|
||||
|
||||
const excludedCategories = categories
|
||||
.filter((cat) => cat.startsWith('-'))
|
||||
.map((cat) => cat.slice(1));
|
||||
const includedCategories = categories.filter((cat) => !cat.startsWith('-'));
|
||||
.filter((cat) => {
|
||||
return cat.startsWith('-');
|
||||
})
|
||||
.map((cat) => {
|
||||
return cat.slice(1);
|
||||
});
|
||||
const includedCategories = categories.filter((cat) => {
|
||||
return !cat.startsWith('-');
|
||||
});
|
||||
|
||||
this.#path = path;
|
||||
this.#recording = true;
|
||||
|
@ -79,31 +79,32 @@ export class WebWorker extends EventEmitter {
|
||||
super();
|
||||
this.#client = client;
|
||||
this.#url = url;
|
||||
this.#executionContextPromise = new Promise<ExecutionContext>(
|
||||
(x) => (this.#executionContextCallback = x)
|
||||
);
|
||||
this.#executionContextPromise = new Promise<ExecutionContext>((x) => {
|
||||
return (this.#executionContextCallback = x);
|
||||
});
|
||||
|
||||
let jsHandleFactory: JSHandleFactory;
|
||||
this.#client.once('Runtime.executionContextCreated', async (event) => {
|
||||
// eslint-disable-next-line @typescript-eslint/explicit-function-return-type
|
||||
jsHandleFactory = (remoteObject) =>
|
||||
new JSHandle(executionContext, client, remoteObject);
|
||||
jsHandleFactory = (remoteObject) => {
|
||||
return new JSHandle(executionContext, client, remoteObject);
|
||||
};
|
||||
const executionContext = new ExecutionContext(client, event.context);
|
||||
this.#executionContextCallback(executionContext);
|
||||
});
|
||||
|
||||
// This might fail if the target is closed before we receive all execution contexts.
|
||||
this.#client.send('Runtime.enable').catch(debugError);
|
||||
this.#client.on('Runtime.consoleAPICalled', (event) =>
|
||||
consoleAPICalled(
|
||||
this.#client.on('Runtime.consoleAPICalled', (event) => {
|
||||
return consoleAPICalled(
|
||||
event.type,
|
||||
event.args.map(jsHandleFactory),
|
||||
event.stackTrace
|
||||
)
|
||||
);
|
||||
this.#client.on('Runtime.exceptionThrown', (exception) =>
|
||||
exceptionThrown(exception.exceptionDetails)
|
||||
);
|
||||
});
|
||||
this.#client.on('Runtime.exceptionThrown', (exception) => {
|
||||
return exceptionThrown(exception.exceptionDetails);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -212,9 +212,9 @@ export function pageBindingInitString(type: string, name: string): string {
|
||||
}
|
||||
const seq = (me.lastSeq || 0) + 1;
|
||||
me.lastSeq = seq;
|
||||
const promise = new Promise((resolve, reject) =>
|
||||
callbacks.set(seq, { resolve, reject })
|
||||
);
|
||||
const promise = new Promise((resolve, reject) => {
|
||||
return callbacks.set(seq, { resolve, reject });
|
||||
});
|
||||
binding(JSON.stringify({ type, name: bindingName, seq, args }));
|
||||
return promise;
|
||||
};
|
||||
@ -318,10 +318,14 @@ export async function waitWithTimeout<T>(
|
||||
const timeoutError = new TimeoutError(
|
||||
`waiting for ${taskName} failed: timeout ${timeout}ms exceeded`
|
||||
);
|
||||
const timeoutPromise = new Promise<T>((_res, rej) => (reject = rej));
|
||||
const timeoutPromise = new Promise<T>((_res, rej) => {
|
||||
return (reject = rej);
|
||||
});
|
||||
let timeoutTimer = null;
|
||||
if (timeout) {
|
||||
timeoutTimer = setTimeout(() => reject(timeoutError), timeout);
|
||||
timeoutTimer = setTimeout(() => {
|
||||
return reject(timeoutError);
|
||||
}, timeout);
|
||||
}
|
||||
try {
|
||||
return await Promise.race([promise, timeoutPromise]);
|
||||
|
@ -143,7 +143,9 @@ const chmodAsync = promisify(fs.chmod.bind(fs));
|
||||
|
||||
function existsAsync(filePath: string): Promise<boolean> {
|
||||
return new Promise((resolve) => {
|
||||
fs.access(filePath, (err) => resolve(!err));
|
||||
fs.access(filePath, (err) => {
|
||||
return resolve(!err);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
@ -365,14 +367,19 @@ export class BrowserFetcher {
|
||||
}
|
||||
const fileNames = await readdirAsync(this.#downloadsFolder);
|
||||
return fileNames
|
||||
.map((fileName) => parseFolderPath(this.#product, fileName))
|
||||
.map((fileName) => {
|
||||
return parseFolderPath(this.#product, fileName);
|
||||
})
|
||||
.filter(
|
||||
(
|
||||
entry
|
||||
): entry is { product: string; platform: string; revision: string } =>
|
||||
(entry && entry.platform === this.#platform) ?? false
|
||||
): entry is { product: string; platform: string; revision: string } => {
|
||||
return (entry && entry.platform === this.#platform) ?? false;
|
||||
}
|
||||
)
|
||||
.map((entry) => entry.revision);
|
||||
.map((entry) => {
|
||||
return entry.revision;
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
@ -388,7 +395,9 @@ export class BrowserFetcher {
|
||||
await existsAsync(folderPath),
|
||||
`Failed to remove: revision ${revision} is not downloaded`
|
||||
);
|
||||
await new Promise((fulfill) => removeRecursive(folderPath, fulfill));
|
||||
await new Promise((fulfill) => {
|
||||
return removeRecursive(folderPath, fulfill);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
@ -518,15 +527,21 @@ function _downloadFile(
|
||||
return;
|
||||
}
|
||||
const file = fs.createWriteStream(destinationPath);
|
||||
file.on('finish', () => fulfill());
|
||||
file.on('error', (error) => reject(error));
|
||||
file.on('finish', () => {
|
||||
return fulfill();
|
||||
});
|
||||
file.on('error', (error) => {
|
||||
return reject(error);
|
||||
});
|
||||
response.pipe(file);
|
||||
totalBytes = parseInt(response.headers['content-length']!, 10);
|
||||
if (progressCallback) {
|
||||
response.on('data', onData);
|
||||
}
|
||||
});
|
||||
request.on('error', (error) => reject(error));
|
||||
request.on('error', (error) => {
|
||||
return reject(error);
|
||||
});
|
||||
return promise;
|
||||
|
||||
function onData(chunk: string): void {
|
||||
@ -542,9 +557,9 @@ function install(archivePath: string, folderPath: string): Promise<unknown> {
|
||||
} else if (archivePath.endsWith('.tar.bz2')) {
|
||||
return _extractTar(archivePath, folderPath);
|
||||
} else if (archivePath.endsWith('.dmg')) {
|
||||
return mkdirAsync(folderPath).then(() =>
|
||||
_installDMG(archivePath, folderPath)
|
||||
);
|
||||
return mkdirAsync(folderPath).then(() => {
|
||||
return _installDMG(archivePath, folderPath);
|
||||
});
|
||||
} else {
|
||||
throw new Error(`Unsupported archive format: ${archivePath}`);
|
||||
}
|
||||
@ -582,9 +597,9 @@ function _installDMG(dmgPath: string, folderPath: string): Promise<void> {
|
||||
mountPath = volumes[0]!;
|
||||
readdirAsync(mountPath)
|
||||
.then((fileNames) => {
|
||||
const appName = fileNames.find(
|
||||
(item) => typeof item === 'string' && item.endsWith('.app')
|
||||
);
|
||||
const appName = fileNames.find((item) => {
|
||||
return typeof item === 'string' && item.endsWith('.app');
|
||||
});
|
||||
if (!appName) {
|
||||
return reject(new Error(`Cannot find app in ${mountPath}`));
|
||||
}
|
||||
|
@ -286,9 +286,15 @@ function waitForWSEndpoint(
|
||||
return new Promise((resolve, reject) => {
|
||||
const listeners = [
|
||||
addEventListener(rl, 'line', onLine),
|
||||
addEventListener(rl, 'close', () => onClose()),
|
||||
addEventListener(browserProcess, 'exit', () => onClose()),
|
||||
addEventListener(browserProcess, 'error', (error) => onClose(error)),
|
||||
addEventListener(rl, 'close', () => {
|
||||
return onClose();
|
||||
}),
|
||||
addEventListener(browserProcess, 'exit', () => {
|
||||
return onClose();
|
||||
}),
|
||||
addEventListener(browserProcess, 'error', (error) => {
|
||||
return onClose(error);
|
||||
}),
|
||||
];
|
||||
const timeoutId = timeout ? setTimeout(onTimeout, timeout) : 0;
|
||||
|
||||
|
@ -35,7 +35,9 @@ import {
|
||||
|
||||
import { Product } from '../common/Product.js';
|
||||
|
||||
const tmpDir = () => process.env['PUPPETEER_TMP_DIR'] || os.tmpdir();
|
||||
const tmpDir = () => {
|
||||
return process.env['PUPPETEER_TMP_DIR'] || os.tmpdir();
|
||||
};
|
||||
|
||||
/**
|
||||
* Describes a launcher - a class that is able to create and launch a browser instance.
|
||||
@ -100,18 +102,18 @@ class ChromeLauncher implements ProductLauncher {
|
||||
chromeArguments.push(...this.defaultArgs(options));
|
||||
} else if (Array.isArray(ignoreDefaultArgs)) {
|
||||
chromeArguments.push(
|
||||
...this.defaultArgs(options).filter(
|
||||
(arg) => !ignoreDefaultArgs.includes(arg)
|
||||
)
|
||||
...this.defaultArgs(options).filter((arg) => {
|
||||
return !ignoreDefaultArgs.includes(arg);
|
||||
})
|
||||
);
|
||||
} else {
|
||||
chromeArguments.push(...args);
|
||||
}
|
||||
|
||||
if (
|
||||
!chromeArguments.some((argument) =>
|
||||
argument.startsWith('--remote-debugging-')
|
||||
)
|
||||
!chromeArguments.some((argument) => {
|
||||
return argument.startsWith('--remote-debugging-');
|
||||
})
|
||||
) {
|
||||
if (pipe) {
|
||||
assert(
|
||||
@ -202,7 +204,12 @@ class ChromeLauncher implements ProductLauncher {
|
||||
|
||||
if (waitForInitialPage) {
|
||||
try {
|
||||
await browser.waitForTarget((t) => t.type() === 'page', { timeout });
|
||||
await browser.waitForTarget(
|
||||
(t) => {
|
||||
return t.type() === 'page';
|
||||
},
|
||||
{ timeout }
|
||||
);
|
||||
} catch (error) {
|
||||
await browser.close();
|
||||
throw error;
|
||||
@ -264,7 +271,11 @@ class ChromeLauncher implements ProductLauncher {
|
||||
'--mute-audio'
|
||||
);
|
||||
}
|
||||
if (args.every((arg) => arg.startsWith('-'))) {
|
||||
if (
|
||||
args.every((arg) => {
|
||||
return arg.startsWith('-');
|
||||
})
|
||||
) {
|
||||
chromeArguments.push('about:blank');
|
||||
}
|
||||
chromeArguments.push(...args);
|
||||
@ -337,18 +348,18 @@ class FirefoxLauncher implements ProductLauncher {
|
||||
firefoxArguments.push(...this.defaultArgs(options));
|
||||
} else if (Array.isArray(ignoreDefaultArgs)) {
|
||||
firefoxArguments.push(
|
||||
...this.defaultArgs(options).filter(
|
||||
(arg) => !ignoreDefaultArgs.includes(arg)
|
||||
)
|
||||
...this.defaultArgs(options).filter((arg) => {
|
||||
return !ignoreDefaultArgs.includes(arg);
|
||||
})
|
||||
);
|
||||
} else {
|
||||
firefoxArguments.push(...args);
|
||||
}
|
||||
|
||||
if (
|
||||
!firefoxArguments.some((argument) =>
|
||||
argument.startsWith('--remote-debugging-')
|
||||
)
|
||||
!firefoxArguments.some((argument) => {
|
||||
return argument.startsWith('--remote-debugging-');
|
||||
})
|
||||
) {
|
||||
if (pipe) {
|
||||
assert(
|
||||
@ -438,7 +449,12 @@ class FirefoxLauncher implements ProductLauncher {
|
||||
|
||||
if (waitForInitialPage) {
|
||||
try {
|
||||
await browser.waitForTarget((t) => t.type() === 'page', { timeout });
|
||||
await browser.waitForTarget(
|
||||
(t) => {
|
||||
return t.type() === 'page';
|
||||
},
|
||||
{ timeout }
|
||||
);
|
||||
} catch (error) {
|
||||
await browser.close();
|
||||
throw error;
|
||||
@ -499,7 +515,11 @@ class FirefoxLauncher implements ProductLauncher {
|
||||
if (devtools) {
|
||||
firefoxArguments.push('--devtools');
|
||||
}
|
||||
if (args.every((arg) => arg.startsWith('-'))) {
|
||||
if (
|
||||
args.every((arg) => {
|
||||
return arg.startsWith('-');
|
||||
})
|
||||
) {
|
||||
firefoxArguments.push('about:blank');
|
||||
}
|
||||
firefoxArguments.push(...args);
|
||||
|
@ -43,9 +43,9 @@ export class NodeWebSocketTransport implements ConnectionTransport {
|
||||
},
|
||||
});
|
||||
|
||||
ws.addEventListener('open', () =>
|
||||
resolve(new NodeWebSocketTransport(ws))
|
||||
);
|
||||
ws.addEventListener('open', () => {
|
||||
return resolve(new NodeWebSocketTransport(ws));
|
||||
});
|
||||
ws.addEventListener('error', reject);
|
||||
});
|
||||
}
|
||||
|
@ -38,7 +38,9 @@ export class PipeTransport implements ConnectionTransport {
|
||||
) {
|
||||
this.#pipeWrite = pipeWrite;
|
||||
this.#eventListeners = [
|
||||
addEventListener(pipeRead, 'data', (buffer) => this.#dispatch(buffer)),
|
||||
addEventListener(pipeRead, 'data', (buffer) => {
|
||||
return this.#dispatch(buffer);
|
||||
}),
|
||||
addEventListener(pipeRead, 'close', () => {
|
||||
if (this.onclose) {
|
||||
this.onclose.call(null);
|
||||
|
@ -111,12 +111,12 @@ export async function downloadBrowser(): Promise<void> {
|
||||
logPolitely(
|
||||
`${supportedProducts[product]} (${revisionInfo.revision}) downloaded to ${revisionInfo.folderPath}`
|
||||
);
|
||||
localRevisions = localRevisions.filter(
|
||||
(revision) => revision !== revisionInfo.revision
|
||||
);
|
||||
const cleanupOldVersions = localRevisions.map((revision) =>
|
||||
browserFetcher.remove(revision)
|
||||
);
|
||||
localRevisions = localRevisions.filter((revision) => {
|
||||
return revision !== revisionInfo.revision;
|
||||
});
|
||||
const cleanupOldVersions = localRevisions.map((revision) => {
|
||||
return browserFetcher.remove(revision);
|
||||
});
|
||||
Promise.all([...cleanupOldVersions]);
|
||||
}
|
||||
|
||||
@ -151,7 +151,9 @@ export async function downloadBrowser(): Promise<void> {
|
||||
|
||||
return browserFetcher
|
||||
.download(revisionInfo.revision, onProgress)
|
||||
.then(() => browserFetcher.localRevisions())
|
||||
.then(() => {
|
||||
return browserFetcher.localRevisions();
|
||||
})
|
||||
.then(onSuccess)
|
||||
.catch(onError);
|
||||
}
|
||||
|
@ -1,6 +1,5 @@
|
||||
module.exports = {
|
||||
rules: {
|
||||
'arrow-body-style': ['error', 'always'],
|
||||
'no-restricted-imports': [
|
||||
'error',
|
||||
{
|
||||
|
@ -22,10 +22,15 @@ const { promisify } = require('util');
|
||||
const exec = promisify(child_process.exec);
|
||||
const fsAccess = promisify(fs.access);
|
||||
|
||||
const fileExists = async (filePath) =>
|
||||
fsAccess(filePath)
|
||||
.then(() => true)
|
||||
.catch(() => false);
|
||||
const fileExists = async (filePath) => {
|
||||
return fsAccess(filePath)
|
||||
.then(() => {
|
||||
return true;
|
||||
})
|
||||
.catch(() => {
|
||||
return false;
|
||||
});
|
||||
};
|
||||
/*
|
||||
|
||||
* Now Puppeteer is built with TypeScript, we need to ensure that
|
||||
|
@ -168,8 +168,12 @@ function runScript(scriptPath, revisionInfo) {
|
||||
},
|
||||
});
|
||||
return new Promise((resolve, reject) => {
|
||||
child.on('error', (err) => reject(err));
|
||||
child.on('exit', (code) => resolve(code));
|
||||
child.on('error', (err) => {
|
||||
return reject(err);
|
||||
});
|
||||
child.on('exit', (code) => {
|
||||
return resolve(code);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
@ -185,8 +189,12 @@ function runUnitTest(pattern, revisionInfo) {
|
||||
},
|
||||
});
|
||||
return new Promise((resolve, reject) => {
|
||||
child.on('error', (err) => reject(err));
|
||||
child.on('exit', (code) => resolve(code));
|
||||
child.on('error', (err) => {
|
||||
return reject(err);
|
||||
});
|
||||
child.on('exit', (code) => {
|
||||
return resolve(code);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
@ -274,10 +282,16 @@ function fetchJSON(url) {
|
||||
const req = agent.request(options, function (res) {
|
||||
let result = '';
|
||||
res.setEncoding('utf8');
|
||||
res.on('data', (chunk) => (result += chunk));
|
||||
res.on('end', () => resolve(JSON.parse(result)));
|
||||
res.on('data', (chunk) => {
|
||||
return (result += chunk);
|
||||
});
|
||||
res.on('end', () => {
|
||||
return resolve(JSON.parse(result));
|
||||
});
|
||||
});
|
||||
req.on('error', (err) => {
|
||||
return reject(err);
|
||||
});
|
||||
req.on('error', (err) => reject(err));
|
||||
req.end();
|
||||
});
|
||||
}
|
||||
|
@ -155,7 +155,9 @@ async function checkOmahaProxyAvailability() {
|
||||
'https://storage.googleapis.com/chromium-browser-snapshots/Win_x64/LAST_CHANGE'
|
||||
),
|
||||
])
|
||||
).map((s) => parseInt(s, 10));
|
||||
).map((s) => {
|
||||
return parseInt(s, 10);
|
||||
});
|
||||
const from = Math.max(...latestRevisions);
|
||||
await checkRangeAvailability({
|
||||
fromRevision: from,
|
||||
@ -183,7 +185,9 @@ async function printLatestRevisionForPlatform(platform) {
|
||||
'https://storage.googleapis.com/chromium-browser-snapshots/Win_x64/LAST_CHANGE'
|
||||
),
|
||||
])
|
||||
).map((s) => parseInt(s, 10));
|
||||
).map((s) => {
|
||||
return parseInt(s, 10);
|
||||
});
|
||||
const from = Math.max(...latestRevisions);
|
||||
await checkRangeAvailability({
|
||||
fromRevision: from,
|
||||
@ -233,13 +237,18 @@ async function checkRangeAvailability({
|
||||
platforms = platforms || SUPPORTED_PLATFORMS;
|
||||
let table;
|
||||
if (printAsTable) {
|
||||
table = new Table([10, ...platforms.map(() => 7)]);
|
||||
table = new Table([
|
||||
10,
|
||||
...platforms.map(() => {
|
||||
return 7;
|
||||
}),
|
||||
]);
|
||||
table.drawRow([''].concat(platforms));
|
||||
}
|
||||
|
||||
const fetchers = platforms.map(
|
||||
(platform) => new BrowserFetcher('', { platform })
|
||||
);
|
||||
const fetchers = platforms.map((platform) => {
|
||||
return new BrowserFetcher('', { platform });
|
||||
});
|
||||
|
||||
const inc = fromRevision < toRevision ? 1 : -1;
|
||||
const revisionToStop = toRevision + inc; // +inc so the range is fully inclusive
|
||||
@ -248,9 +257,13 @@ async function checkRangeAvailability({
|
||||
revision !== revisionToStop;
|
||||
revision += inc
|
||||
) {
|
||||
const promises = fetchers.map((fetcher) => fetcher.canDownload(revision));
|
||||
const promises = fetchers.map((fetcher) => {
|
||||
return fetcher.canDownload(revision);
|
||||
});
|
||||
const availability = await Promise.all(promises);
|
||||
const allAvailable = availability.every((e) => !!e);
|
||||
const allAvailable = availability.every((e) => {
|
||||
return !!e;
|
||||
});
|
||||
if (table) {
|
||||
const values = [
|
||||
' ' +
|
||||
@ -279,7 +292,9 @@ async function checkRangeAvailability({
|
||||
*/
|
||||
function fetch(url) {
|
||||
let resolve;
|
||||
const promise = new Promise((x) => (resolve = x));
|
||||
const promise = new Promise((x) => {
|
||||
return (resolve = x);
|
||||
});
|
||||
https
|
||||
.get(url, (response) => {
|
||||
if (response.statusCode !== 200) {
|
||||
|
@ -86,8 +86,12 @@ async function main(url) {
|
||||
return;
|
||||
}
|
||||
const devicePayloads = json.extensions
|
||||
.filter((extension) => extension.type === 'emulated-device')
|
||||
.map((extension) => extension.device);
|
||||
.filter((extension) => {
|
||||
return extension.type === 'emulated-device';
|
||||
})
|
||||
.map((extension) => {
|
||||
return extension.device;
|
||||
});
|
||||
let devices = [];
|
||||
for (const payload of devicePayloads) {
|
||||
let names = [];
|
||||
@ -112,8 +116,12 @@ async function main(url) {
|
||||
}
|
||||
}
|
||||
}
|
||||
devices = devices.filter((device) => device.viewport.isMobile);
|
||||
devices.sort((a, b) => a.name.localeCompare(b.name));
|
||||
devices = devices.filter((device) => {
|
||||
return device.viewport.isMobile;
|
||||
});
|
||||
devices.sort((a, b) => {
|
||||
return a.name.localeCompare(b.name);
|
||||
});
|
||||
// Use single-quotes instead of double-quotes to conform with codestyle.
|
||||
const serialized = JSON.stringify(devices, null, 2)
|
||||
.replace(/'/g, `\\'`)
|
||||
@ -282,8 +290,12 @@ function httpGET(url) {
|
||||
const request = driver.get(url, (response) => {
|
||||
let data = '';
|
||||
response.setEncoding('utf8');
|
||||
response.on('data', (chunk) => (data += chunk));
|
||||
response.on('end', () => fulfill(data));
|
||||
response.on('data', (chunk) => {
|
||||
return (data += chunk);
|
||||
});
|
||||
response.on('end', () => {
|
||||
return fulfill(data);
|
||||
});
|
||||
response.on('error', reject);
|
||||
});
|
||||
request.on('error', reject);
|
||||
|
@ -67,7 +67,9 @@ export class TestServer {
|
||||
|
||||
static async create(dirPath: string, port: number): Promise<TestServer> {
|
||||
const server = new TestServer(dirPath, port);
|
||||
await new Promise((x) => server.#server.once('listening', x));
|
||||
await new Promise((x) => {
|
||||
return server.#server.once('listening', x);
|
||||
});
|
||||
return server;
|
||||
}
|
||||
|
||||
@ -77,7 +79,9 @@ export class TestServer {
|
||||
cert: readFileSync(join(__dirname, '..', 'cert.pem')),
|
||||
passphrase: 'aaaa',
|
||||
});
|
||||
await new Promise((x) => server.#server.once('listening', x));
|
||||
await new Promise((x) => {
|
||||
return server.#server.once('listening', x);
|
||||
});
|
||||
return server;
|
||||
}
|
||||
|
||||
@ -104,7 +108,9 @@ export class TestServer {
|
||||
throw error;
|
||||
}
|
||||
});
|
||||
connection.once('close', () => this.#connections.delete(connection));
|
||||
connection.once('close', () => {
|
||||
return this.#connections.delete(connection);
|
||||
});
|
||||
};
|
||||
|
||||
enableHTTPCache(pathPrefix: string): void {
|
||||
@ -129,7 +135,9 @@ export class TestServer {
|
||||
socket.destroy();
|
||||
}
|
||||
this.#connections.clear();
|
||||
await new Promise((x) => this.#server.close(x));
|
||||
await new Promise((x) => {
|
||||
return this.#server.close(x);
|
||||
});
|
||||
}
|
||||
|
||||
setRoute(
|
||||
@ -186,8 +194,12 @@ export class TestServer {
|
||||
});
|
||||
request.postBody = new Promise((resolve) => {
|
||||
let body = '';
|
||||
request.on('data', (chunk: string) => (body += chunk));
|
||||
request.on('end', () => resolve(body));
|
||||
request.on('data', (chunk: string) => {
|
||||
return (body += chunk);
|
||||
});
|
||||
request.on('end', () => {
|
||||
return resolve(body);
|
||||
});
|
||||
});
|
||||
assert(request.url);
|
||||
const url = new URL(request.url, `https://${request.headers.host}`);
|
||||
|
Loading…
Reference in New Issue
Block a user