brave-real-playwright-core 1.55.1 → 1.56.1

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.
Files changed (94) hide show
  1. package/README.md +5 -5
  2. package/advanced-stealth.js +1 -1
  3. package/lib/browserServerImpl.js +3 -6
  4. package/lib/client/browser.js +0 -10
  5. package/lib/client/browserContext.js +2 -8
  6. package/lib/client/channelOwner.js +0 -7
  7. package/lib/client/consoleMessage.js +2 -3
  8. package/lib/client/electron.js +1 -1
  9. package/lib/client/events.js +1 -0
  10. package/lib/client/network.js +3 -0
  11. package/lib/client/page.js +13 -1
  12. package/lib/generated/bindingsControllerSource.js +1 -1
  13. package/lib/generated/injectedScriptSource.js +1 -1
  14. package/lib/generated/pollingRecorderSource.js +1 -1
  15. package/lib/generated/utilityScriptSource.js +1 -1
  16. package/lib/protocol/validator.js +26 -15
  17. package/lib/remote/playwrightServer.js +12 -14
  18. package/lib/server/bidi/bidiBrowser.js +54 -10
  19. package/lib/server/bidi/bidiChromium.js +1 -1
  20. package/lib/server/bidi/bidiConnection.js +31 -6
  21. package/lib/server/bidi/bidiExecutionContext.js +4 -4
  22. package/lib/server/bidi/bidiFirefox.js +16 -1
  23. package/lib/server/bidi/bidiNetworkManager.js +82 -16
  24. package/lib/server/bidi/bidiPage.js +84 -18
  25. package/lib/server/browserType.js +3 -3
  26. package/lib/server/chromium/chromium.js +1 -1
  27. package/lib/server/chromium/chromiumSwitches.js +3 -1
  28. package/lib/server/chromium/crBrowser.js +4 -34
  29. package/lib/server/chromium/crPage.js +22 -31
  30. package/lib/server/codegen/csharp.js +19 -26
  31. package/lib/server/codegen/java.js +4 -0
  32. package/lib/server/codegen/javascript.js +3 -1
  33. package/lib/server/codegen/python.js +2 -0
  34. package/lib/server/debugController.js +8 -36
  35. package/lib/server/deviceDescriptorsSource.json +62 -62
  36. package/lib/server/dispatchers/androidDispatcher.js +17 -0
  37. package/lib/server/dispatchers/browserContextDispatcher.js +1 -15
  38. package/lib/server/dispatchers/networkDispatchers.js +6 -3
  39. package/lib/server/dispatchers/pageDispatcher.js +24 -0
  40. package/lib/server/dom.js +8 -3
  41. package/lib/server/firefox/ffPage.js +1 -2
  42. package/lib/server/firefox/firefox.js +1 -1
  43. package/lib/server/frames.js +12 -4
  44. package/lib/server/har/harTracer.js +7 -8
  45. package/lib/server/network.js +12 -0
  46. package/lib/server/page.js +39 -17
  47. package/lib/server/recorder/chat.js +2 -2
  48. package/lib/server/recorder/recorderRunner.js +4 -0
  49. package/lib/server/registry/browserFetcher.js +3 -3
  50. package/lib/server/registry/index.js +27 -0
  51. package/lib/server/trace/recorder/snapshotter.js +13 -2
  52. package/lib/server/trace/recorder/snapshotterInjected.js +3 -1
  53. package/lib/server/utils/comparators.js +2 -2
  54. package/lib/server/utils/env.js +7 -2
  55. package/lib/server/utils/wsServer.js +2 -7
  56. package/lib/server/webkit/webkit.js +24 -8
  57. package/lib/server/webkit/wkBrowser.js +7 -3
  58. package/lib/server/webkit/wkPage.js +7 -8
  59. package/lib/server/webkit/wsl/webkit-wsl-transport-client.js +74 -0
  60. package/lib/server/webkit/wsl/webkit-wsl-transport-server.js +113 -0
  61. package/lib/utils/isomorphic/ariaSnapshot.js +12 -10
  62. package/lib/utils/isomorphic/protocolMetainfo.js +3 -0
  63. package/lib/utils/isomorphic/urlMatch.js +3 -8
  64. package/lib/utilsBundle.js +3 -0
  65. package/lib/utilsBundleImpl/index.js +80 -80
  66. package/lib/vite/htmlReport/index.html +37 -28
  67. package/lib/vite/recorder/assets/codeMirrorModule-RJCXzfmE.js +24 -0
  68. package/lib/vite/recorder/assets/index-Ri0uHF7I.css +1 -0
  69. package/lib/vite/recorder/assets/index-Y-X2TGJv.js +193 -0
  70. package/lib/vite/recorder/index.html +2 -2
  71. package/lib/vite/traceViewer/assets/codeMirrorModule-eyVcHN77.js +24 -0
  72. package/lib/vite/traceViewer/assets/defaultSettingsView-w0zYjHsW.js +265 -0
  73. package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
  74. package/lib/vite/traceViewer/defaultSettingsView.TQ8_7ybu.css +1 -0
  75. package/lib/vite/traceViewer/index.Bx16ehp1.js +2 -0
  76. package/lib/vite/traceViewer/index.I8N9v4jT.css +1 -0
  77. package/lib/vite/traceViewer/index.html +4 -4
  78. package/lib/vite/traceViewer/sw.bundle.js +3 -3
  79. package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
  80. package/lib/vite/traceViewer/uiMode.DRQ310U5.js +5 -0
  81. package/lib/vite/traceViewer/uiMode.html +4 -4
  82. package/lib/vite/traceViewer/{xtermModule.Beg8tuEN.css → xtermModule.DYP7pi_n.css} +1 -1
  83. package/package.json +9 -9
  84. package/lib/vite/recorder/assets/codeMirrorModule-DzQ0k89p.js +0 -24
  85. package/lib/vite/recorder/assets/index-CI4HQ-Zb.css +0 -1
  86. package/lib/vite/recorder/assets/index-D7C7daHH.js +0 -184
  87. package/lib/vite/traceViewer/assets/codeMirrorModule-CEFqZ5b3.js +0 -24
  88. package/lib/vite/traceViewer/assets/defaultSettingsView-BA25Usqk.js +0 -256
  89. package/lib/vite/traceViewer/assets/xtermModule-BoAIEibi.js +0 -9
  90. package/lib/vite/traceViewer/defaultSettingsView.DVJHpiGt.css +0 -1
  91. package/lib/vite/traceViewer/index.BFsek2M6.css +0 -1
  92. package/lib/vite/traceViewer/index.CheexZ4_.js +0 -2
  93. package/lib/vite/traceViewer/uiMode.BatfzHMG.css +0 -1
  94. 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.emitOnContextOnceInitialized(import_browserContext.BrowserContext.Events.PageError, error, 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
- valueOrRegex: () => valueOrRegex
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: valueOrRegex(value.value)
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)] = valueOrRegex(value.value);
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: valueOrRegex(String(value.value))
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 valueOrRegex(value) {
185
- return value.startsWith("/") && value.endsWith("/") && value.length > 1 ? { pattern: value.slice(1, -1) } : normalizeWhitespace(value);
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, options)._parse();
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, options) {
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
- valueOrRegex
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
- const afterDeep = glob[i + 1];
48
- const isDeep = starCount > 1 && (beforeDeep === "/" || beforeDeep === void 0) && (afterDeep === "/" || afterDeep === void 0);
49
- if (isDeep) {
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) {
@@ -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,