chore: upgrade internal types to support TypeScript 4.9.3 (#19280)

Fixes https://github.com/microsoft/TypeScript/issues/51619

Co-authored-by: Max Schmitt <max@schmitt.mx>
This commit is contained in:
Dmitry Gozman 2022-12-05 17:22:25 -08:00 committed by GitHub
parent 48182a4eb2
commit 81c8620bfe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 54 additions and 20 deletions

33
package-lock.json generated
View File

@ -23,7 +23,7 @@
"@babel/preset-react": "^7.18.6", "@babel/preset-react": "^7.18.6",
"@types/codemirror": "^5.60.5", "@types/codemirror": "^5.60.5",
"@types/formidable": "^2.0.4", "@types/formidable": "^2.0.4",
"@types/node": "=14.18.24", "@types/node": "=14.18.34",
"@types/react": "^18.0.12", "@types/react": "^18.0.12",
"@types/react-dom": "^18.0.5", "@types/react-dom": "^18.0.5",
"@types/resize-observer-browser": "^0.1.7", "@types/resize-observer-browser": "^0.1.7",
@ -59,7 +59,7 @@
"rimraf": "^3.0.2", "rimraf": "^3.0.2",
"socksv5": "0.0.6", "socksv5": "0.0.6",
"ssim.js": "^3.5.0", "ssim.js": "^3.5.0",
"typescript": "^4.7.3", "typescript": "^4.9.3",
"vite": "^3.2.1", "vite": "^3.2.1",
"ws": "^8.5.0", "ws": "^8.5.0",
"xml2js": "^0.4.23", "xml2js": "^0.4.23",
@ -1083,8 +1083,9 @@
"license": "MIT" "license": "MIT"
}, },
"node_modules/@types/node": { "node_modules/@types/node": {
"version": "14.18.24", "version": "14.18.34",
"license": "MIT" "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.34.tgz",
"integrity": "sha512-hcU9AIQVHmPnmjRK+XUUYlILlr9pQrsqSrwov/JK1pnf3GTQowVBhx54FbvM0AU/VXGH4i3+vgXS5EguR7fysA=="
}, },
"node_modules/@types/normalize-package-data": { "node_modules/@types/normalize-package-data": {
"version": "2.4.1", "version": "2.4.1",
@ -2348,9 +2349,10 @@
"integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==" "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA=="
}, },
"node_modules/electron/node_modules/@types/node": { "node_modules/electron/node_modules/@types/node": {
"version": "16.11.47", "version": "16.18.6",
"dev": true, "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.6.tgz",
"license": "MIT" "integrity": "sha512-vmYJF0REqDyyU0gviezF/KHq/fYaUbFhkcNbQCuPGFQj6VTbXuHZoxs/Y7mutWe73C8AC6l9fFu8mSYiBAqkGA==",
"dev": true
}, },
"node_modules/electron/node_modules/debug": { "node_modules/electron/node_modules/debug": {
"version": "2.6.9", "version": "2.6.9",
@ -5081,9 +5083,10 @@
"license": "MIT" "license": "MIT"
}, },
"node_modules/typescript": { "node_modules/typescript": {
"version": "4.7.3", "version": "4.9.3",
"resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.3.tgz",
"integrity": "sha512-CIfGzTelbKNEnLpLdGFgdyKhG23CKdKgQPOBc+OUNrkJ2vr+KSzsSV5kq5iWhEQbok+quxgGzrAtGWCyU7tHnA==",
"dev": true, "dev": true,
"license": "Apache-2.0",
"bin": { "bin": {
"tsc": "bin/tsc", "tsc": "bin/tsc",
"tsserver": "bin/tsserver" "tsserver": "bin/tsserver"
@ -6778,7 +6781,9 @@
"dev": true "dev": true
}, },
"@types/node": { "@types/node": {
"version": "14.18.24" "version": "14.18.34",
"resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.34.tgz",
"integrity": "sha512-hcU9AIQVHmPnmjRK+XUUYlILlr9pQrsqSrwov/JK1pnf3GTQowVBhx54FbvM0AU/VXGH4i3+vgXS5EguR7fysA=="
}, },
"@types/normalize-package-data": { "@types/normalize-package-data": {
"version": "2.4.1", "version": "2.4.1",
@ -7600,7 +7605,9 @@
}, },
"dependencies": { "dependencies": {
"@types/node": { "@types/node": {
"version": "16.11.47", "version": "16.18.6",
"resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.6.tgz",
"integrity": "sha512-vmYJF0REqDyyU0gviezF/KHq/fYaUbFhkcNbQCuPGFQj6VTbXuHZoxs/Y7mutWe73C8AC6l9fFu8mSYiBAqkGA==",
"dev": true "dev": true
}, },
"debug": { "debug": {
@ -9304,7 +9311,9 @@
"dev": true "dev": true
}, },
"typescript": { "typescript": {
"version": "4.7.3", "version": "4.9.3",
"resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.3.tgz",
"integrity": "sha512-CIfGzTelbKNEnLpLdGFgdyKhG23CKdKgQPOBc+OUNrkJ2vr+KSzsSV5kq5iWhEQbok+quxgGzrAtGWCyU7tHnA==",
"dev": true "dev": true
}, },
"universalify": { "universalify": {

View File

@ -58,7 +58,7 @@
"@babel/preset-react": "^7.18.6", "@babel/preset-react": "^7.18.6",
"@types/codemirror": "^5.60.5", "@types/codemirror": "^5.60.5",
"@types/formidable": "^2.0.4", "@types/formidable": "^2.0.4",
"@types/node": "=14.18.24", "@types/node": "=14.18.34",
"@types/react": "^18.0.12", "@types/react": "^18.0.12",
"@types/react-dom": "^18.0.5", "@types/react-dom": "^18.0.5",
"@types/resize-observer-browser": "^0.1.7", "@types/resize-observer-browser": "^0.1.7",
@ -94,7 +94,7 @@
"rimraf": "^3.0.2", "rimraf": "^3.0.2",
"socksv5": "0.0.6", "socksv5": "0.0.6",
"ssim.js": "^3.5.0", "ssim.js": "^3.5.0",
"typescript": "^4.7.3", "typescript": "^4.9.3",
"vite": "^3.2.1", "vite": "^3.2.1",
"ws": "^8.5.0", "ws": "^8.5.0",
"xml2js": "^0.4.23", "xml2js": "^0.4.23",

View File

@ -120,6 +120,7 @@ export class FrameExecutionContext extends js.ExecutionContext {
} }
export class ElementHandle<T extends Node = Node> extends js.JSHandle<T> { export class ElementHandle<T extends Node = Node> extends js.JSHandle<T> {
__elementhandle: T = true as any;
declare readonly _context: FrameExecutionContext; declare readonly _context: FrameExecutionContext;
readonly _page: Page; readonly _page: Page;
declare readonly _objectId: string; declare readonly _objectId: string;

View File

@ -27,10 +27,16 @@ export type RemoteObject = {
value?: any value?: any
}; };
type NoHandles<Arg> = Arg extends JSHandle ? never : (Arg extends object ? { [Key in keyof Arg]: NoHandles<Arg[Key]> } : Arg); interface TaggedAsJSHandle<T> {
__jshandle: T;
}
interface TaggedAsElementHandle<T> {
__elementhandle: T;
}
type NoHandles<Arg> = Arg extends TaggedAsJSHandle<any> ? never : (Arg extends object ? { [Key in keyof Arg]: NoHandles<Arg[Key]> } : Arg);
type Unboxed<Arg> = type Unboxed<Arg> =
Arg extends dom.ElementHandle<infer T> ? T : Arg extends TaggedAsElementHandle<infer T> ? T :
Arg extends JSHandle<infer T> ? T : Arg extends TaggedAsJSHandle<infer T> ? T :
Arg extends NoHandles<Arg> ? Arg : Arg extends NoHandles<Arg> ? Arg :
Arg extends [infer A0] ? [Unboxed<A0>] : Arg extends [infer A0] ? [Unboxed<A0>] :
Arg extends [infer A0, infer A1] ? [Unboxed<A0>, Unboxed<A1>] : Arg extends [infer A0, infer A1] ? [Unboxed<A0>, Unboxed<A1>] :
@ -129,6 +135,7 @@ export class ExecutionContext extends SdkObject {
} }
export class JSHandle<T = any> extends SdkObject { export class JSHandle<T = any> extends SdkObject {
__jshandle: T = true as any;
readonly _context: ExecutionContext; readonly _context: ExecutionContext;
_disposed = false; _disposed = false;
readonly _objectId: ObjectId | undefined; readonly _objectId: ObjectId | undefined;

View File

@ -29,7 +29,7 @@ export async function queryObjectCount(type: Function): Promise<number> {
prototypeObjectId: constructorFunction.objectId prototypeObjectId: constructorFunction.objectId
}, (_, result) => f(result))) as any; }, (_, result) => f(result))) as any;
const { result: { value } } = await new Promise(f => session.post('Runtime.callFunctionOn', { const { result: { value } } = await new Promise<any>(f => session.post('Runtime.callFunctionOn', {
functionDeclaration: 'function (arr) { return this.length; }', functionDeclaration: 'function (arr) { return this.length; }',
objectId: instanceArray.objectId, objectId: instanceArray.objectId,
arguments: [{ objectId: instanceArray.objectId }], arguments: [{ objectId: instanceArray.objectId }],

View File

@ -657,8 +657,7 @@ async function captureLastKeydown(page) {
lastEvent.key = e.key; lastEvent.key = e.key;
lastEvent.code = e.code; lastEvent.code = e.code;
lastEvent.metaKey = e.metaKey; lastEvent.metaKey = e.metaKey;
// keyIdentifier only exists in WebKit, and isn't in TypeScript's lib. lastEvent.keyIdentifier = 'keyIdentifier' in e && typeof e['keyIdentifier'] === 'string' && e['keyIdentifier'];
lastEvent.keyIdentifier = 'keyIdentifier' in e && e['keyIdentifier'];
}, true); }, true);
return lastEvent; return lastEvent;
}); });

View File

@ -567,6 +567,23 @@ playwright.chromium.launch().then(async browser => {
const value = await handle.jsonValue(); const value = await handle.jsonValue();
const assertion: AssertType<number, typeof value> = true; const assertion: AssertType<number, typeof value> = true;
} }
{
const handle = await page.evaluateHandle(() => document.body);
const tuple = { s: '', n: 23, h: handle };
const value = await page.evaluate(([{ s, n, h }]) => {
return parseInt(s) + n + parseInt(h.nodeName);
}, [tuple]);
const assertion: AssertType<number, typeof value> = true;
}
{
type T = ({ s: string } | playwright.ElementHandle)[];
const handle = await page.evaluateHandle(() => document.body);
const tuple: T = [{ s: '' }, handle];
const value = await page.evaluate(([a, b]) => {
return (a instanceof Node ? a.nodeName : a.s) + (b instanceof Node ? b.nodeName : b.s);
}, tuple);
const assertion: AssertType<string, typeof value> = true;
}
{ {
const handle = await page.evaluateHandle(() => document.createElement('body')); const handle = await page.evaluateHandle(() => document.createElement('body'));
@ -861,3 +878,4 @@ import {
Geolocation, Geolocation,
HTTPCredentials, HTTPCredentials,
} from 'playwright'; } from 'playwright';