@smoothdeploy/playwright 1.58.3 → 1.60.0-beta-1780662356000
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/ThirdPartyNotices.txt +8 -5036
- package/lib/agents/agentParser.js +2 -2
- package/lib/agents/generateAgents.js +21 -22
- package/lib/agents/playwright-test-healer.agent.md +1 -0
- package/lib/agents/playwright-test-planner.agent.md +2 -1
- package/lib/cli/reportActions.js +78 -0
- package/lib/cli/testActions.js +211 -0
- package/lib/common/index.js +2898 -0
- package/lib/common/index.js.txt +35 -0
- package/lib/errorContext.js +130 -0
- package/lib/index.js +283 -206
- package/lib/{isomorphic/testServerConnection.js → isomorphic.js} +70 -35
- package/lib/isomorphic.js.txt +9 -0
- package/lib/loader/loaderProcessEntry.js +34 -0
- package/lib/loader/loaderProcessEntry.js.txt +9 -0
- package/lib/matchers/expect.js +12988 -249
- package/lib/matchers/expect.js.LICENSE +693 -0
- package/lib/matchers/expect.js.txt +72 -0
- package/lib/mcp/test/browserBackend.js +49 -22
- package/lib/mcp/test/generatorTools.js +16 -16
- package/lib/mcp/test/plannerTools.js +25 -20
- package/lib/mcp/test/seed.js +7 -7
- package/lib/mcp/test/testBackend.js +30 -30
- package/lib/mcp/test/testContext.js +50 -33
- package/lib/mcp/test/testTools.js +15 -25
- package/lib/{internalsForTest.js → package.js} +13 -8
- package/lib/program.js +63 -263
- package/lib/runner/index.js +8339 -0
- package/lib/runner/index.js.txt +60 -0
- package/lib/transform/babelBundle.js +71002 -18
- package/lib/transform/babelBundle.js.LICENSE +2359 -0
- package/lib/transform/babelBundle.js.txt +325 -0
- package/lib/transform/esmLoader.js +5884 -30
- package/lib/transform/esmLoader.js.LICENSE +335 -0
- package/lib/transform/esmLoader.js.txt +55 -0
- package/lib/util.js +37 -34
- package/lib/worker/workerProcessEntry.js +3251 -0
- package/lib/worker/workerProcessEntry.js.txt +24 -0
- package/package.json +5 -16
- package/test.mjs +1 -0
- package/types/test.d.ts +173 -12
- package/types/testReporter.d.ts +7 -5
- package/lib/common/config.js +0 -282
- package/lib/common/configLoader.js +0 -344
- package/lib/common/esmLoaderHost.js +0 -104
- package/lib/common/expectBundle.js +0 -28
- package/lib/common/expectBundleImpl.js +0 -407
- package/lib/common/fixtures.js +0 -302
- package/lib/common/ipc.js +0 -60
- package/lib/common/poolBuilder.js +0 -85
- package/lib/common/process.js +0 -132
- package/lib/common/suiteUtils.js +0 -140
- package/lib/common/test.js +0 -321
- package/lib/common/testLoader.js +0 -101
- package/lib/common/testType.js +0 -298
- package/lib/common/validators.js +0 -68
- package/lib/fsWatcher.js +0 -67
- package/lib/isomorphic/events.js +0 -77
- package/lib/isomorphic/folders.js +0 -30
- package/lib/isomorphic/stringInternPool.js +0 -69
- package/lib/isomorphic/teleReceiver.js +0 -521
- package/lib/isomorphic/teleSuiteUpdater.js +0 -157
- package/lib/isomorphic/testServerInterface.js +0 -16
- package/lib/isomorphic/testTree.js +0 -329
- package/lib/isomorphic/types.d.js +0 -16
- package/lib/loader/loaderMain.js +0 -59
- package/lib/matchers/matcherHint.js +0 -44
- package/lib/matchers/matchers.js +0 -383
- package/lib/matchers/toBeTruthy.js +0 -75
- package/lib/matchers/toEqual.js +0 -100
- package/lib/matchers/toHaveURL.js +0 -101
- package/lib/matchers/toMatchAriaSnapshot.js +0 -159
- package/lib/matchers/toMatchSnapshot.js +0 -342
- package/lib/matchers/toMatchText.js +0 -99
- package/lib/mcp/browser/browserContextFactory.js +0 -329
- package/lib/mcp/browser/browserServerBackend.js +0 -84
- package/lib/mcp/browser/config.js +0 -421
- package/lib/mcp/browser/context.js +0 -244
- package/lib/mcp/browser/response.js +0 -278
- package/lib/mcp/browser/sessionLog.js +0 -75
- package/lib/mcp/browser/tab.js +0 -343
- package/lib/mcp/browser/tools/common.js +0 -65
- package/lib/mcp/browser/tools/console.js +0 -46
- package/lib/mcp/browser/tools/dialogs.js +0 -60
- package/lib/mcp/browser/tools/evaluate.js +0 -61
- package/lib/mcp/browser/tools/files.js +0 -58
- package/lib/mcp/browser/tools/form.js +0 -63
- package/lib/mcp/browser/tools/install.js +0 -72
- package/lib/mcp/browser/tools/keyboard.js +0 -107
- package/lib/mcp/browser/tools/mouse.js +0 -107
- package/lib/mcp/browser/tools/navigate.js +0 -71
- package/lib/mcp/browser/tools/network.js +0 -63
- package/lib/mcp/browser/tools/open.js +0 -57
- package/lib/mcp/browser/tools/pdf.js +0 -49
- package/lib/mcp/browser/tools/runCode.js +0 -78
- package/lib/mcp/browser/tools/screenshot.js +0 -93
- package/lib/mcp/browser/tools/snapshot.js +0 -173
- package/lib/mcp/browser/tools/tabs.js +0 -67
- package/lib/mcp/browser/tools/tool.js +0 -47
- package/lib/mcp/browser/tools/tracing.js +0 -74
- package/lib/mcp/browser/tools/utils.js +0 -94
- package/lib/mcp/browser/tools/verify.js +0 -143
- package/lib/mcp/browser/tools/wait.js +0 -63
- package/lib/mcp/browser/tools.js +0 -84
- package/lib/mcp/browser/watchdog.js +0 -44
- package/lib/mcp/config.d.js +0 -16
- package/lib/mcp/extension/cdpRelay.js +0 -351
- package/lib/mcp/extension/extensionContextFactory.js +0 -76
- package/lib/mcp/extension/protocol.js +0 -28
- package/lib/mcp/index.js +0 -61
- package/lib/mcp/log.js +0 -35
- package/lib/mcp/program.js +0 -111
- package/lib/mcp/sdk/exports.js +0 -28
- package/lib/mcp/sdk/http.js +0 -152
- package/lib/mcp/sdk/inProcessTransport.js +0 -71
- package/lib/mcp/sdk/server.js +0 -223
- package/lib/mcp/sdk/tool.js +0 -47
- package/lib/mcp/terminal/cli.js +0 -296
- package/lib/mcp/terminal/command.js +0 -56
- package/lib/mcp/terminal/commands.js +0 -333
- package/lib/mcp/terminal/daemon.js +0 -129
- package/lib/mcp/terminal/help.json +0 -32
- package/lib/mcp/terminal/helpGenerator.js +0 -88
- package/lib/mcp/terminal/socketConnection.js +0 -80
- package/lib/plugins/gitCommitInfoPlugin.js +0 -198
- package/lib/plugins/index.js +0 -28
- package/lib/plugins/webServerPlugin.js +0 -237
- package/lib/reporters/base.js +0 -634
- package/lib/reporters/blob.js +0 -138
- package/lib/reporters/dot.js +0 -99
- package/lib/reporters/empty.js +0 -32
- package/lib/reporters/github.js +0 -128
- package/lib/reporters/html.js +0 -633
- package/lib/reporters/internalReporter.js +0 -138
- package/lib/reporters/json.js +0 -254
- package/lib/reporters/junit.js +0 -232
- package/lib/reporters/line.js +0 -131
- package/lib/reporters/list.js +0 -253
- package/lib/reporters/listModeReporter.js +0 -69
- package/lib/reporters/markdown.js +0 -144
- package/lib/reporters/merge.js +0 -558
- package/lib/reporters/multiplexer.js +0 -112
- package/lib/reporters/reporterV2.js +0 -102
- package/lib/reporters/smoothdeploy.js +0 -333
- package/lib/reporters/teleEmitter.js +0 -317
- package/lib/reporters/versions/blobV1.js +0 -16
- package/lib/runner/dispatcher.js +0 -531
- package/lib/runner/failureTracker.js +0 -72
- package/lib/runner/lastRun.js +0 -77
- package/lib/runner/loadUtils.js +0 -334
- package/lib/runner/loaderHost.js +0 -89
- package/lib/runner/processHost.js +0 -180
- package/lib/runner/projectUtils.js +0 -241
- package/lib/runner/rebase.js +0 -189
- package/lib/runner/reporters.js +0 -140
- package/lib/runner/sigIntWatcher.js +0 -96
- package/lib/runner/storage.js +0 -91
- package/lib/runner/taskRunner.js +0 -127
- package/lib/runner/tasks.js +0 -410
- package/lib/runner/testGroups.js +0 -125
- package/lib/runner/testRunner.js +0 -398
- package/lib/runner/testServer.js +0 -269
- package/lib/runner/uiModeReporter.js +0 -30
- package/lib/runner/vcs.js +0 -72
- package/lib/runner/watchMode.js +0 -396
- package/lib/runner/workerHost.js +0 -104
- package/lib/third_party/pirates.js +0 -62
- package/lib/third_party/tsconfig-loader.js +0 -103
- package/lib/transform/babelBundleImpl.js +0 -461
- package/lib/transform/compilationCache.js +0 -274
- package/lib/transform/md.js +0 -221
- package/lib/transform/portTransport.js +0 -67
- package/lib/transform/transform.js +0 -303
- package/lib/utilsBundle.js +0 -50
- package/lib/utilsBundleImpl.js +0 -103
- package/lib/worker/fixtureRunner.js +0 -262
- package/lib/worker/testInfo.js +0 -536
- package/lib/worker/testTracing.js +0 -345
- package/lib/worker/timeoutManager.js +0 -174
- package/lib/worker/util.js +0 -31
- package/lib/worker/workerMain.js +0 -530
- /package/lib/{common/globals.js → globals.js} +0 -0
|
@@ -1,329 +0,0 @@
|
|
|
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 testTree_exports = {};
|
|
20
|
-
__export(testTree_exports, {
|
|
21
|
-
TestTree: () => TestTree,
|
|
22
|
-
sortAndPropagateStatus: () => sortAndPropagateStatus,
|
|
23
|
-
statusEx: () => statusEx
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(testTree_exports);
|
|
26
|
-
class TestTree {
|
|
27
|
-
constructor(rootFolder, rootSuite, loadErrors, projectFilters, pathSeparator, hideFiles) {
|
|
28
|
-
this._treeItemById = /* @__PURE__ */ new Map();
|
|
29
|
-
this._treeItemByTestId = /* @__PURE__ */ new Map();
|
|
30
|
-
const filterProjects = projectFilters && [...projectFilters.values()].some(Boolean);
|
|
31
|
-
this.pathSeparator = pathSeparator;
|
|
32
|
-
this.rootItem = {
|
|
33
|
-
kind: "group",
|
|
34
|
-
subKind: "folder",
|
|
35
|
-
id: rootFolder,
|
|
36
|
-
title: "",
|
|
37
|
-
location: { file: "", line: 0, column: 0 },
|
|
38
|
-
duration: 0,
|
|
39
|
-
parent: void 0,
|
|
40
|
-
children: [],
|
|
41
|
-
status: "none",
|
|
42
|
-
hasLoadErrors: false
|
|
43
|
-
};
|
|
44
|
-
this._treeItemById.set(rootFolder, this.rootItem);
|
|
45
|
-
const visitSuite = (project, parentSuite, parentGroup, mode) => {
|
|
46
|
-
for (const suite of mode === "tests" ? [] : parentSuite.suites) {
|
|
47
|
-
if (!suite.title) {
|
|
48
|
-
visitSuite(project, suite, parentGroup, "all");
|
|
49
|
-
continue;
|
|
50
|
-
}
|
|
51
|
-
let group = parentGroup.children.find((item) => item.kind === "group" && item.title === suite.title);
|
|
52
|
-
if (!group) {
|
|
53
|
-
group = {
|
|
54
|
-
kind: "group",
|
|
55
|
-
subKind: "describe",
|
|
56
|
-
id: "suite:" + parentSuite.titlePath().join("") + "" + suite.title,
|
|
57
|
-
// account for anonymous suites
|
|
58
|
-
title: suite.title,
|
|
59
|
-
location: suite.location,
|
|
60
|
-
duration: 0,
|
|
61
|
-
parent: parentGroup,
|
|
62
|
-
children: [],
|
|
63
|
-
status: "none",
|
|
64
|
-
hasLoadErrors: false
|
|
65
|
-
};
|
|
66
|
-
this._addChild(parentGroup, group);
|
|
67
|
-
}
|
|
68
|
-
visitSuite(project, suite, group, "all");
|
|
69
|
-
}
|
|
70
|
-
for (const test of mode === "suites" ? [] : parentSuite.tests) {
|
|
71
|
-
const title = test.title;
|
|
72
|
-
let testCaseItem = parentGroup.children.find((t) => t.kind !== "group" && t.title === title);
|
|
73
|
-
if (!testCaseItem) {
|
|
74
|
-
testCaseItem = {
|
|
75
|
-
kind: "case",
|
|
76
|
-
id: "test:" + test.titlePath().join(""),
|
|
77
|
-
title,
|
|
78
|
-
parent: parentGroup,
|
|
79
|
-
children: [],
|
|
80
|
-
tests: [],
|
|
81
|
-
location: test.location,
|
|
82
|
-
duration: 0,
|
|
83
|
-
status: "none",
|
|
84
|
-
project: void 0,
|
|
85
|
-
test: void 0,
|
|
86
|
-
tags: test.tags
|
|
87
|
-
};
|
|
88
|
-
this._addChild(parentGroup, testCaseItem);
|
|
89
|
-
}
|
|
90
|
-
const result = test.results[0];
|
|
91
|
-
let status = "none";
|
|
92
|
-
if (result?.[statusEx] === "scheduled")
|
|
93
|
-
status = "scheduled";
|
|
94
|
-
else if (result?.[statusEx] === "running")
|
|
95
|
-
status = "running";
|
|
96
|
-
else if (result?.status === "skipped")
|
|
97
|
-
status = "skipped";
|
|
98
|
-
else if (result?.status === "interrupted")
|
|
99
|
-
status = "none";
|
|
100
|
-
else if (result && test.outcome() !== "expected")
|
|
101
|
-
status = "failed";
|
|
102
|
-
else if (result && test.outcome() === "expected")
|
|
103
|
-
status = "passed";
|
|
104
|
-
testCaseItem.tests.push(test);
|
|
105
|
-
const testItem = {
|
|
106
|
-
kind: "test",
|
|
107
|
-
id: test.id,
|
|
108
|
-
title: project.name,
|
|
109
|
-
location: test.location,
|
|
110
|
-
test,
|
|
111
|
-
parent: testCaseItem,
|
|
112
|
-
children: [],
|
|
113
|
-
status,
|
|
114
|
-
duration: test.results.length ? Math.max(0, test.results[0].duration) : 0,
|
|
115
|
-
project
|
|
116
|
-
};
|
|
117
|
-
this._addChild(testCaseItem, testItem);
|
|
118
|
-
this._treeItemByTestId.set(test.id, testItem);
|
|
119
|
-
testCaseItem.duration = testCaseItem.children.reduce((a, b) => a + b.duration, 0);
|
|
120
|
-
}
|
|
121
|
-
};
|
|
122
|
-
for (const projectSuite of rootSuite?.suites || []) {
|
|
123
|
-
if (filterProjects && !projectFilters.get(projectSuite.title))
|
|
124
|
-
continue;
|
|
125
|
-
for (const fileSuite of projectSuite.suites) {
|
|
126
|
-
if (hideFiles) {
|
|
127
|
-
visitSuite(projectSuite.project(), fileSuite, this.rootItem, "suites");
|
|
128
|
-
if (fileSuite.tests.length) {
|
|
129
|
-
const defaultDescribeItem = this._defaultDescribeItem();
|
|
130
|
-
visitSuite(projectSuite.project(), fileSuite, defaultDescribeItem, "tests");
|
|
131
|
-
}
|
|
132
|
-
} else {
|
|
133
|
-
const fileItem = this._fileItem(fileSuite.location.file.split(pathSeparator), true);
|
|
134
|
-
visitSuite(projectSuite.project(), fileSuite, fileItem, "all");
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
for (const loadError of loadErrors) {
|
|
139
|
-
if (!loadError.location)
|
|
140
|
-
continue;
|
|
141
|
-
const fileItem = this._fileItem(loadError.location.file.split(pathSeparator), true);
|
|
142
|
-
fileItem.hasLoadErrors = true;
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
_addChild(parent, child) {
|
|
146
|
-
parent.children.push(child);
|
|
147
|
-
child.parent = parent;
|
|
148
|
-
this._treeItemById.set(child.id, child);
|
|
149
|
-
}
|
|
150
|
-
filterTree(filterText, statusFilters, runningTestIds) {
|
|
151
|
-
const tokens = filterText.trim().toLowerCase().split(" ");
|
|
152
|
-
const filtersStatuses = [...statusFilters.values()].some(Boolean);
|
|
153
|
-
const filter = (testCase) => {
|
|
154
|
-
const titleWithTags = [...testCase.tests[0].titlePath(), ...testCase.tests[0].tags].join(" ").toLowerCase();
|
|
155
|
-
if (!tokens.every((token) => titleWithTags.includes(token)) && !testCase.tests.some((t) => runningTestIds?.has(t.id)))
|
|
156
|
-
return false;
|
|
157
|
-
testCase.children = testCase.children.filter((test) => {
|
|
158
|
-
return !filtersStatuses || runningTestIds?.has(test.test.id) || statusFilters.get(test.status);
|
|
159
|
-
});
|
|
160
|
-
testCase.tests = testCase.children.map((c) => c.test);
|
|
161
|
-
return !!testCase.children.length;
|
|
162
|
-
};
|
|
163
|
-
const visit = (treeItem) => {
|
|
164
|
-
const newChildren = [];
|
|
165
|
-
for (const child of treeItem.children) {
|
|
166
|
-
if (child.kind === "case") {
|
|
167
|
-
if (filter(child))
|
|
168
|
-
newChildren.push(child);
|
|
169
|
-
} else {
|
|
170
|
-
visit(child);
|
|
171
|
-
if (child.children.length || child.hasLoadErrors)
|
|
172
|
-
newChildren.push(child);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
treeItem.children = newChildren;
|
|
176
|
-
};
|
|
177
|
-
visit(this.rootItem);
|
|
178
|
-
}
|
|
179
|
-
_fileItem(filePath, isFile) {
|
|
180
|
-
if (filePath.length === 0)
|
|
181
|
-
return this.rootItem;
|
|
182
|
-
const fileName = filePath.join(this.pathSeparator);
|
|
183
|
-
const existingFileItem = this._treeItemById.get(fileName);
|
|
184
|
-
if (existingFileItem)
|
|
185
|
-
return existingFileItem;
|
|
186
|
-
const parentFileItem = this._fileItem(filePath.slice(0, filePath.length - 1), false);
|
|
187
|
-
const fileItem = {
|
|
188
|
-
kind: "group",
|
|
189
|
-
subKind: isFile ? "file" : "folder",
|
|
190
|
-
id: fileName,
|
|
191
|
-
title: filePath[filePath.length - 1],
|
|
192
|
-
location: { file: fileName, line: 0, column: 0 },
|
|
193
|
-
duration: 0,
|
|
194
|
-
parent: parentFileItem,
|
|
195
|
-
children: [],
|
|
196
|
-
status: "none",
|
|
197
|
-
hasLoadErrors: false
|
|
198
|
-
};
|
|
199
|
-
this._addChild(parentFileItem, fileItem);
|
|
200
|
-
return fileItem;
|
|
201
|
-
}
|
|
202
|
-
_defaultDescribeItem() {
|
|
203
|
-
let defaultDescribeItem = this._treeItemById.get("<anonymous>");
|
|
204
|
-
if (!defaultDescribeItem) {
|
|
205
|
-
defaultDescribeItem = {
|
|
206
|
-
kind: "group",
|
|
207
|
-
subKind: "describe",
|
|
208
|
-
id: "<anonymous>",
|
|
209
|
-
title: "<anonymous>",
|
|
210
|
-
location: { file: "", line: 0, column: 0 },
|
|
211
|
-
duration: 0,
|
|
212
|
-
parent: this.rootItem,
|
|
213
|
-
children: [],
|
|
214
|
-
status: "none",
|
|
215
|
-
hasLoadErrors: false
|
|
216
|
-
};
|
|
217
|
-
this._addChild(this.rootItem, defaultDescribeItem);
|
|
218
|
-
}
|
|
219
|
-
return defaultDescribeItem;
|
|
220
|
-
}
|
|
221
|
-
sortAndPropagateStatus() {
|
|
222
|
-
sortAndPropagateStatus(this.rootItem);
|
|
223
|
-
}
|
|
224
|
-
flattenForSingleProject() {
|
|
225
|
-
const visit = (treeItem) => {
|
|
226
|
-
if (treeItem.kind === "case" && treeItem.children.length === 1) {
|
|
227
|
-
treeItem.project = treeItem.children[0].project;
|
|
228
|
-
treeItem.test = treeItem.children[0].test;
|
|
229
|
-
treeItem.children = [];
|
|
230
|
-
this._treeItemByTestId.set(treeItem.test.id, treeItem);
|
|
231
|
-
} else {
|
|
232
|
-
treeItem.children.forEach(visit);
|
|
233
|
-
}
|
|
234
|
-
};
|
|
235
|
-
visit(this.rootItem);
|
|
236
|
-
}
|
|
237
|
-
shortenRoot() {
|
|
238
|
-
let shortRoot = this.rootItem;
|
|
239
|
-
while (shortRoot.children.length === 1 && shortRoot.children[0].kind === "group" && shortRoot.children[0].subKind === "folder")
|
|
240
|
-
shortRoot = shortRoot.children[0];
|
|
241
|
-
shortRoot.location = this.rootItem.location;
|
|
242
|
-
this.rootItem = shortRoot;
|
|
243
|
-
}
|
|
244
|
-
fileNames() {
|
|
245
|
-
const result = /* @__PURE__ */ new Set();
|
|
246
|
-
const visit = (treeItem) => {
|
|
247
|
-
if (treeItem.kind === "group" && treeItem.subKind === "file")
|
|
248
|
-
result.add(treeItem.id);
|
|
249
|
-
else
|
|
250
|
-
treeItem.children.forEach(visit);
|
|
251
|
-
};
|
|
252
|
-
visit(this.rootItem);
|
|
253
|
-
return [...result];
|
|
254
|
-
}
|
|
255
|
-
flatTreeItems() {
|
|
256
|
-
const result = [];
|
|
257
|
-
const visit = (treeItem) => {
|
|
258
|
-
result.push(treeItem);
|
|
259
|
-
treeItem.children.forEach(visit);
|
|
260
|
-
};
|
|
261
|
-
visit(this.rootItem);
|
|
262
|
-
return result;
|
|
263
|
-
}
|
|
264
|
-
treeItemById(id) {
|
|
265
|
-
return this._treeItemById.get(id);
|
|
266
|
-
}
|
|
267
|
-
collectTestIds(treeItem) {
|
|
268
|
-
return collectTestIds(treeItem);
|
|
269
|
-
}
|
|
270
|
-
}
|
|
271
|
-
function sortAndPropagateStatus(treeItem) {
|
|
272
|
-
for (const child of treeItem.children)
|
|
273
|
-
sortAndPropagateStatus(child);
|
|
274
|
-
if (treeItem.kind === "group") {
|
|
275
|
-
treeItem.children.sort((a, b) => {
|
|
276
|
-
const fc = a.location.file.localeCompare(b.location.file);
|
|
277
|
-
return fc || a.location.line - b.location.line;
|
|
278
|
-
});
|
|
279
|
-
}
|
|
280
|
-
let allPassed = treeItem.children.length > 0;
|
|
281
|
-
let allSkipped = treeItem.children.length > 0;
|
|
282
|
-
let hasFailed = false;
|
|
283
|
-
let hasRunning = false;
|
|
284
|
-
let hasScheduled = false;
|
|
285
|
-
for (const child of treeItem.children) {
|
|
286
|
-
allSkipped = allSkipped && child.status === "skipped";
|
|
287
|
-
allPassed = allPassed && (child.status === "passed" || child.status === "skipped");
|
|
288
|
-
hasFailed = hasFailed || child.status === "failed";
|
|
289
|
-
hasRunning = hasRunning || child.status === "running";
|
|
290
|
-
hasScheduled = hasScheduled || child.status === "scheduled";
|
|
291
|
-
}
|
|
292
|
-
if (hasRunning)
|
|
293
|
-
treeItem.status = "running";
|
|
294
|
-
else if (hasScheduled)
|
|
295
|
-
treeItem.status = "scheduled";
|
|
296
|
-
else if (hasFailed)
|
|
297
|
-
treeItem.status = "failed";
|
|
298
|
-
else if (allSkipped)
|
|
299
|
-
treeItem.status = "skipped";
|
|
300
|
-
else if (allPassed)
|
|
301
|
-
treeItem.status = "passed";
|
|
302
|
-
}
|
|
303
|
-
function collectTestIds(treeItem) {
|
|
304
|
-
const testIds = /* @__PURE__ */ new Set();
|
|
305
|
-
const locations = /* @__PURE__ */ new Set();
|
|
306
|
-
const visit = (treeItem2) => {
|
|
307
|
-
if (treeItem2.kind !== "test" && treeItem2.kind !== "case") {
|
|
308
|
-
treeItem2.children.forEach(visit);
|
|
309
|
-
return;
|
|
310
|
-
}
|
|
311
|
-
let fileItem = treeItem2;
|
|
312
|
-
while (fileItem && fileItem.parent && !(fileItem.kind === "group" && fileItem.subKind === "file"))
|
|
313
|
-
fileItem = fileItem.parent;
|
|
314
|
-
locations.add(fileItem.location.file);
|
|
315
|
-
if (treeItem2.kind === "case")
|
|
316
|
-
treeItem2.tests.forEach((test) => testIds.add(test.id));
|
|
317
|
-
else
|
|
318
|
-
testIds.add(treeItem2.id);
|
|
319
|
-
};
|
|
320
|
-
visit(treeItem);
|
|
321
|
-
return { testIds, locations };
|
|
322
|
-
}
|
|
323
|
-
const statusEx = Symbol("statusEx");
|
|
324
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
325
|
-
0 && (module.exports = {
|
|
326
|
-
TestTree,
|
|
327
|
-
sortAndPropagateStatus,
|
|
328
|
-
statusEx
|
|
329
|
-
});
|
|
@@ -1,16 +0,0 @@
|
|
|
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 __copyProps = (to, from, except, desc) => {
|
|
7
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
8
|
-
for (let key of __getOwnPropNames(from))
|
|
9
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
10
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
11
|
-
}
|
|
12
|
-
return to;
|
|
13
|
-
};
|
|
14
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
15
|
-
var types_d_exports = {};
|
|
16
|
-
module.exports = __toCommonJS(types_d_exports);
|
package/lib/loader/loaderMain.js
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
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 loaderMain_exports = {};
|
|
20
|
-
__export(loaderMain_exports, {
|
|
21
|
-
LoaderMain: () => LoaderMain,
|
|
22
|
-
create: () => create
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(loaderMain_exports);
|
|
25
|
-
var import_configLoader = require("../common/configLoader");
|
|
26
|
-
var import_esmLoaderHost = require("../common/esmLoaderHost");
|
|
27
|
-
var import_poolBuilder = require("../common/poolBuilder");
|
|
28
|
-
var import_process = require("../common/process");
|
|
29
|
-
var import_testLoader = require("../common/testLoader");
|
|
30
|
-
var import_compilationCache = require("../transform/compilationCache");
|
|
31
|
-
class LoaderMain extends import_process.ProcessRunner {
|
|
32
|
-
constructor(serializedConfig) {
|
|
33
|
-
super();
|
|
34
|
-
this._poolBuilder = import_poolBuilder.PoolBuilder.createForLoader();
|
|
35
|
-
this._serializedConfig = serializedConfig;
|
|
36
|
-
}
|
|
37
|
-
_config() {
|
|
38
|
-
if (!this._configPromise)
|
|
39
|
-
this._configPromise = (0, import_configLoader.deserializeConfig)(this._serializedConfig);
|
|
40
|
-
return this._configPromise;
|
|
41
|
-
}
|
|
42
|
-
async loadTestFile(params) {
|
|
43
|
-
const testErrors = [];
|
|
44
|
-
const config = await this._config();
|
|
45
|
-
const fileSuite = await (0, import_testLoader.loadTestFile)(params.file, config, testErrors);
|
|
46
|
-
this._poolBuilder.buildPools(fileSuite);
|
|
47
|
-
return { fileSuite: fileSuite._deepSerialize(), testErrors };
|
|
48
|
-
}
|
|
49
|
-
async getCompilationCacheFromLoader() {
|
|
50
|
-
await (0, import_esmLoaderHost.incorporateCompilationCache)();
|
|
51
|
-
return (0, import_compilationCache.serializeCompilationCache)();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
const create = (config) => new LoaderMain(config);
|
|
55
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
56
|
-
0 && (module.exports = {
|
|
57
|
-
LoaderMain,
|
|
58
|
-
create
|
|
59
|
-
});
|
|
@@ -1,44 +0,0 @@
|
|
|
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 matcherHint_exports = {};
|
|
20
|
-
__export(matcherHint_exports, {
|
|
21
|
-
ExpectError: () => ExpectError,
|
|
22
|
-
isJestError: () => isJestError
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(matcherHint_exports);
|
|
25
|
-
var import_utils = require("playwright-core/lib/utils");
|
|
26
|
-
class ExpectError extends Error {
|
|
27
|
-
constructor(jestError, customMessage, stackFrames) {
|
|
28
|
-
super("");
|
|
29
|
-
this.name = jestError.name;
|
|
30
|
-
this.message = jestError.message;
|
|
31
|
-
this.matcherResult = jestError.matcherResult;
|
|
32
|
-
if (customMessage)
|
|
33
|
-
this.message = customMessage + "\n\n" + this.message;
|
|
34
|
-
this.stack = this.name + ": " + this.message + "\n" + (0, import_utils.stringifyStackFrames)(stackFrames).join("\n");
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
function isJestError(e) {
|
|
38
|
-
return e instanceof Error && "matcherResult" in e && !!e.matcherResult;
|
|
39
|
-
}
|
|
40
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
41
|
-
0 && (module.exports = {
|
|
42
|
-
ExpectError,
|
|
43
|
-
isJestError
|
|
44
|
-
});
|