brave-real-playwright-core 1.55.1-patch.1 → 1.56.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -5
- package/advanced-stealth.js +1 -1
- package/lib/browserServerImpl.js +3 -6
- package/lib/client/browser.js +0 -10
- package/lib/client/browserContext.js +2 -8
- package/lib/client/channelOwner.js +0 -7
- package/lib/client/consoleMessage.js +2 -3
- package/lib/client/electron.js +1 -1
- package/lib/client/events.js +1 -0
- package/lib/client/network.js +3 -0
- package/lib/client/page.js +13 -1
- package/lib/generated/bindingsControllerSource.js +1 -1
- package/lib/generated/injectedScriptSource.js +1 -1
- package/lib/generated/pollingRecorderSource.js +1 -1
- package/lib/generated/utilityScriptSource.js +1 -1
- package/lib/protocol/validator.js +26 -15
- package/lib/remote/playwrightServer.js +12 -14
- package/lib/server/bidi/bidiBrowser.js +54 -10
- package/lib/server/bidi/bidiChromium.js +1 -1
- package/lib/server/bidi/bidiConnection.js +31 -6
- package/lib/server/bidi/bidiExecutionContext.js +4 -4
- package/lib/server/bidi/bidiFirefox.js +16 -1
- package/lib/server/bidi/bidiNetworkManager.js +82 -16
- package/lib/server/bidi/bidiPage.js +84 -18
- package/lib/server/browserType.js +3 -3
- package/lib/server/chromium/chromium.js +1 -1
- package/lib/server/chromium/chromiumSwitches.js +3 -1
- package/lib/server/chromium/crBrowser.js +2 -33
- package/lib/server/chromium/crPage.js +22 -31
- package/lib/server/codegen/csharp.js +19 -26
- package/lib/server/codegen/java.js +4 -0
- package/lib/server/codegen/javascript.js +3 -1
- package/lib/server/codegen/python.js +2 -0
- package/lib/server/debugController.js +8 -36
- package/lib/server/deviceDescriptorsSource.json +62 -62
- package/lib/server/dispatchers/androidDispatcher.js +17 -0
- package/lib/server/dispatchers/browserContextDispatcher.js +1 -15
- package/lib/server/dispatchers/networkDispatchers.js +6 -3
- package/lib/server/dispatchers/pageDispatcher.js +24 -0
- package/lib/server/dom.js +8 -3
- package/lib/server/firefox/ffPage.js +1 -2
- package/lib/server/firefox/firefox.js +1 -1
- package/lib/server/frames.js +12 -4
- package/lib/server/har/harTracer.js +7 -8
- package/lib/server/network.js +12 -0
- package/lib/server/page.js +39 -17
- package/lib/server/recorder/chat.js +2 -2
- package/lib/server/recorder/recorderRunner.js +4 -0
- package/lib/server/registry/browserFetcher.js +3 -3
- package/lib/server/registry/index.js +27 -0
- package/lib/server/trace/recorder/snapshotter.js +13 -2
- package/lib/server/trace/recorder/snapshotterInjected.js +3 -1
- package/lib/server/utils/comparators.js +2 -2
- package/lib/server/utils/env.js +7 -2
- package/lib/server/utils/wsServer.js +2 -7
- package/lib/server/webkit/webkit.js +24 -8
- package/lib/server/webkit/wkBrowser.js +7 -3
- package/lib/server/webkit/wkPage.js +7 -8
- package/lib/server/webkit/wsl/webkit-wsl-transport-client.js +74 -0
- package/lib/server/webkit/wsl/webkit-wsl-transport-server.js +113 -0
- package/lib/utils/isomorphic/ariaSnapshot.js +12 -10
- package/lib/utils/isomorphic/protocolMetainfo.js +3 -0
- package/lib/utils/isomorphic/urlMatch.js +3 -8
- package/lib/utilsBundle.js +3 -0
- package/lib/utilsBundleImpl/index.js +80 -80
- package/lib/vite/htmlReport/index.html +37 -28
- package/lib/vite/recorder/assets/codeMirrorModule-RJCXzfmE.js +24 -0
- package/lib/vite/recorder/assets/index-Ri0uHF7I.css +1 -0
- package/lib/vite/recorder/assets/index-Y-X2TGJv.js +193 -0
- package/lib/vite/recorder/index.html +2 -2
- package/lib/vite/traceViewer/assets/codeMirrorModule-eyVcHN77.js +24 -0
- package/lib/vite/traceViewer/assets/defaultSettingsView-w0zYjHsW.js +265 -0
- package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
- package/lib/vite/traceViewer/defaultSettingsView.TQ8_7ybu.css +1 -0
- package/lib/vite/traceViewer/index.Bx16ehp1.js +2 -0
- package/lib/vite/traceViewer/index.I8N9v4jT.css +1 -0
- package/lib/vite/traceViewer/index.html +4 -4
- package/lib/vite/traceViewer/sw.bundle.js +3 -3
- package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
- package/lib/vite/traceViewer/uiMode.DRQ310U5.js +5 -0
- package/lib/vite/traceViewer/uiMode.html +4 -4
- package/lib/vite/traceViewer/{xtermModule.Beg8tuEN.css → xtermModule.DYP7pi_n.css} +1 -1
- package/package.json +9 -9
- package/lib/vite/recorder/assets/codeMirrorModule-DzQ0k89p.js +0 -24
- package/lib/vite/recorder/assets/index-CI4HQ-Zb.css +0 -1
- package/lib/vite/recorder/assets/index-D7C7daHH.js +0 -184
- package/lib/vite/traceViewer/assets/codeMirrorModule-CEFqZ5b3.js +0 -24
- package/lib/vite/traceViewer/assets/defaultSettingsView-BA25Usqk.js +0 -256
- package/lib/vite/traceViewer/assets/xtermModule-BoAIEibi.js +0 -9
- package/lib/vite/traceViewer/defaultSettingsView.DVJHpiGt.css +0 -1
- package/lib/vite/traceViewer/index.BFsek2M6.css +0 -1
- package/lib/vite/traceViewer/index.CheexZ4_.js +0 -2
- package/lib/vite/traceViewer/uiMode.BatfzHMG.css +0 -1
- package/lib/vite/traceViewer/uiMode.Dy4dnPNW.js +0 -5
|
@@ -39,7 +39,6 @@ var import_eventsHelper = require("../utils/eventsHelper");
|
|
|
39
39
|
var import_hostPlatform = require("../utils/hostPlatform");
|
|
40
40
|
var import_stackTrace = require("../../utils/isomorphic/stackTrace");
|
|
41
41
|
var import_utilsBundle = require("../../utilsBundle");
|
|
42
|
-
var import_browserContext = require("../browserContext");
|
|
43
42
|
var dialog = __toESM(require("../dialog"));
|
|
44
43
|
var dom = __toESM(require("../dom"));
|
|
45
44
|
var import_errors = require("../errors");
|
|
@@ -54,6 +53,7 @@ var import_wkInterceptableRequest = require("./wkInterceptableRequest");
|
|
|
54
53
|
var import_wkProvisionalPage = require("./wkProvisionalPage");
|
|
55
54
|
var import_wkWorkers = require("./wkWorkers");
|
|
56
55
|
var import_debugLogger = require("../utils/debugLogger");
|
|
56
|
+
var import_webkit = require("./webkit");
|
|
57
57
|
const UTILITY_WORLD_NAME = "__playwright_utility_world__";
|
|
58
58
|
class WKPage {
|
|
59
59
|
constructor(browserContext, pageProxySession, opener) {
|
|
@@ -289,6 +289,8 @@ class WKPage {
|
|
|
289
289
|
session.dispatchMessage({ id: message.id, error: { message: e.message } });
|
|
290
290
|
});
|
|
291
291
|
});
|
|
292
|
+
if (targetInfo.type === "frame")
|
|
293
|
+
return;
|
|
292
294
|
(0, import_utils.assert)(targetInfo.type === "page", "Only page targets are expected in WebKit, received: " + targetInfo.type);
|
|
293
295
|
if (!targetInfo.isProvisional) {
|
|
294
296
|
(0, import_utils.assert)(!this._page.initializedOrUndefined());
|
|
@@ -341,7 +343,6 @@ class WKPage {
|
|
|
341
343
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.frameDetached", (event) => this._onFrameDetached(event.frameId)),
|
|
342
344
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.willCheckNavigationPolicy", (event) => this._onWillCheckNavigationPolicy(event.frameId)),
|
|
343
345
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.didCheckNavigationPolicy", (event) => this._onDidCheckNavigationPolicy(event.frameId, event.cancel)),
|
|
344
|
-
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.frameScheduledNavigation", (event) => this._onFrameScheduledNavigation(event.frameId, event.delay, event.targetIsCurrentFrame)),
|
|
345
346
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.loadEventFired", (event) => this._page.frameManager.frameLifecycleEvent(event.frameId, "load")),
|
|
346
347
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Page.domContentEventFired", (event) => this._page.frameManager.frameLifecycleEvent(event.frameId, "domcontentloaded")),
|
|
347
348
|
import_eventsHelper.eventsHelper.addEventListener(this._session, "Runtime.executionContextCreated", (event) => this._onExecutionContextCreated(event.context)),
|
|
@@ -388,10 +389,6 @@ class WKPage {
|
|
|
388
389
|
return;
|
|
389
390
|
this._page.frameManager.frameAbortedNavigation(frameId, "Navigation canceled by policy check");
|
|
390
391
|
}
|
|
391
|
-
_onFrameScheduledNavigation(frameId, delay, targetIsCurrentFrame) {
|
|
392
|
-
if (targetIsCurrentFrame)
|
|
393
|
-
this._page.frameManager.frameRequestedNavigation(frameId);
|
|
394
|
-
}
|
|
395
392
|
_handleFrameTree(frameTree) {
|
|
396
393
|
this._onFrameAttached(frameTree.frame.id, frameTree.frame.parentId || null);
|
|
397
394
|
this._onFrameNavigated(frameTree.frame, true);
|
|
@@ -478,7 +475,7 @@ class WKPage {
|
|
|
478
475
|
const error = new Error(message);
|
|
479
476
|
error.stack = stack;
|
|
480
477
|
error.name = name;
|
|
481
|
-
this._page.
|
|
478
|
+
this._page.addPageError(error);
|
|
482
479
|
return;
|
|
483
480
|
}
|
|
484
481
|
let derivedType = type || "";
|
|
@@ -769,7 +766,7 @@ class WKPage {
|
|
|
769
766
|
async _startVideo(options) {
|
|
770
767
|
(0, import_utils.assert)(!this._recordingVideoFile);
|
|
771
768
|
const { screencastId } = await this._pageProxySession.send("Screencast.startVideo", {
|
|
772
|
-
file: options.outputFile,
|
|
769
|
+
file: this._browserContext._browser.options.channel === "webkit-wsl" ? await (0, import_webkit.translatePathToWSL)(options.outputFile) : options.outputFile,
|
|
773
770
|
width: options.width,
|
|
774
771
|
height: options.height,
|
|
775
772
|
toolbarHeight: this._toolbarHeight()
|
|
@@ -889,6 +886,8 @@ class WKPage {
|
|
|
889
886
|
async setInputFilePaths(handle, paths) {
|
|
890
887
|
const pageProxyId = this._pageProxySession.sessionId;
|
|
891
888
|
const objectId = handle._objectId;
|
|
889
|
+
if (this._browserContext._browser?.options.channel === "webkit-wsl")
|
|
890
|
+
paths = await Promise.all(paths.map((path2) => (0, import_webkit.translatePathToWSL)(path2)));
|
|
892
891
|
await Promise.all([
|
|
893
892
|
this._pageProxySession.connection.browserSession.send("Playwright.grantFileReadAccess", { pageProxyId, paths }),
|
|
894
893
|
this._session.send("DOM.setInputFiles", { objectId, paths })
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __copyProps = (to, from, except, desc) => {
|
|
9
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
+
for (let key of __getOwnPropNames(from))
|
|
11
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
+
}
|
|
14
|
+
return to;
|
|
15
|
+
};
|
|
16
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
+
mod
|
|
23
|
+
));
|
|
24
|
+
var import_net = __toESM(require("net"));
|
|
25
|
+
var import_fs = __toESM(require("fs"));
|
|
26
|
+
var import_child_process = require("child_process");
|
|
27
|
+
(async () => {
|
|
28
|
+
const { PW_WSL_BRIDGE_PORT: socketPort, ...childEnv } = process.env;
|
|
29
|
+
if (!socketPort)
|
|
30
|
+
throw new Error("PW_WSL_BRIDGE_PORT env var is not set");
|
|
31
|
+
const [executable, ...args] = process.argv.slice(2);
|
|
32
|
+
if (!(await import_fs.default.promises.stat(executable)).isFile())
|
|
33
|
+
throw new Error(`Executable does not exist. Did you update Playwright recently? Make sure to run npx playwright install webkit-wsl`);
|
|
34
|
+
const address = (() => {
|
|
35
|
+
const res = (0, import_child_process.spawnSync)("/usr/bin/wslinfo", ["--networking-mode"], { encoding: "utf8" });
|
|
36
|
+
if (res.error || res.status !== 0)
|
|
37
|
+
throw new Error(`Failed to run /usr/bin/wslinfo --networking-mode: ${res.error?.message || res.stderr || res.status}`);
|
|
38
|
+
if (res.stdout.trim() === "nat") {
|
|
39
|
+
const ipRes = (0, import_child_process.spawnSync)("/usr/sbin/ip", ["route", "show"], { encoding: "utf8" });
|
|
40
|
+
if (ipRes.error || ipRes.status !== 0)
|
|
41
|
+
throw new Error(`Failed to run ip route show: ${ipRes.error?.message || ipRes.stderr || ipRes.status}`);
|
|
42
|
+
const ip = ipRes.stdout.trim().split("\n").find((line) => line.includes("default"))?.split(" ")[2];
|
|
43
|
+
if (!ip)
|
|
44
|
+
throw new Error("Could not determine WSL IP address (NAT mode).");
|
|
45
|
+
return ip;
|
|
46
|
+
}
|
|
47
|
+
return "127.0.0.1";
|
|
48
|
+
})();
|
|
49
|
+
const socket = import_net.default.createConnection(parseInt(socketPort, 10), address);
|
|
50
|
+
socket.setNoDelay(true);
|
|
51
|
+
await new Promise((resolve, reject) => {
|
|
52
|
+
socket.on("connect", resolve);
|
|
53
|
+
socket.on("error", reject);
|
|
54
|
+
});
|
|
55
|
+
const child = (0, import_child_process.spawn)(executable, args, {
|
|
56
|
+
stdio: ["inherit", "inherit", "inherit", "pipe", "pipe"],
|
|
57
|
+
env: childEnv
|
|
58
|
+
});
|
|
59
|
+
const [childOutput, childInput] = [child.stdio[3], child.stdio[4]];
|
|
60
|
+
socket.pipe(childOutput);
|
|
61
|
+
childInput.pipe(socket);
|
|
62
|
+
socket.on("end", () => child.kill());
|
|
63
|
+
child.on("exit", (exitCode) => {
|
|
64
|
+
socket.end();
|
|
65
|
+
process.exit(exitCode || 0);
|
|
66
|
+
});
|
|
67
|
+
await new Promise((resolve, reject) => {
|
|
68
|
+
child.on("exit", resolve);
|
|
69
|
+
child.on("error", reject);
|
|
70
|
+
});
|
|
71
|
+
})().catch((error) => {
|
|
72
|
+
console.error("Error occurred:", error);
|
|
73
|
+
process.exit(1);
|
|
74
|
+
});
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __copyProps = (to, from, except, desc) => {
|
|
9
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
+
for (let key of __getOwnPropNames(from))
|
|
11
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
+
}
|
|
14
|
+
return to;
|
|
15
|
+
};
|
|
16
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
+
mod
|
|
23
|
+
));
|
|
24
|
+
var import_net = __toESM(require("net"));
|
|
25
|
+
var import_path = __toESM(require("path"));
|
|
26
|
+
var import_child_process = require("child_process");
|
|
27
|
+
(async () => {
|
|
28
|
+
const argv = process.argv.slice(2);
|
|
29
|
+
if (!argv.length) {
|
|
30
|
+
console.error(`Usage: node ${import_path.default.basename(__filename)} <executable> [args...]`);
|
|
31
|
+
process.exit(1);
|
|
32
|
+
}
|
|
33
|
+
const parentIn = new import_net.default.Socket({ fd: 3, readable: true, writable: false });
|
|
34
|
+
const parentOut = new import_net.default.Socket({ fd: 4, readable: false, writable: true });
|
|
35
|
+
const server = import_net.default.createServer();
|
|
36
|
+
let socket = null;
|
|
37
|
+
server.on("connection", (s) => {
|
|
38
|
+
if (socket) {
|
|
39
|
+
log("Extra connection received, destroying.");
|
|
40
|
+
socket.destroy();
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
socket = s;
|
|
44
|
+
socket.setNoDelay(true);
|
|
45
|
+
log("Client connected, wiring pipes.");
|
|
46
|
+
socket.pipe(parentOut);
|
|
47
|
+
parentIn.pipe(socket);
|
|
48
|
+
socket.on("close", () => {
|
|
49
|
+
log("Socket closed");
|
|
50
|
+
socket = null;
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
await new Promise((resolve, reject) => {
|
|
54
|
+
server.once("error", reject);
|
|
55
|
+
server.listen(0, () => resolve(null));
|
|
56
|
+
});
|
|
57
|
+
const address = server.address();
|
|
58
|
+
if (!address || typeof address === "string") {
|
|
59
|
+
console.error("Failed to obtain listening address");
|
|
60
|
+
process.exit(1);
|
|
61
|
+
}
|
|
62
|
+
const port = address.port;
|
|
63
|
+
log("Server listening on", port);
|
|
64
|
+
const env = {
|
|
65
|
+
...process.env,
|
|
66
|
+
// WSLENV is a colon-delimited list of environment variables that should be included when launching WSL processes from Win32 or Win32 processes from WSL
|
|
67
|
+
WSLENV: "PW_WSL_BRIDGE_PORT",
|
|
68
|
+
PW_WSL_BRIDGE_PORT: String(port)
|
|
69
|
+
};
|
|
70
|
+
let shuttingDown = false;
|
|
71
|
+
const child = (0, import_child_process.spawn)("wsl.exe", [
|
|
72
|
+
"-d",
|
|
73
|
+
"playwright",
|
|
74
|
+
"--cd",
|
|
75
|
+
"/home/pwuser",
|
|
76
|
+
"/home/pwuser/node/bin/node",
|
|
77
|
+
"/home/pwuser/webkit-wsl-transport-client.js",
|
|
78
|
+
process.env.WEBKIT_EXECUTABLE || "",
|
|
79
|
+
...argv
|
|
80
|
+
], {
|
|
81
|
+
env,
|
|
82
|
+
stdio: ["inherit", "inherit", "inherit"]
|
|
83
|
+
// no fd3/fd4 here; they stay only in this wrapper
|
|
84
|
+
});
|
|
85
|
+
log("Spawned child pid", child.pid);
|
|
86
|
+
child.on("close", (code, signal) => {
|
|
87
|
+
log("Child exit", { code, signal });
|
|
88
|
+
const exitCode = code ?? (signal ? 128 : 0);
|
|
89
|
+
shutdown(exitCode);
|
|
90
|
+
});
|
|
91
|
+
child.on("error", (err) => {
|
|
92
|
+
console.error("Child process failed to start:", err);
|
|
93
|
+
shutdown(1);
|
|
94
|
+
});
|
|
95
|
+
await new Promise((resolve) => child.once("close", resolve));
|
|
96
|
+
async function shutdown(code = 0) {
|
|
97
|
+
if (shuttingDown)
|
|
98
|
+
return;
|
|
99
|
+
shuttingDown = true;
|
|
100
|
+
server.close();
|
|
101
|
+
parentIn.destroy();
|
|
102
|
+
parentOut.destroy();
|
|
103
|
+
socket?.destroy();
|
|
104
|
+
await new Promise((resolve) => server.once("close", resolve));
|
|
105
|
+
process.exit(code);
|
|
106
|
+
}
|
|
107
|
+
function log(...args) {
|
|
108
|
+
console.error(/* @__PURE__ */ new Date(), `[${import_path.default.basename(__filename)}]`, ...args);
|
|
109
|
+
}
|
|
110
|
+
})().catch((error) => {
|
|
111
|
+
console.error("Error occurred:", error);
|
|
112
|
+
process.exit(1);
|
|
113
|
+
});
|
|
@@ -22,7 +22,7 @@ __export(ariaSnapshot_exports, {
|
|
|
22
22
|
ParserError: () => ParserError,
|
|
23
23
|
parseAriaSnapshot: () => parseAriaSnapshot,
|
|
24
24
|
parseAriaSnapshotUnsafe: () => parseAriaSnapshotUnsafe,
|
|
25
|
-
|
|
25
|
+
textValue: () => textValue
|
|
26
26
|
});
|
|
27
27
|
module.exports = __toCommonJS(ariaSnapshot_exports);
|
|
28
28
|
function parseAriaSnapshotUnsafe(yaml, text, options = {}) {
|
|
@@ -95,7 +95,7 @@ function parseAriaSnapshot(yaml, text, options = {}) {
|
|
|
95
95
|
}
|
|
96
96
|
container.children.push({
|
|
97
97
|
kind: "text",
|
|
98
|
-
text:
|
|
98
|
+
text: textValue(value.value)
|
|
99
99
|
});
|
|
100
100
|
continue;
|
|
101
101
|
}
|
|
@@ -121,7 +121,7 @@ function parseAriaSnapshot(yaml, text, options = {}) {
|
|
|
121
121
|
continue;
|
|
122
122
|
}
|
|
123
123
|
container.props = container.props ?? {};
|
|
124
|
-
container.props[key.value.slice(1)] =
|
|
124
|
+
container.props[key.value.slice(1)] = textValue(value.value);
|
|
125
125
|
continue;
|
|
126
126
|
}
|
|
127
127
|
const childNode = KeyParser.parse(key, parseOptions, errors);
|
|
@@ -141,7 +141,7 @@ function parseAriaSnapshot(yaml, text, options = {}) {
|
|
|
141
141
|
...childNode,
|
|
142
142
|
children: [{
|
|
143
143
|
kind: "text",
|
|
144
|
-
text:
|
|
144
|
+
text: textValue(String(value.value))
|
|
145
145
|
}]
|
|
146
146
|
});
|
|
147
147
|
continue;
|
|
@@ -181,13 +181,16 @@ const emptyFragment = { kind: "role", role: "fragment" };
|
|
|
181
181
|
function normalizeWhitespace(text) {
|
|
182
182
|
return text.replace(/[\u200b\u00ad]/g, "").replace(/[\r\n\s\t]+/g, " ").trim();
|
|
183
183
|
}
|
|
184
|
-
function
|
|
185
|
-
return
|
|
184
|
+
function textValue(value) {
|
|
185
|
+
return {
|
|
186
|
+
raw: value,
|
|
187
|
+
normalized: normalizeWhitespace(value)
|
|
188
|
+
};
|
|
186
189
|
}
|
|
187
190
|
class KeyParser {
|
|
188
191
|
static parse(text, options, errors) {
|
|
189
192
|
try {
|
|
190
|
-
return new KeyParser(text.value
|
|
193
|
+
return new KeyParser(text.value)._parse();
|
|
191
194
|
} catch (e) {
|
|
192
195
|
if (e instanceof ParserError) {
|
|
193
196
|
const message = options.prettyErrors === false ? e.message : e.message + ":\n\n" + text.value + "\n" + " ".repeat(e.pos) + "^\n";
|
|
@@ -200,11 +203,10 @@ class KeyParser {
|
|
|
200
203
|
throw e;
|
|
201
204
|
}
|
|
202
205
|
}
|
|
203
|
-
constructor(input
|
|
206
|
+
constructor(input) {
|
|
204
207
|
this._input = input;
|
|
205
208
|
this._pos = 0;
|
|
206
209
|
this._length = input.length;
|
|
207
|
-
this._options = options;
|
|
208
210
|
}
|
|
209
211
|
_peek() {
|
|
210
212
|
return this._input[this._pos] || "";
|
|
@@ -386,5 +388,5 @@ class ParserError extends Error {
|
|
|
386
388
|
ParserError,
|
|
387
389
|
parseAriaSnapshot,
|
|
388
390
|
parseAriaSnapshotUnsafe,
|
|
389
|
-
|
|
391
|
+
textValue
|
|
390
392
|
});
|
|
@@ -105,6 +105,7 @@ const methodMetainfo = /* @__PURE__ */ new Map([
|
|
|
105
105
|
["BrowserContext.clockSetSystemTime", { title: 'Set system time "{timeNumber|timeString}"' }],
|
|
106
106
|
["Page.addInitScript", { title: "Add init script", group: "configuration" }],
|
|
107
107
|
["Page.close", { title: "Close page", pausesBeforeAction: true }],
|
|
108
|
+
["Page.consoleMessages", { title: "Get console messages", group: "getter" }],
|
|
108
109
|
["Page.emulateMedia", { title: "Emulate media", snapshot: true, pausesBeforeAction: true }],
|
|
109
110
|
["Page.exposeBinding", { title: "Expose binding", group: "configuration" }],
|
|
110
111
|
["Page.goBack", { title: "Go back", slowMo: true, snapshot: true, pausesBeforeAction: true }],
|
|
@@ -132,7 +133,9 @@ const methodMetainfo = /* @__PURE__ */ new Map([
|
|
|
132
133
|
["Page.mouseWheel", { title: "Mouse wheel", slowMo: true, snapshot: true, pausesBeforeAction: true }],
|
|
133
134
|
["Page.touchscreenTap", { title: "Tap", slowMo: true, snapshot: true, pausesBeforeAction: true }],
|
|
134
135
|
["Page.accessibilitySnapshot", { title: "Accessibility snapshot", group: "getter" }],
|
|
136
|
+
["Page.pageErrors", { title: "Get page errors", group: "getter" }],
|
|
135
137
|
["Page.pdf", { title: "PDF" }],
|
|
138
|
+
["Page.requests", { title: "Get network requests", group: "getter" }],
|
|
136
139
|
["Page.snapshotForAI", { internal: true }],
|
|
137
140
|
["Page.startJSCoverage", { title: "Start JS coverage", group: "configuration" }],
|
|
138
141
|
["Page.stopJSCoverage", { title: "Stop JS coverage", group: "configuration" }],
|
|
@@ -38,20 +38,15 @@ function globToRegexPattern(glob) {
|
|
|
38
38
|
continue;
|
|
39
39
|
}
|
|
40
40
|
if (c === "*") {
|
|
41
|
-
const beforeDeep = glob[i - 1];
|
|
42
41
|
let starCount = 1;
|
|
43
42
|
while (glob[i + 1] === "*") {
|
|
44
43
|
starCount++;
|
|
45
44
|
i++;
|
|
46
45
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
tokens.push("((?:[^/]*(?:/|$))*)");
|
|
51
|
-
i++;
|
|
52
|
-
} else {
|
|
46
|
+
if (starCount > 1)
|
|
47
|
+
tokens.push("(.*)");
|
|
48
|
+
else
|
|
53
49
|
tokens.push("([^/]*)");
|
|
54
|
-
}
|
|
55
50
|
continue;
|
|
56
51
|
}
|
|
57
52
|
switch (c) {
|
package/lib/utilsBundle.js
CHANGED
|
@@ -20,6 +20,7 @@ var utilsBundle_exports = {};
|
|
|
20
20
|
__export(utilsBundle_exports, {
|
|
21
21
|
HttpsProxyAgent: () => HttpsProxyAgent,
|
|
22
22
|
PNG: () => PNG,
|
|
23
|
+
ProgramOption: () => ProgramOption,
|
|
23
24
|
SocksProxyAgent: () => SocksProxyAgent,
|
|
24
25
|
colors: () => colors,
|
|
25
26
|
debug: () => debug,
|
|
@@ -54,6 +55,7 @@ const minimatch = require("./utilsBundleImpl").minimatch;
|
|
|
54
55
|
const open = require("./utilsBundleImpl").open;
|
|
55
56
|
const PNG = require("./utilsBundleImpl").PNG;
|
|
56
57
|
const program = require("./utilsBundleImpl").program;
|
|
58
|
+
const ProgramOption = require("./utilsBundleImpl").ProgramOption;
|
|
57
59
|
const progress = require("./utilsBundleImpl").progress;
|
|
58
60
|
const SocksProxyAgent = require("./utilsBundleImpl").SocksProxyAgent;
|
|
59
61
|
const yaml = require("./utilsBundleImpl").yaml;
|
|
@@ -84,6 +86,7 @@ function ms(ms2) {
|
|
|
84
86
|
0 && (module.exports = {
|
|
85
87
|
HttpsProxyAgent,
|
|
86
88
|
PNG,
|
|
89
|
+
ProgramOption,
|
|
87
90
|
SocksProxyAgent,
|
|
88
91
|
colors,
|
|
89
92
|
debug,
|