patchright-bun 1.58.1 → 1.58.2
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 +225 -225
- package/ThirdPartyNotices.txt +5041 -5041
- package/cli.js +19 -19
- package/index.d.ts +17 -17
- package/index.js +17 -17
- package/index.mjs +18 -18
- package/jsx-runtime.js +42 -42
- package/jsx-runtime.mjs +21 -21
- package/lib/agents/agentParser.js +89 -89
- package/lib/agents/copilot-setup-steps.yml +34 -34
- package/lib/agents/generateAgents.js +348 -348
- package/lib/agents/playwright-test-coverage.prompt.md +31 -31
- package/lib/agents/playwright-test-generate.prompt.md +8 -8
- package/lib/agents/playwright-test-generator.agent.md +88 -88
- package/lib/agents/playwright-test-heal.prompt.md +6 -6
- package/lib/agents/playwright-test-healer.agent.md +55 -55
- package/lib/agents/playwright-test-plan.prompt.md +9 -9
- package/lib/agents/playwright-test-planner.agent.md +73 -73
- package/lib/common/config.js +282 -282
- package/lib/common/configLoader.js +344 -344
- package/lib/common/esmLoaderHost.js +104 -104
- package/lib/common/expectBundle.js +28 -28
- package/lib/common/expectBundleImpl.js +407 -407
- package/lib/common/fixtures.js +302 -302
- package/lib/common/globals.js +58 -58
- package/lib/common/ipc.js +60 -60
- package/lib/common/poolBuilder.js +85 -85
- package/lib/common/process.js +132 -132
- package/lib/common/suiteUtils.js +140 -140
- package/lib/common/test.js +321 -321
- package/lib/common/testLoader.js +101 -101
- package/lib/common/testType.js +298 -298
- package/lib/common/validators.js +68 -68
- package/lib/fsWatcher.js +67 -67
- package/lib/index.js +726 -726
- package/lib/internalsForTest.js +42 -42
- package/lib/isomorphic/events.js +77 -77
- package/lib/isomorphic/folders.js +30 -30
- package/lib/isomorphic/stringInternPool.js +69 -69
- package/lib/isomorphic/teleReceiver.js +521 -521
- package/lib/isomorphic/teleSuiteUpdater.js +157 -157
- package/lib/isomorphic/testServerConnection.js +225 -225
- package/lib/isomorphic/testServerInterface.js +16 -16
- package/lib/isomorphic/testTree.js +329 -329
- package/lib/isomorphic/types.d.js +16 -16
- package/lib/loader/loaderMain.js +59 -59
- package/lib/matchers/expect.js +311 -311
- package/lib/matchers/matcherHint.js +44 -44
- package/lib/matchers/matchers.js +383 -383
- package/lib/matchers/toBeTruthy.js +75 -75
- package/lib/matchers/toEqual.js +100 -100
- package/lib/matchers/toHaveURL.js +101 -101
- package/lib/matchers/toMatchAriaSnapshot.js +159 -159
- package/lib/matchers/toMatchSnapshot.js +342 -342
- package/lib/matchers/toMatchText.js +99 -99
- package/lib/mcp/browser/browserContextFactory.js +329 -329
- package/lib/mcp/browser/browserServerBackend.js +84 -84
- package/lib/mcp/browser/config.js +421 -421
- package/lib/mcp/browser/context.js +244 -244
- package/lib/mcp/browser/response.js +278 -278
- package/lib/mcp/browser/sessionLog.js +75 -75
- package/lib/mcp/browser/tab.js +343 -343
- package/lib/mcp/browser/tools/common.js +65 -65
- package/lib/mcp/browser/tools/console.js +46 -46
- package/lib/mcp/browser/tools/dialogs.js +60 -60
- package/lib/mcp/browser/tools/evaluate.js +61 -61
- package/lib/mcp/browser/tools/files.js +58 -58
- package/lib/mcp/browser/tools/form.js +63 -63
- package/lib/mcp/browser/tools/install.js +72 -72
- package/lib/mcp/browser/tools/keyboard.js +107 -107
- package/lib/mcp/browser/tools/mouse.js +107 -107
- package/lib/mcp/browser/tools/navigate.js +71 -71
- package/lib/mcp/browser/tools/network.js +63 -63
- package/lib/mcp/browser/tools/open.js +57 -57
- package/lib/mcp/browser/tools/pdf.js +49 -49
- package/lib/mcp/browser/tools/runCode.js +78 -78
- package/lib/mcp/browser/tools/screenshot.js +93 -93
- package/lib/mcp/browser/tools/snapshot.js +173 -173
- package/lib/mcp/browser/tools/tabs.js +67 -67
- package/lib/mcp/browser/tools/tool.js +47 -47
- package/lib/mcp/browser/tools/tracing.js +74 -74
- package/lib/mcp/browser/tools/utils.js +94 -94
- package/lib/mcp/browser/tools/verify.js +143 -143
- package/lib/mcp/browser/tools/wait.js +63 -63
- package/lib/mcp/browser/tools.js +84 -84
- package/lib/mcp/browser/watchdog.js +44 -44
- package/lib/mcp/config.d.js +16 -16
- package/lib/mcp/extension/cdpRelay.js +351 -351
- package/lib/mcp/extension/extensionContextFactory.js +76 -76
- package/lib/mcp/extension/protocol.js +28 -28
- package/lib/mcp/index.js +61 -61
- package/lib/mcp/log.js +35 -35
- package/lib/mcp/program.js +111 -111
- package/lib/mcp/sdk/exports.js +28 -28
- package/lib/mcp/sdk/http.js +152 -152
- package/lib/mcp/sdk/inProcessTransport.js +71 -71
- package/lib/mcp/sdk/server.js +223 -223
- package/lib/mcp/sdk/tool.js +47 -47
- package/lib/mcp/terminal/cli.js +296 -296
- package/lib/mcp/terminal/command.js +56 -56
- package/lib/mcp/terminal/commands.js +333 -333
- package/lib/mcp/terminal/daemon.js +129 -129
- package/lib/mcp/terminal/help.json +31 -31
- package/lib/mcp/terminal/helpGenerator.js +88 -88
- package/lib/mcp/terminal/socketConnection.js +80 -80
- package/lib/mcp/test/browserBackend.js +98 -98
- package/lib/mcp/test/generatorTools.js +122 -122
- package/lib/mcp/test/plannerTools.js +145 -145
- package/lib/mcp/test/seed.js +82 -82
- package/lib/mcp/test/streams.js +44 -44
- package/lib/mcp/test/testBackend.js +99 -99
- package/lib/mcp/test/testContext.js +285 -285
- package/lib/mcp/test/testTool.js +30 -30
- package/lib/mcp/test/testTools.js +108 -108
- package/lib/plugins/gitCommitInfoPlugin.js +198 -198
- package/lib/plugins/index.js +28 -28
- package/lib/plugins/webServerPlugin.js +237 -237
- package/lib/program.js +417 -417
- package/lib/reporters/base.js +634 -634
- package/lib/reporters/blob.js +138 -138
- package/lib/reporters/dot.js +99 -99
- package/lib/reporters/empty.js +32 -32
- package/lib/reporters/github.js +128 -128
- package/lib/reporters/html.js +633 -633
- package/lib/reporters/internalReporter.js +138 -138
- package/lib/reporters/json.js +254 -254
- package/lib/reporters/junit.js +232 -232
- package/lib/reporters/line.js +131 -131
- package/lib/reporters/list.js +253 -253
- package/lib/reporters/listModeReporter.js +69 -69
- package/lib/reporters/markdown.js +144 -144
- package/lib/reporters/merge.js +558 -558
- package/lib/reporters/multiplexer.js +112 -112
- package/lib/reporters/reporterV2.js +102 -102
- package/lib/reporters/teleEmitter.js +317 -317
- package/lib/reporters/versions/blobV1.js +16 -16
- package/lib/runner/dispatcher.js +530 -530
- package/lib/runner/failureTracker.js +72 -72
- package/lib/runner/lastRun.js +77 -77
- package/lib/runner/loadUtils.js +334 -334
- package/lib/runner/loaderHost.js +89 -89
- package/lib/runner/processHost.js +180 -180
- package/lib/runner/projectUtils.js +241 -241
- package/lib/runner/rebase.js +189 -189
- package/lib/runner/reporters.js +138 -138
- package/lib/runner/sigIntWatcher.js +96 -96
- package/lib/runner/storage.js +91 -91
- package/lib/runner/taskRunner.js +127 -127
- package/lib/runner/tasks.js +410 -410
- package/lib/runner/testGroups.js +125 -125
- package/lib/runner/testRunner.js +398 -398
- package/lib/runner/testServer.js +269 -269
- package/lib/runner/uiModeReporter.js +30 -30
- package/lib/runner/vcs.js +72 -72
- package/lib/runner/watchMode.js +396 -396
- package/lib/runner/workerHost.js +104 -104
- package/lib/third_party/pirates.js +62 -62
- package/lib/third_party/tsconfig-loader.js +103 -103
- package/lib/transform/babelBundle.js +46 -46
- package/lib/transform/babelBundleImpl.js +461 -461
- package/lib/transform/compilationCache.js +274 -274
- package/lib/transform/esmLoader.js +103 -103
- package/lib/transform/md.js +221 -221
- package/lib/transform/portTransport.js +67 -67
- package/lib/transform/transform.js +303 -303
- package/lib/util.js +400 -400
- package/lib/utilsBundle.js +50 -50
- package/lib/utilsBundleImpl.js +103 -103
- package/lib/worker/fixtureRunner.js +262 -262
- package/lib/worker/testInfo.js +536 -536
- package/lib/worker/testTracing.js +345 -345
- package/lib/worker/timeoutManager.js +174 -174
- package/lib/worker/util.js +31 -31
- package/lib/worker/workerMain.js +530 -530
- package/package.json +2 -2
- package/test.d.ts +18 -18
- package/test.js +24 -24
- package/test.mjs +34 -34
- package/types/test.d.ts +10251 -10251
- package/types/testReporter.d.ts +822 -822
package/lib/common/process.js
CHANGED
|
@@ -1,132 +1,132 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var process_exports = {};
|
|
20
|
-
__export(process_exports, {
|
|
21
|
-
ProcessRunner: () => ProcessRunner
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(process_exports);
|
|
24
|
-
var import_utils = require("patchright-core/lib/utils");
|
|
25
|
-
var import_util = require("../util");
|
|
26
|
-
class ProcessRunner {
|
|
27
|
-
async gracefullyClose() {
|
|
28
|
-
}
|
|
29
|
-
dispatchEvent(method, params) {
|
|
30
|
-
const response = { method, params };
|
|
31
|
-
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
32
|
-
}
|
|
33
|
-
async sendRequest(method, params) {
|
|
34
|
-
return await sendRequestToParent(method, params);
|
|
35
|
-
}
|
|
36
|
-
async sendMessageNoReply(method, params) {
|
|
37
|
-
void sendRequestToParent(method, params).catch(() => {
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
let gracefullyCloseCalled = false;
|
|
42
|
-
let forceExitInitiated = false;
|
|
43
|
-
sendMessageToParent({ method: "ready" });
|
|
44
|
-
process.on("disconnect", () => gracefullyCloseAndExit(true));
|
|
45
|
-
process.on("SIGINT", () => {
|
|
46
|
-
});
|
|
47
|
-
process.on("SIGTERM", () => {
|
|
48
|
-
});
|
|
49
|
-
let processRunner;
|
|
50
|
-
let processName;
|
|
51
|
-
const startingEnv = { ...process.env };
|
|
52
|
-
process.on("message", async (message) => {
|
|
53
|
-
if (message.method === "__init__") {
|
|
54
|
-
const { processParams, runnerParams, runnerScript } = message.params;
|
|
55
|
-
void (0, import_utils.startProfiling)();
|
|
56
|
-
(0, import_utils.setTimeOrigin)(processParams.timeOrigin);
|
|
57
|
-
const { create } = require(runnerScript);
|
|
58
|
-
processRunner = create(runnerParams);
|
|
59
|
-
processName = processParams.processName;
|
|
60
|
-
return;
|
|
61
|
-
}
|
|
62
|
-
if (message.method === "__stop__") {
|
|
63
|
-
const keys = /* @__PURE__ */ new Set([...Object.keys(process.env), ...Object.keys(startingEnv)]);
|
|
64
|
-
const producedEnv = [...keys].filter((key) => startingEnv[key] !== process.env[key]).map((key) => [key, process.env[key] ?? null]);
|
|
65
|
-
sendMessageToParent({ method: "__env_produced__", params: producedEnv });
|
|
66
|
-
await gracefullyCloseAndExit(false);
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
if (message.method === "__dispatch__") {
|
|
70
|
-
const { id, method, params } = message.params;
|
|
71
|
-
try {
|
|
72
|
-
const result = await processRunner[method](params);
|
|
73
|
-
const response = { id, result };
|
|
74
|
-
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
75
|
-
} catch (e) {
|
|
76
|
-
const response = { id, error: (0, import_util.serializeError)(e) };
|
|
77
|
-
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
if (message.method === "__response__")
|
|
81
|
-
handleResponseFromParent(message.params);
|
|
82
|
-
});
|
|
83
|
-
const kForceExitTimeout = +(process.env.PWTEST_FORCE_EXIT_TIMEOUT || 3e4);
|
|
84
|
-
async function gracefullyCloseAndExit(forceExit) {
|
|
85
|
-
if (forceExit && !forceExitInitiated) {
|
|
86
|
-
forceExitInitiated = true;
|
|
87
|
-
setTimeout(() => process.exit(0), kForceExitTimeout);
|
|
88
|
-
}
|
|
89
|
-
if (!gracefullyCloseCalled) {
|
|
90
|
-
gracefullyCloseCalled = true;
|
|
91
|
-
await processRunner?.gracefullyClose().catch(() => {
|
|
92
|
-
});
|
|
93
|
-
if (processName)
|
|
94
|
-
await (0, import_utils.stopProfiling)(processName).catch(() => {
|
|
95
|
-
});
|
|
96
|
-
process.exit(0);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
function sendMessageToParent(message) {
|
|
100
|
-
try {
|
|
101
|
-
process.send(message);
|
|
102
|
-
} catch (e) {
|
|
103
|
-
try {
|
|
104
|
-
JSON.stringify(message);
|
|
105
|
-
} catch {
|
|
106
|
-
throw e;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
let lastId = 0;
|
|
111
|
-
const requestCallbacks = /* @__PURE__ */ new Map();
|
|
112
|
-
async function sendRequestToParent(method, params) {
|
|
113
|
-
const id = ++lastId;
|
|
114
|
-
sendMessageToParent({ method: "__request__", params: { id, method, params } });
|
|
115
|
-
const promise = new import_utils.ManualPromise();
|
|
116
|
-
requestCallbacks.set(id, promise);
|
|
117
|
-
return promise;
|
|
118
|
-
}
|
|
119
|
-
function handleResponseFromParent(response) {
|
|
120
|
-
const promise = requestCallbacks.get(response.id);
|
|
121
|
-
if (!promise)
|
|
122
|
-
return;
|
|
123
|
-
requestCallbacks.delete(response.id);
|
|
124
|
-
if (response.error)
|
|
125
|
-
promise.reject(new Error(response.error.message));
|
|
126
|
-
else
|
|
127
|
-
promise.resolve(response.result);
|
|
128
|
-
}
|
|
129
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
130
|
-
0 && (module.exports = {
|
|
131
|
-
ProcessRunner
|
|
132
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var process_exports = {};
|
|
20
|
+
__export(process_exports, {
|
|
21
|
+
ProcessRunner: () => ProcessRunner
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(process_exports);
|
|
24
|
+
var import_utils = require("patchright-bun-core/lib/utils");
|
|
25
|
+
var import_util = require("../util");
|
|
26
|
+
class ProcessRunner {
|
|
27
|
+
async gracefullyClose() {
|
|
28
|
+
}
|
|
29
|
+
dispatchEvent(method, params) {
|
|
30
|
+
const response = { method, params };
|
|
31
|
+
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
32
|
+
}
|
|
33
|
+
async sendRequest(method, params) {
|
|
34
|
+
return await sendRequestToParent(method, params);
|
|
35
|
+
}
|
|
36
|
+
async sendMessageNoReply(method, params) {
|
|
37
|
+
void sendRequestToParent(method, params).catch(() => {
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
let gracefullyCloseCalled = false;
|
|
42
|
+
let forceExitInitiated = false;
|
|
43
|
+
sendMessageToParent({ method: "ready" });
|
|
44
|
+
process.on("disconnect", () => gracefullyCloseAndExit(true));
|
|
45
|
+
process.on("SIGINT", () => {
|
|
46
|
+
});
|
|
47
|
+
process.on("SIGTERM", () => {
|
|
48
|
+
});
|
|
49
|
+
let processRunner;
|
|
50
|
+
let processName;
|
|
51
|
+
const startingEnv = { ...process.env };
|
|
52
|
+
process.on("message", async (message) => {
|
|
53
|
+
if (message.method === "__init__") {
|
|
54
|
+
const { processParams, runnerParams, runnerScript } = message.params;
|
|
55
|
+
void (0, import_utils.startProfiling)();
|
|
56
|
+
(0, import_utils.setTimeOrigin)(processParams.timeOrigin);
|
|
57
|
+
const { create } = require(runnerScript);
|
|
58
|
+
processRunner = create(runnerParams);
|
|
59
|
+
processName = processParams.processName;
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
if (message.method === "__stop__") {
|
|
63
|
+
const keys = /* @__PURE__ */ new Set([...Object.keys(process.env), ...Object.keys(startingEnv)]);
|
|
64
|
+
const producedEnv = [...keys].filter((key) => startingEnv[key] !== process.env[key]).map((key) => [key, process.env[key] ?? null]);
|
|
65
|
+
sendMessageToParent({ method: "__env_produced__", params: producedEnv });
|
|
66
|
+
await gracefullyCloseAndExit(false);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
if (message.method === "__dispatch__") {
|
|
70
|
+
const { id, method, params } = message.params;
|
|
71
|
+
try {
|
|
72
|
+
const result = await processRunner[method](params);
|
|
73
|
+
const response = { id, result };
|
|
74
|
+
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
75
|
+
} catch (e) {
|
|
76
|
+
const response = { id, error: (0, import_util.serializeError)(e) };
|
|
77
|
+
sendMessageToParent({ method: "__dispatch__", params: response });
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
if (message.method === "__response__")
|
|
81
|
+
handleResponseFromParent(message.params);
|
|
82
|
+
});
|
|
83
|
+
const kForceExitTimeout = +(process.env.PWTEST_FORCE_EXIT_TIMEOUT || 3e4);
|
|
84
|
+
async function gracefullyCloseAndExit(forceExit) {
|
|
85
|
+
if (forceExit && !forceExitInitiated) {
|
|
86
|
+
forceExitInitiated = true;
|
|
87
|
+
setTimeout(() => process.exit(0), kForceExitTimeout);
|
|
88
|
+
}
|
|
89
|
+
if (!gracefullyCloseCalled) {
|
|
90
|
+
gracefullyCloseCalled = true;
|
|
91
|
+
await processRunner?.gracefullyClose().catch(() => {
|
|
92
|
+
});
|
|
93
|
+
if (processName)
|
|
94
|
+
await (0, import_utils.stopProfiling)(processName).catch(() => {
|
|
95
|
+
});
|
|
96
|
+
process.exit(0);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
function sendMessageToParent(message) {
|
|
100
|
+
try {
|
|
101
|
+
process.send(message);
|
|
102
|
+
} catch (e) {
|
|
103
|
+
try {
|
|
104
|
+
JSON.stringify(message);
|
|
105
|
+
} catch {
|
|
106
|
+
throw e;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
let lastId = 0;
|
|
111
|
+
const requestCallbacks = /* @__PURE__ */ new Map();
|
|
112
|
+
async function sendRequestToParent(method, params) {
|
|
113
|
+
const id = ++lastId;
|
|
114
|
+
sendMessageToParent({ method: "__request__", params: { id, method, params } });
|
|
115
|
+
const promise = new import_utils.ManualPromise();
|
|
116
|
+
requestCallbacks.set(id, promise);
|
|
117
|
+
return promise;
|
|
118
|
+
}
|
|
119
|
+
function handleResponseFromParent(response) {
|
|
120
|
+
const promise = requestCallbacks.get(response.id);
|
|
121
|
+
if (!promise)
|
|
122
|
+
return;
|
|
123
|
+
requestCallbacks.delete(response.id);
|
|
124
|
+
if (response.error)
|
|
125
|
+
promise.reject(new Error(response.error.message));
|
|
126
|
+
else
|
|
127
|
+
promise.resolve(response.result);
|
|
128
|
+
}
|
|
129
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
130
|
+
0 && (module.exports = {
|
|
131
|
+
ProcessRunner
|
|
132
|
+
});
|
package/lib/common/suiteUtils.js
CHANGED
|
@@ -1,140 +1,140 @@
|
|
|
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 __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
var suiteUtils_exports = {};
|
|
30
|
-
__export(suiteUtils_exports, {
|
|
31
|
-
applyRepeatEachIndex: () => applyRepeatEachIndex,
|
|
32
|
-
bindFileSuiteToProject: () => bindFileSuiteToProject,
|
|
33
|
-
filterByFocusedLine: () => filterByFocusedLine,
|
|
34
|
-
filterOnly: () => filterOnly,
|
|
35
|
-
filterSuite: () => filterSuite,
|
|
36
|
-
filterTestsRemoveEmptySuites: () => filterTestsRemoveEmptySuites
|
|
37
|
-
});
|
|
38
|
-
module.exports = __toCommonJS(suiteUtils_exports);
|
|
39
|
-
var import_path = __toESM(require("path"));
|
|
40
|
-
var import_utils = require("patchright-core/lib/utils");
|
|
41
|
-
var import_util = require("../util");
|
|
42
|
-
function filterSuite(suite, suiteFilter, testFilter) {
|
|
43
|
-
for (const child of suite.suites) {
|
|
44
|
-
if (!suiteFilter(child))
|
|
45
|
-
filterSuite(child, suiteFilter, testFilter);
|
|
46
|
-
}
|
|
47
|
-
const filteredTests = suite.tests.filter(testFilter);
|
|
48
|
-
const entries = /* @__PURE__ */ new Set([...suite.suites, ...filteredTests]);
|
|
49
|
-
suite._entries = suite._entries.filter((e) => entries.has(e));
|
|
50
|
-
}
|
|
51
|
-
function filterTestsRemoveEmptySuites(suite, filter) {
|
|
52
|
-
const filteredSuites = suite.suites.filter((child) => filterTestsRemoveEmptySuites(child, filter));
|
|
53
|
-
const filteredTests = suite.tests.filter(filter);
|
|
54
|
-
const entries = /* @__PURE__ */ new Set([...filteredSuites, ...filteredTests]);
|
|
55
|
-
suite._entries = suite._entries.filter((e) => entries.has(e));
|
|
56
|
-
return !!suite._entries.length;
|
|
57
|
-
}
|
|
58
|
-
function bindFileSuiteToProject(project, suite) {
|
|
59
|
-
const relativeFile = import_path.default.relative(project.project.testDir, suite.location.file);
|
|
60
|
-
const fileId = (0, import_utils.calculateSha1)((0, import_utils.toPosixPath)(relativeFile)).slice(0, 20);
|
|
61
|
-
const result = suite._deepClone();
|
|
62
|
-
result._fileId = fileId;
|
|
63
|
-
result.forEachTest((test, suite2) => {
|
|
64
|
-
suite2._fileId = fileId;
|
|
65
|
-
const [file, ...titles] = test.titlePath();
|
|
66
|
-
const testIdExpression = `[project=${project.id}]${(0, import_utils.toPosixPath)(file)}${titles.join("")}`;
|
|
67
|
-
const testId = fileId + "-" + (0, import_utils.calculateSha1)(testIdExpression).slice(0, 20);
|
|
68
|
-
test.id = testId;
|
|
69
|
-
test._projectId = project.id;
|
|
70
|
-
let inheritedRetries;
|
|
71
|
-
let inheritedTimeout;
|
|
72
|
-
for (let parentSuite = suite2; parentSuite; parentSuite = parentSuite.parent) {
|
|
73
|
-
if (parentSuite._staticAnnotations.length)
|
|
74
|
-
test.annotations.unshift(...parentSuite._staticAnnotations);
|
|
75
|
-
if (inheritedRetries === void 0 && parentSuite._retries !== void 0)
|
|
76
|
-
inheritedRetries = parentSuite._retries;
|
|
77
|
-
if (inheritedTimeout === void 0 && parentSuite._timeout !== void 0)
|
|
78
|
-
inheritedTimeout = parentSuite._timeout;
|
|
79
|
-
}
|
|
80
|
-
test.retries = inheritedRetries ?? project.project.retries;
|
|
81
|
-
test.timeout = inheritedTimeout ?? project.project.timeout;
|
|
82
|
-
if (test.annotations.some((a) => a.type === "skip" || a.type === "fixme"))
|
|
83
|
-
test.expectedStatus = "skipped";
|
|
84
|
-
if (test._poolDigest)
|
|
85
|
-
test._workerHash = `${project.id}-${test._poolDigest}-0`;
|
|
86
|
-
});
|
|
87
|
-
return result;
|
|
88
|
-
}
|
|
89
|
-
function applyRepeatEachIndex(project, fileSuite, repeatEachIndex) {
|
|
90
|
-
fileSuite.forEachTest((test, suite) => {
|
|
91
|
-
if (repeatEachIndex) {
|
|
92
|
-
const [file, ...titles] = test.titlePath();
|
|
93
|
-
const testIdExpression = `[project=${project.id}]${(0, import_utils.toPosixPath)(file)}${titles.join("")} (repeat:${repeatEachIndex})`;
|
|
94
|
-
const testId = suite._fileId + "-" + (0, import_utils.calculateSha1)(testIdExpression).slice(0, 20);
|
|
95
|
-
test.id = testId;
|
|
96
|
-
test.repeatEachIndex = repeatEachIndex;
|
|
97
|
-
if (test._poolDigest)
|
|
98
|
-
test._workerHash = `${project.id}-${test._poolDigest}-${repeatEachIndex}`;
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
function filterOnly(suite) {
|
|
103
|
-
if (!suite._getOnlyItems().length)
|
|
104
|
-
return;
|
|
105
|
-
const suiteFilter = (suite2) => suite2._only;
|
|
106
|
-
const testFilter = (test) => test._only;
|
|
107
|
-
return filterSuiteWithOnlySemantics(suite, suiteFilter, testFilter);
|
|
108
|
-
}
|
|
109
|
-
function filterSuiteWithOnlySemantics(suite, suiteFilter, testFilter) {
|
|
110
|
-
const onlySuites = suite.suites.filter((child) => filterSuiteWithOnlySemantics(child, suiteFilter, testFilter) || suiteFilter(child));
|
|
111
|
-
const onlyTests = suite.tests.filter(testFilter);
|
|
112
|
-
const onlyEntries = /* @__PURE__ */ new Set([...onlySuites, ...onlyTests]);
|
|
113
|
-
if (onlyEntries.size) {
|
|
114
|
-
suite._entries = suite._entries.filter((e) => onlyEntries.has(e));
|
|
115
|
-
return true;
|
|
116
|
-
}
|
|
117
|
-
return false;
|
|
118
|
-
}
|
|
119
|
-
function filterByFocusedLine(suite, focusedTestFileLines) {
|
|
120
|
-
if (!focusedTestFileLines.length)
|
|
121
|
-
return;
|
|
122
|
-
const matchers = focusedTestFileLines.map(createFileMatcherFromFilter);
|
|
123
|
-
const testFileLineMatches = (testFileName, testLine, testColumn) => matchers.some((m) => m(testFileName, testLine, testColumn));
|
|
124
|
-
const suiteFilter = (suite2) => !!suite2.location && testFileLineMatches(suite2.location.file, suite2.location.line, suite2.location.column);
|
|
125
|
-
const testFilter = (test) => testFileLineMatches(test.location.file, test.location.line, test.location.column);
|
|
126
|
-
return filterSuite(suite, suiteFilter, testFilter);
|
|
127
|
-
}
|
|
128
|
-
function createFileMatcherFromFilter(filter) {
|
|
129
|
-
const fileMatcher = (0, import_util.createFileMatcher)(filter.re || filter.exact || "");
|
|
130
|
-
return (testFileName, testLine, testColumn) => fileMatcher(testFileName) && (filter.line === testLine || filter.line === null) && (filter.column === testColumn || filter.column === null);
|
|
131
|
-
}
|
|
132
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
133
|
-
0 && (module.exports = {
|
|
134
|
-
applyRepeatEachIndex,
|
|
135
|
-
bindFileSuiteToProject,
|
|
136
|
-
filterByFocusedLine,
|
|
137
|
-
filterOnly,
|
|
138
|
-
filterSuite,
|
|
139
|
-
filterTestsRemoveEmptySuites
|
|
140
|
-
});
|
|
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 __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var suiteUtils_exports = {};
|
|
30
|
+
__export(suiteUtils_exports, {
|
|
31
|
+
applyRepeatEachIndex: () => applyRepeatEachIndex,
|
|
32
|
+
bindFileSuiteToProject: () => bindFileSuiteToProject,
|
|
33
|
+
filterByFocusedLine: () => filterByFocusedLine,
|
|
34
|
+
filterOnly: () => filterOnly,
|
|
35
|
+
filterSuite: () => filterSuite,
|
|
36
|
+
filterTestsRemoveEmptySuites: () => filterTestsRemoveEmptySuites
|
|
37
|
+
});
|
|
38
|
+
module.exports = __toCommonJS(suiteUtils_exports);
|
|
39
|
+
var import_path = __toESM(require("path"));
|
|
40
|
+
var import_utils = require("patchright-bun-core/lib/utils");
|
|
41
|
+
var import_util = require("../util");
|
|
42
|
+
function filterSuite(suite, suiteFilter, testFilter) {
|
|
43
|
+
for (const child of suite.suites) {
|
|
44
|
+
if (!suiteFilter(child))
|
|
45
|
+
filterSuite(child, suiteFilter, testFilter);
|
|
46
|
+
}
|
|
47
|
+
const filteredTests = suite.tests.filter(testFilter);
|
|
48
|
+
const entries = /* @__PURE__ */ new Set([...suite.suites, ...filteredTests]);
|
|
49
|
+
suite._entries = suite._entries.filter((e) => entries.has(e));
|
|
50
|
+
}
|
|
51
|
+
function filterTestsRemoveEmptySuites(suite, filter) {
|
|
52
|
+
const filteredSuites = suite.suites.filter((child) => filterTestsRemoveEmptySuites(child, filter));
|
|
53
|
+
const filteredTests = suite.tests.filter(filter);
|
|
54
|
+
const entries = /* @__PURE__ */ new Set([...filteredSuites, ...filteredTests]);
|
|
55
|
+
suite._entries = suite._entries.filter((e) => entries.has(e));
|
|
56
|
+
return !!suite._entries.length;
|
|
57
|
+
}
|
|
58
|
+
function bindFileSuiteToProject(project, suite) {
|
|
59
|
+
const relativeFile = import_path.default.relative(project.project.testDir, suite.location.file);
|
|
60
|
+
const fileId = (0, import_utils.calculateSha1)((0, import_utils.toPosixPath)(relativeFile)).slice(0, 20);
|
|
61
|
+
const result = suite._deepClone();
|
|
62
|
+
result._fileId = fileId;
|
|
63
|
+
result.forEachTest((test, suite2) => {
|
|
64
|
+
suite2._fileId = fileId;
|
|
65
|
+
const [file, ...titles] = test.titlePath();
|
|
66
|
+
const testIdExpression = `[project=${project.id}]${(0, import_utils.toPosixPath)(file)}${titles.join("")}`;
|
|
67
|
+
const testId = fileId + "-" + (0, import_utils.calculateSha1)(testIdExpression).slice(0, 20);
|
|
68
|
+
test.id = testId;
|
|
69
|
+
test._projectId = project.id;
|
|
70
|
+
let inheritedRetries;
|
|
71
|
+
let inheritedTimeout;
|
|
72
|
+
for (let parentSuite = suite2; parentSuite; parentSuite = parentSuite.parent) {
|
|
73
|
+
if (parentSuite._staticAnnotations.length)
|
|
74
|
+
test.annotations.unshift(...parentSuite._staticAnnotations);
|
|
75
|
+
if (inheritedRetries === void 0 && parentSuite._retries !== void 0)
|
|
76
|
+
inheritedRetries = parentSuite._retries;
|
|
77
|
+
if (inheritedTimeout === void 0 && parentSuite._timeout !== void 0)
|
|
78
|
+
inheritedTimeout = parentSuite._timeout;
|
|
79
|
+
}
|
|
80
|
+
test.retries = inheritedRetries ?? project.project.retries;
|
|
81
|
+
test.timeout = inheritedTimeout ?? project.project.timeout;
|
|
82
|
+
if (test.annotations.some((a) => a.type === "skip" || a.type === "fixme"))
|
|
83
|
+
test.expectedStatus = "skipped";
|
|
84
|
+
if (test._poolDigest)
|
|
85
|
+
test._workerHash = `${project.id}-${test._poolDigest}-0`;
|
|
86
|
+
});
|
|
87
|
+
return result;
|
|
88
|
+
}
|
|
89
|
+
function applyRepeatEachIndex(project, fileSuite, repeatEachIndex) {
|
|
90
|
+
fileSuite.forEachTest((test, suite) => {
|
|
91
|
+
if (repeatEachIndex) {
|
|
92
|
+
const [file, ...titles] = test.titlePath();
|
|
93
|
+
const testIdExpression = `[project=${project.id}]${(0, import_utils.toPosixPath)(file)}${titles.join("")} (repeat:${repeatEachIndex})`;
|
|
94
|
+
const testId = suite._fileId + "-" + (0, import_utils.calculateSha1)(testIdExpression).slice(0, 20);
|
|
95
|
+
test.id = testId;
|
|
96
|
+
test.repeatEachIndex = repeatEachIndex;
|
|
97
|
+
if (test._poolDigest)
|
|
98
|
+
test._workerHash = `${project.id}-${test._poolDigest}-${repeatEachIndex}`;
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
function filterOnly(suite) {
|
|
103
|
+
if (!suite._getOnlyItems().length)
|
|
104
|
+
return;
|
|
105
|
+
const suiteFilter = (suite2) => suite2._only;
|
|
106
|
+
const testFilter = (test) => test._only;
|
|
107
|
+
return filterSuiteWithOnlySemantics(suite, suiteFilter, testFilter);
|
|
108
|
+
}
|
|
109
|
+
function filterSuiteWithOnlySemantics(suite, suiteFilter, testFilter) {
|
|
110
|
+
const onlySuites = suite.suites.filter((child) => filterSuiteWithOnlySemantics(child, suiteFilter, testFilter) || suiteFilter(child));
|
|
111
|
+
const onlyTests = suite.tests.filter(testFilter);
|
|
112
|
+
const onlyEntries = /* @__PURE__ */ new Set([...onlySuites, ...onlyTests]);
|
|
113
|
+
if (onlyEntries.size) {
|
|
114
|
+
suite._entries = suite._entries.filter((e) => onlyEntries.has(e));
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
117
|
+
return false;
|
|
118
|
+
}
|
|
119
|
+
function filterByFocusedLine(suite, focusedTestFileLines) {
|
|
120
|
+
if (!focusedTestFileLines.length)
|
|
121
|
+
return;
|
|
122
|
+
const matchers = focusedTestFileLines.map(createFileMatcherFromFilter);
|
|
123
|
+
const testFileLineMatches = (testFileName, testLine, testColumn) => matchers.some((m) => m(testFileName, testLine, testColumn));
|
|
124
|
+
const suiteFilter = (suite2) => !!suite2.location && testFileLineMatches(suite2.location.file, suite2.location.line, suite2.location.column);
|
|
125
|
+
const testFilter = (test) => testFileLineMatches(test.location.file, test.location.line, test.location.column);
|
|
126
|
+
return filterSuite(suite, suiteFilter, testFilter);
|
|
127
|
+
}
|
|
128
|
+
function createFileMatcherFromFilter(filter) {
|
|
129
|
+
const fileMatcher = (0, import_util.createFileMatcher)(filter.re || filter.exact || "");
|
|
130
|
+
return (testFileName, testLine, testColumn) => fileMatcher(testFileName) && (filter.line === testLine || filter.line === null) && (filter.column === testColumn || filter.column === null);
|
|
131
|
+
}
|
|
132
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
133
|
+
0 && (module.exports = {
|
|
134
|
+
applyRepeatEachIndex,
|
|
135
|
+
bindFileSuiteToProject,
|
|
136
|
+
filterByFocusedLine,
|
|
137
|
+
filterOnly,
|
|
138
|
+
filterSuite,
|
|
139
|
+
filterTestsRemoveEmptySuites
|
|
140
|
+
});
|