@one2x/playwright 1.57.0-alpha.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 (331) hide show
  1. package/LICENSE +202 -0
  2. package/NOTICE +5 -0
  3. package/README.md +168 -0
  4. package/ThirdPartyNotices.txt +6277 -0
  5. package/cli.js +19 -0
  6. package/index.d.ts +17 -0
  7. package/index.js +17 -0
  8. package/index.mjs +18 -0
  9. package/jsx-runtime.js +42 -0
  10. package/jsx-runtime.mjs +21 -0
  11. package/lib/agents/copilot-setup-steps.yml +34 -0
  12. package/lib/agents/generateAgents.js +394 -0
  13. package/lib/agents/generateAgents.js.map +7 -0
  14. package/lib/agents/playwright-test-coverage.prompt.md +31 -0
  15. package/lib/agents/playwright-test-generate.prompt.md +8 -0
  16. package/lib/agents/playwright-test-generator.agent.md +88 -0
  17. package/lib/agents/playwright-test-heal.prompt.md +6 -0
  18. package/lib/agents/playwright-test-healer.agent.md +55 -0
  19. package/lib/agents/playwright-test-plan.prompt.md +9 -0
  20. package/lib/agents/playwright-test-planner.agent.md +117 -0
  21. package/lib/common/config.js +280 -0
  22. package/lib/common/config.js.map +7 -0
  23. package/lib/common/configLoader.js +344 -0
  24. package/lib/common/configLoader.js.map +7 -0
  25. package/lib/common/esmLoaderHost.js +102 -0
  26. package/lib/common/esmLoaderHost.js.map +7 -0
  27. package/lib/common/expectBundle.js +52 -0
  28. package/lib/common/expectBundle.js.map +7 -0
  29. package/lib/common/expectBundleImpl.js +389 -0
  30. package/lib/common/expectBundleImpl.js.map +7 -0
  31. package/lib/common/fixtures.js +302 -0
  32. package/lib/common/fixtures.js.map +7 -0
  33. package/lib/common/globals.js +58 -0
  34. package/lib/common/globals.js.map +7 -0
  35. package/lib/common/ipc.js +60 -0
  36. package/lib/common/ipc.js.map +7 -0
  37. package/lib/common/poolBuilder.js +85 -0
  38. package/lib/common/poolBuilder.js.map +7 -0
  39. package/lib/common/process.js +104 -0
  40. package/lib/common/process.js.map +7 -0
  41. package/lib/common/suiteUtils.js +140 -0
  42. package/lib/common/suiteUtils.js.map +7 -0
  43. package/lib/common/test.js +321 -0
  44. package/lib/common/test.js.map +7 -0
  45. package/lib/common/testLoader.js +101 -0
  46. package/lib/common/testLoader.js.map +7 -0
  47. package/lib/common/testType.js +298 -0
  48. package/lib/common/testType.js.map +7 -0
  49. package/lib/common/validators.js +68 -0
  50. package/lib/common/validators.js.map +7 -0
  51. package/lib/fsWatcher.js +67 -0
  52. package/lib/fsWatcher.js.map +7 -0
  53. package/lib/index.js +682 -0
  54. package/lib/index.js.map +7 -0
  55. package/lib/internalsForTest.js +42 -0
  56. package/lib/internalsForTest.js.map +7 -0
  57. package/lib/isomorphic/events.js +77 -0
  58. package/lib/isomorphic/events.js.map +7 -0
  59. package/lib/isomorphic/folders.js +30 -0
  60. package/lib/isomorphic/folders.js.map +7 -0
  61. package/lib/isomorphic/stringInternPool.js +69 -0
  62. package/lib/isomorphic/stringInternPool.js.map +7 -0
  63. package/lib/isomorphic/teleReceiver.js +508 -0
  64. package/lib/isomorphic/teleReceiver.js.map +7 -0
  65. package/lib/isomorphic/teleSuiteUpdater.js +137 -0
  66. package/lib/isomorphic/teleSuiteUpdater.js.map +7 -0
  67. package/lib/isomorphic/testServerConnection.js +211 -0
  68. package/lib/isomorphic/testServerConnection.js.map +7 -0
  69. package/lib/isomorphic/testServerInterface.js +16 -0
  70. package/lib/isomorphic/testServerInterface.js.map +7 -0
  71. package/lib/isomorphic/testTree.js +334 -0
  72. package/lib/isomorphic/testTree.js.map +7 -0
  73. package/lib/isomorphic/types.d.js +16 -0
  74. package/lib/isomorphic/types.d.js.map +7 -0
  75. package/lib/loader/loaderMain.js +59 -0
  76. package/lib/loader/loaderMain.js.map +7 -0
  77. package/lib/matchers/expect.js +325 -0
  78. package/lib/matchers/expect.js.map +7 -0
  79. package/lib/matchers/matcherHint.js +87 -0
  80. package/lib/matchers/matcherHint.js.map +7 -0
  81. package/lib/matchers/matchers.js +366 -0
  82. package/lib/matchers/matchers.js.map +7 -0
  83. package/lib/matchers/toBeTruthy.js +73 -0
  84. package/lib/matchers/toBeTruthy.js.map +7 -0
  85. package/lib/matchers/toEqual.js +99 -0
  86. package/lib/matchers/toEqual.js.map +7 -0
  87. package/lib/matchers/toHaveURL.js +102 -0
  88. package/lib/matchers/toHaveURL.js.map +7 -0
  89. package/lib/matchers/toMatchAriaSnapshot.js +159 -0
  90. package/lib/matchers/toMatchAriaSnapshot.js.map +7 -0
  91. package/lib/matchers/toMatchSnapshot.js +341 -0
  92. package/lib/matchers/toMatchSnapshot.js.map +7 -0
  93. package/lib/matchers/toMatchText.js +99 -0
  94. package/lib/matchers/toMatchText.js.map +7 -0
  95. package/lib/mcp/browser/actions.d.js +16 -0
  96. package/lib/mcp/browser/actions.d.js.map +7 -0
  97. package/lib/mcp/browser/browserContextFactory.js +357 -0
  98. package/lib/mcp/browser/browserContextFactory.js.map +7 -0
  99. package/lib/mcp/browser/browserServerBackend.js +76 -0
  100. package/lib/mcp/browser/browserServerBackend.js.map +7 -0
  101. package/lib/mcp/browser/codegen.js +66 -0
  102. package/lib/mcp/browser/codegen.js.map +7 -0
  103. package/lib/mcp/browser/config.js +425 -0
  104. package/lib/mcp/browser/config.js.map +7 -0
  105. package/lib/mcp/browser/context.js +287 -0
  106. package/lib/mcp/browser/context.js.map +7 -0
  107. package/lib/mcp/browser/response.js +228 -0
  108. package/lib/mcp/browser/response.js.map +7 -0
  109. package/lib/mcp/browser/sessionLog.js +160 -0
  110. package/lib/mcp/browser/sessionLog.js.map +7 -0
  111. package/lib/mcp/browser/tab.js +280 -0
  112. package/lib/mcp/browser/tab.js.map +7 -0
  113. package/lib/mcp/browser/tools/actionRetry.js +40 -0
  114. package/lib/mcp/browser/tools/actionRetry.js.map +7 -0
  115. package/lib/mcp/browser/tools/common.js +63 -0
  116. package/lib/mcp/browser/tools/common.js.map +7 -0
  117. package/lib/mcp/browser/tools/console.js +44 -0
  118. package/lib/mcp/browser/tools/console.js.map +7 -0
  119. package/lib/mcp/browser/tools/dialogs.js +60 -0
  120. package/lib/mcp/browser/tools/dialogs.js.map +7 -0
  121. package/lib/mcp/browser/tools/evaluate.js +69 -0
  122. package/lib/mcp/browser/tools/evaluate.js.map +7 -0
  123. package/lib/mcp/browser/tools/files.js +58 -0
  124. package/lib/mcp/browser/tools/files.js.map +7 -0
  125. package/lib/mcp/browser/tools/form.js +79 -0
  126. package/lib/mcp/browser/tools/form.js.map +7 -0
  127. package/lib/mcp/browser/tools/install.js +69 -0
  128. package/lib/mcp/browser/tools/install.js.map +7 -0
  129. package/lib/mcp/browser/tools/keyboard.js +84 -0
  130. package/lib/mcp/browser/tools/keyboard.js.map +7 -0
  131. package/lib/mcp/browser/tools/mouse.js +107 -0
  132. package/lib/mcp/browser/tools/mouse.js.map +7 -0
  133. package/lib/mcp/browser/tools/navigate.js +62 -0
  134. package/lib/mcp/browser/tools/navigate.js.map +7 -0
  135. package/lib/mcp/browser/tools/network.js +54 -0
  136. package/lib/mcp/browser/tools/network.js.map +7 -0
  137. package/lib/mcp/browser/tools/pdf.js +59 -0
  138. package/lib/mcp/browser/tools/pdf.js.map +7 -0
  139. package/lib/mcp/browser/tools/screenshot.js +106 -0
  140. package/lib/mcp/browser/tools/screenshot.js.map +7 -0
  141. package/lib/mcp/browser/tools/snapshot.js +312 -0
  142. package/lib/mcp/browser/tools/snapshot.js.map +7 -0
  143. package/lib/mcp/browser/tools/tabs.js +67 -0
  144. package/lib/mcp/browser/tools/tabs.js.map +7 -0
  145. package/lib/mcp/browser/tools/tool.js +49 -0
  146. package/lib/mcp/browser/tools/tool.js.map +7 -0
  147. package/lib/mcp/browser/tools/tracing.js +74 -0
  148. package/lib/mcp/browser/tools/tracing.js.map +7 -0
  149. package/lib/mcp/browser/tools/utils.js +96 -0
  150. package/lib/mcp/browser/tools/utils.js.map +7 -0
  151. package/lib/mcp/browser/tools/verify.js +153 -0
  152. package/lib/mcp/browser/tools/verify.js.map +7 -0
  153. package/lib/mcp/browser/tools/wait.js +63 -0
  154. package/lib/mcp/browser/tools/wait.js.map +7 -0
  155. package/lib/mcp/browser/tools.js +80 -0
  156. package/lib/mcp/browser/tools.js.map +7 -0
  157. package/lib/mcp/browser/watchdog.js +44 -0
  158. package/lib/mcp/browser/watchdog.js.map +7 -0
  159. package/lib/mcp/config.d.js +16 -0
  160. package/lib/mcp/config.d.js.map +7 -0
  161. package/lib/mcp/extension/cdpRelay.js +351 -0
  162. package/lib/mcp/extension/cdpRelay.js.map +7 -0
  163. package/lib/mcp/extension/extensionContextFactory.js +75 -0
  164. package/lib/mcp/extension/extensionContextFactory.js.map +7 -0
  165. package/lib/mcp/extension/protocol.js +28 -0
  166. package/lib/mcp/extension/protocol.js.map +7 -0
  167. package/lib/mcp/index.js +61 -0
  168. package/lib/mcp/index.js.map +7 -0
  169. package/lib/mcp/log.js +35 -0
  170. package/lib/mcp/log.js.map +7 -0
  171. package/lib/mcp/program.js +118 -0
  172. package/lib/mcp/program.js.map +7 -0
  173. package/lib/mcp/sdk/bundle.js +81 -0
  174. package/lib/mcp/sdk/bundle.js.map +7 -0
  175. package/lib/mcp/sdk/exports.js +32 -0
  176. package/lib/mcp/sdk/exports.js.map +7 -0
  177. package/lib/mcp/sdk/http.js +276 -0
  178. package/lib/mcp/sdk/http.js.map +7 -0
  179. package/lib/mcp/sdk/inProcessTransport.js +71 -0
  180. package/lib/mcp/sdk/inProcessTransport.js.map +7 -0
  181. package/lib/mcp/sdk/mdb.js +208 -0
  182. package/lib/mcp/sdk/mdb.js.map +7 -0
  183. package/lib/mcp/sdk/proxyBackend.js +128 -0
  184. package/lib/mcp/sdk/proxyBackend.js.map +7 -0
  185. package/lib/mcp/sdk/server.js +190 -0
  186. package/lib/mcp/sdk/server.js.map +7 -0
  187. package/lib/mcp/sdk/tool.js +51 -0
  188. package/lib/mcp/sdk/tool.js.map +7 -0
  189. package/lib/mcp/test/browserBackend.js +98 -0
  190. package/lib/mcp/test/browserBackend.js.map +7 -0
  191. package/lib/mcp/test/generatorTools.js +122 -0
  192. package/lib/mcp/test/generatorTools.js.map +7 -0
  193. package/lib/mcp/test/plannerTools.js +46 -0
  194. package/lib/mcp/test/plannerTools.js.map +7 -0
  195. package/lib/mcp/test/seed.js +82 -0
  196. package/lib/mcp/test/seed.js.map +7 -0
  197. package/lib/mcp/test/streams.js +41 -0
  198. package/lib/mcp/test/streams.js.map +7 -0
  199. package/lib/mcp/test/testBackend.js +97 -0
  200. package/lib/mcp/test/testBackend.js.map +7 -0
  201. package/lib/mcp/test/testContext.js +216 -0
  202. package/lib/mcp/test/testContext.js.map +7 -0
  203. package/lib/mcp/test/testTool.js +30 -0
  204. package/lib/mcp/test/testTool.js.map +7 -0
  205. package/lib/mcp/test/testTools.js +111 -0
  206. package/lib/mcp/test/testTools.js.map +7 -0
  207. package/lib/mcpBundleImpl.js +41 -0
  208. package/lib/mcpBundleImpl.js.map +7 -0
  209. package/lib/plugins/gitCommitInfoPlugin.js +198 -0
  210. package/lib/plugins/gitCommitInfoPlugin.js.map +7 -0
  211. package/lib/plugins/index.js +28 -0
  212. package/lib/plugins/index.js.map +7 -0
  213. package/lib/plugins/webServerPlugin.js +233 -0
  214. package/lib/plugins/webServerPlugin.js.map +7 -0
  215. package/lib/program.js +412 -0
  216. package/lib/program.js.map +7 -0
  217. package/lib/reporters/base.js +609 -0
  218. package/lib/reporters/base.js.map +7 -0
  219. package/lib/reporters/blob.js +135 -0
  220. package/lib/reporters/blob.js.map +7 -0
  221. package/lib/reporters/dot.js +82 -0
  222. package/lib/reporters/dot.js.map +7 -0
  223. package/lib/reporters/empty.js +32 -0
  224. package/lib/reporters/empty.js.map +7 -0
  225. package/lib/reporters/github.js +128 -0
  226. package/lib/reporters/github.js.map +7 -0
  227. package/lib/reporters/html.js +623 -0
  228. package/lib/reporters/html.js.map +7 -0
  229. package/lib/reporters/internalReporter.js +130 -0
  230. package/lib/reporters/internalReporter.js.map +7 -0
  231. package/lib/reporters/json.js +254 -0
  232. package/lib/reporters/json.js.map +7 -0
  233. package/lib/reporters/junit.js +232 -0
  234. package/lib/reporters/junit.js.map +7 -0
  235. package/lib/reporters/line.js +113 -0
  236. package/lib/reporters/line.js.map +7 -0
  237. package/lib/reporters/list.js +231 -0
  238. package/lib/reporters/list.js.map +7 -0
  239. package/lib/reporters/listModeReporter.js +69 -0
  240. package/lib/reporters/listModeReporter.js.map +7 -0
  241. package/lib/reporters/markdown.js +144 -0
  242. package/lib/reporters/markdown.js.map +7 -0
  243. package/lib/reporters/merge.js +541 -0
  244. package/lib/reporters/merge.js.map +7 -0
  245. package/lib/reporters/multiplexer.js +104 -0
  246. package/lib/reporters/multiplexer.js.map +7 -0
  247. package/lib/reporters/reporterV2.js +102 -0
  248. package/lib/reporters/reporterV2.js.map +7 -0
  249. package/lib/reporters/teleEmitter.js +298 -0
  250. package/lib/reporters/teleEmitter.js.map +7 -0
  251. package/lib/reporters/versions/blobV1.js +16 -0
  252. package/lib/reporters/versions/blobV1.js.map +7 -0
  253. package/lib/runner/dispatcher.js +491 -0
  254. package/lib/runner/dispatcher.js.map +7 -0
  255. package/lib/runner/failureTracker.js +72 -0
  256. package/lib/runner/failureTracker.js.map +7 -0
  257. package/lib/runner/lastRun.js +77 -0
  258. package/lib/runner/lastRun.js.map +7 -0
  259. package/lib/runner/loadUtils.js +334 -0
  260. package/lib/runner/loadUtils.js.map +7 -0
  261. package/lib/runner/loaderHost.js +89 -0
  262. package/lib/runner/loaderHost.js.map +7 -0
  263. package/lib/runner/processHost.js +161 -0
  264. package/lib/runner/processHost.js.map +7 -0
  265. package/lib/runner/projectUtils.js +241 -0
  266. package/lib/runner/projectUtils.js.map +7 -0
  267. package/lib/runner/rebase.js +189 -0
  268. package/lib/runner/rebase.js.map +7 -0
  269. package/lib/runner/reporters.js +138 -0
  270. package/lib/runner/reporters.js.map +7 -0
  271. package/lib/runner/runner.js +110 -0
  272. package/lib/runner/sigIntWatcher.js +96 -0
  273. package/lib/runner/sigIntWatcher.js.map +7 -0
  274. package/lib/runner/taskRunner.js +127 -0
  275. package/lib/runner/taskRunner.js.map +7 -0
  276. package/lib/runner/tasks.js +410 -0
  277. package/lib/runner/tasks.js.map +7 -0
  278. package/lib/runner/testGroups.js +117 -0
  279. package/lib/runner/testGroups.js.map +7 -0
  280. package/lib/runner/testRunner.js +390 -0
  281. package/lib/runner/testRunner.js.map +7 -0
  282. package/lib/runner/testServer.js +267 -0
  283. package/lib/runner/testServer.js.map +7 -0
  284. package/lib/runner/uiModeReporter.js +30 -0
  285. package/lib/runner/uiModeReporter.js.map +7 -0
  286. package/lib/runner/vcs.js +72 -0
  287. package/lib/runner/vcs.js.map +7 -0
  288. package/lib/runner/watchMode.js +395 -0
  289. package/lib/runner/watchMode.js.map +7 -0
  290. package/lib/runner/workerHost.js +95 -0
  291. package/lib/runner/workerHost.js.map +7 -0
  292. package/lib/third_party/pirates.js +62 -0
  293. package/lib/third_party/pirates.js.map +7 -0
  294. package/lib/third_party/tsconfig-loader.js +103 -0
  295. package/lib/third_party/tsconfig-loader.js.map +7 -0
  296. package/lib/transform/babelBundle.js +43 -0
  297. package/lib/transform/babelBundle.js.map +7 -0
  298. package/lib/transform/babelBundleImpl.js +461 -0
  299. package/lib/transform/babelBundleImpl.js.map +7 -0
  300. package/lib/transform/compilationCache.js +272 -0
  301. package/lib/transform/compilationCache.js.map +7 -0
  302. package/lib/transform/esmLoader.js +104 -0
  303. package/lib/transform/esmLoader.js.map +7 -0
  304. package/lib/transform/portTransport.js +67 -0
  305. package/lib/transform/portTransport.js.map +7 -0
  306. package/lib/transform/transform.js +293 -0
  307. package/lib/transform/transform.js.map +7 -0
  308. package/lib/util.js +403 -0
  309. package/lib/util.js.map +7 -0
  310. package/lib/utilsBundle.js +43 -0
  311. package/lib/utilsBundle.js.map +7 -0
  312. package/lib/utilsBundleImpl.js +100 -0
  313. package/lib/utilsBundleImpl.js.map +7 -0
  314. package/lib/worker/fixtureRunner.js +258 -0
  315. package/lib/worker/fixtureRunner.js.map +7 -0
  316. package/lib/worker/testInfo.js +514 -0
  317. package/lib/worker/testInfo.js.map +7 -0
  318. package/lib/worker/testTracing.js +344 -0
  319. package/lib/worker/testTracing.js.map +7 -0
  320. package/lib/worker/timeoutManager.js +174 -0
  321. package/lib/worker/timeoutManager.js.map +7 -0
  322. package/lib/worker/util.js +31 -0
  323. package/lib/worker/util.js.map +7 -0
  324. package/lib/worker/workerMain.js +520 -0
  325. package/lib/worker/workerMain.js.map +7 -0
  326. package/package.json +74 -0
  327. package/test.d.ts +18 -0
  328. package/test.js +24 -0
  329. package/test.mjs +33 -0
  330. package/types/test.d.ts +10196 -0
  331. package/types/testReporter.d.ts +821 -0
@@ -0,0 +1,623 @@
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 html_exports = {};
30
+ __export(html_exports, {
31
+ default: () => html_default,
32
+ showHTMLReport: () => showHTMLReport,
33
+ startHtmlReportServer: () => startHtmlReportServer
34
+ });
35
+ module.exports = __toCommonJS(html_exports);
36
+ var import_fs = __toESM(require("fs"));
37
+ var import_path = __toESM(require("path"));
38
+ var import_stream = require("stream");
39
+ var import_utils = require("playwright-core/lib/utils");
40
+ var import_utils2 = require("playwright-core/lib/utils");
41
+ var import_utilsBundle = require("playwright-core/lib/utilsBundle");
42
+ var import_utilsBundle2 = require("playwright-core/lib/utilsBundle");
43
+ var import_zipBundle = require("playwright-core/lib/zipBundle");
44
+ var import_base = require("./base");
45
+ var import_babelBundle = require("../transform/babelBundle");
46
+ var import_util = require("../util");
47
+ const htmlReportOptions = ["always", "never", "on-failure"];
48
+ const isHtmlReportOption = (type) => {
49
+ return htmlReportOptions.includes(type);
50
+ };
51
+ class HtmlReporter {
52
+ constructor(options) {
53
+ this._topLevelErrors = [];
54
+ this._options = options;
55
+ }
56
+ version() {
57
+ return "v2";
58
+ }
59
+ printsToStdio() {
60
+ return false;
61
+ }
62
+ onConfigure(config) {
63
+ this.config = config;
64
+ }
65
+ onBegin(suite) {
66
+ const { outputFolder, open: open2, attachmentsBaseURL, host, port } = this._resolveOptions();
67
+ this._outputFolder = outputFolder;
68
+ this._open = open2;
69
+ this._host = host;
70
+ this._port = port;
71
+ this._attachmentsBaseURL = attachmentsBaseURL;
72
+ const reportedWarnings = /* @__PURE__ */ new Set();
73
+ for (const project of this.config.projects) {
74
+ if (this._isSubdirectory(outputFolder, project.outputDir) || this._isSubdirectory(project.outputDir, outputFolder)) {
75
+ const key = outputFolder + "|" + project.outputDir;
76
+ if (reportedWarnings.has(key))
77
+ continue;
78
+ reportedWarnings.add(key);
79
+ writeLine(import_utils2.colors.red(`Configuration Error: HTML reporter output folder clashes with the tests output folder:`));
80
+ writeLine(`
81
+ html reporter folder: ${import_utils2.colors.bold(outputFolder)}
82
+ test results folder: ${import_utils2.colors.bold(project.outputDir)}`);
83
+ writeLine("");
84
+ writeLine(`HTML reporter will clear its output directory prior to being generated, which will lead to the artifact loss.
85
+ `);
86
+ }
87
+ }
88
+ this.suite = suite;
89
+ }
90
+ _resolveOptions() {
91
+ const outputFolder = reportFolderFromEnv() ?? (0, import_util.resolveReporterOutputPath)("playwright-report", this._options.configDir, this._options.outputFolder);
92
+ return {
93
+ outputFolder,
94
+ open: getHtmlReportOptionProcessEnv() || this._options.open || "on-failure",
95
+ attachmentsBaseURL: process.env.PLAYWRIGHT_HTML_ATTACHMENTS_BASE_URL || this._options.attachmentsBaseURL || "data/",
96
+ host: process.env.PLAYWRIGHT_HTML_HOST || this._options.host,
97
+ port: process.env.PLAYWRIGHT_HTML_PORT ? +process.env.PLAYWRIGHT_HTML_PORT : this._options.port
98
+ };
99
+ }
100
+ _isSubdirectory(parentDir, dir) {
101
+ const relativePath = import_path.default.relative(parentDir, dir);
102
+ return !!relativePath && !relativePath.startsWith("..") && !import_path.default.isAbsolute(relativePath);
103
+ }
104
+ onError(error) {
105
+ this._topLevelErrors.push(error);
106
+ }
107
+ async onEnd(result) {
108
+ const projectSuites = this.suite.suites;
109
+ await (0, import_utils.removeFolders)([this._outputFolder]);
110
+ let noSnippets;
111
+ if (process.env.PLAYWRIGHT_HTML_NO_SNIPPETS === "false" || process.env.PLAYWRIGHT_HTML_NO_SNIPPETS === "0")
112
+ noSnippets = false;
113
+ else if (process.env.PLAYWRIGHT_HTML_NO_SNIPPETS)
114
+ noSnippets = true;
115
+ noSnippets = noSnippets || this._options.noSnippets;
116
+ let noCopyPrompt;
117
+ if (process.env.PLAYWRIGHT_HTML_NO_COPY_PROMPT === "false" || process.env.PLAYWRIGHT_HTML_NO_COPY_PROMPT === "0")
118
+ noCopyPrompt = false;
119
+ else if (process.env.PLAYWRIGHT_HTML_NO_COPY_PROMPT)
120
+ noCopyPrompt = true;
121
+ noCopyPrompt = noCopyPrompt || this._options.noCopyPrompt;
122
+ const builder = new HtmlBuilder(this.config, this._outputFolder, this._attachmentsBaseURL, {
123
+ title: process.env.PLAYWRIGHT_HTML_TITLE || this._options.title,
124
+ noSnippets,
125
+ noCopyPrompt
126
+ });
127
+ this._buildResult = await builder.build(this.config.metadata, projectSuites, result, this._topLevelErrors);
128
+ }
129
+ async onExit() {
130
+ if (process.env.CI || !this._buildResult)
131
+ return;
132
+ const { ok, singleTestId } = this._buildResult;
133
+ const shouldOpen = !!process.stdin.isTTY && (this._open === "always" || !ok && this._open === "on-failure");
134
+ if (shouldOpen) {
135
+ await showHTMLReport(this._outputFolder, this._host, this._port, singleTestId);
136
+ } else if (this._options._mode === "test" && !!process.stdin.isTTY) {
137
+ const packageManagerCommand = (0, import_utils.getPackageManagerExecCommand)();
138
+ const relativeReportPath = this._outputFolder === standaloneDefaultFolder() ? "" : " " + import_path.default.relative(process.cwd(), this._outputFolder);
139
+ const hostArg = this._host ? ` --host ${this._host}` : "";
140
+ const portArg = this._port ? ` --port ${this._port}` : "";
141
+ writeLine("");
142
+ writeLine("To open last HTML report run:");
143
+ writeLine(import_utils2.colors.cyan(`
144
+ ${packageManagerCommand} playwright show-report${relativeReportPath}${hostArg}${portArg}
145
+ `));
146
+ }
147
+ }
148
+ }
149
+ function reportFolderFromEnv() {
150
+ const envValue = process.env.PLAYWRIGHT_HTML_OUTPUT_DIR || process.env.PLAYWRIGHT_HTML_REPORT;
151
+ return envValue ? import_path.default.resolve(envValue) : void 0;
152
+ }
153
+ function getHtmlReportOptionProcessEnv() {
154
+ const htmlOpenEnv = process.env.PLAYWRIGHT_HTML_OPEN || process.env.PW_TEST_HTML_REPORT_OPEN;
155
+ if (!htmlOpenEnv)
156
+ return void 0;
157
+ if (!isHtmlReportOption(htmlOpenEnv)) {
158
+ writeLine(import_utils2.colors.red(`Configuration Error: HTML reporter Invalid value for PLAYWRIGHT_HTML_OPEN: ${htmlOpenEnv}. Valid values are: ${htmlReportOptions.join(", ")}`));
159
+ return void 0;
160
+ }
161
+ return htmlOpenEnv;
162
+ }
163
+ function standaloneDefaultFolder() {
164
+ return reportFolderFromEnv() ?? (0, import_util.resolveReporterOutputPath)("playwright-report", process.cwd(), void 0);
165
+ }
166
+ async function showHTMLReport(reportFolder, host = "localhost", port, testId) {
167
+ const folder = reportFolder ?? standaloneDefaultFolder();
168
+ try {
169
+ (0, import_utils.assert)(import_fs.default.statSync(folder).isDirectory());
170
+ } catch (e) {
171
+ writeLine(import_utils2.colors.red(`No report found at "${folder}"`));
172
+ (0, import_utils.gracefullyProcessExitDoNotHang)(1);
173
+ return;
174
+ }
175
+ const server = startHtmlReportServer(folder);
176
+ await server.start({ port, host, preferredPort: port ? void 0 : 9323 });
177
+ let url = server.urlPrefix("human-readable");
178
+ writeLine("");
179
+ writeLine(import_utils2.colors.cyan(` Serving HTML report at ${url}. Press Ctrl+C to quit.`));
180
+ if (testId)
181
+ url += `#?testId=${testId}`;
182
+ url = url.replace("0.0.0.0", "localhost");
183
+ await (0, import_utilsBundle.open)(url, { wait: true }).catch(() => {
184
+ });
185
+ await new Promise(() => {
186
+ });
187
+ }
188
+ function startHtmlReportServer(folder) {
189
+ const server = new import_utils.HttpServer();
190
+ server.routePrefix("/", (request, response) => {
191
+ let relativePath = new URL("http://localhost" + request.url).pathname;
192
+ if (relativePath.startsWith("/trace/file")) {
193
+ const url = new URL("http://localhost" + request.url);
194
+ try {
195
+ return server.serveFile(request, response, url.searchParams.get("path"));
196
+ } catch (e) {
197
+ return false;
198
+ }
199
+ }
200
+ if (relativePath === "/")
201
+ relativePath = "/index.html";
202
+ const absolutePath = import_path.default.join(folder, ...relativePath.split("/"));
203
+ return server.serveFile(request, response, absolutePath);
204
+ });
205
+ return server;
206
+ }
207
+ class HtmlBuilder {
208
+ constructor(config, outputDir, attachmentsBaseURL, options) {
209
+ this._stepsInFile = new import_utils.MultiMap();
210
+ this._hasTraces = false;
211
+ this._config = config;
212
+ this._reportFolder = outputDir;
213
+ this._options = options;
214
+ import_fs.default.mkdirSync(this._reportFolder, { recursive: true });
215
+ this._dataZipFile = new import_zipBundle.yazl.ZipFile();
216
+ this._attachmentsBaseURL = attachmentsBaseURL;
217
+ }
218
+ async build(metadata, projectSuites, result, topLevelErrors) {
219
+ const data = /* @__PURE__ */ new Map();
220
+ for (const projectSuite of projectSuites) {
221
+ const projectName = projectSuite.project().name;
222
+ for (const fileSuite of projectSuite.suites) {
223
+ const fileName = this._relativeLocation(fileSuite.location).file;
224
+ this._createEntryForSuite(data, projectName, fileSuite, fileName, true);
225
+ }
226
+ }
227
+ if (!this._options.noSnippets)
228
+ createSnippets(this._stepsInFile);
229
+ let ok = true;
230
+ for (const [fileId, { testFile, testFileSummary }] of data) {
231
+ const stats = testFileSummary.stats;
232
+ for (const test of testFileSummary.tests) {
233
+ if (test.outcome === "expected")
234
+ ++stats.expected;
235
+ if (test.outcome === "skipped")
236
+ ++stats.skipped;
237
+ if (test.outcome === "unexpected")
238
+ ++stats.unexpected;
239
+ if (test.outcome === "flaky")
240
+ ++stats.flaky;
241
+ ++stats.total;
242
+ }
243
+ stats.ok = stats.unexpected + stats.flaky === 0;
244
+ if (!stats.ok)
245
+ ok = false;
246
+ const testCaseSummaryComparator = (t1, t2) => {
247
+ const w1 = (t1.outcome === "unexpected" ? 1e3 : 0) + (t1.outcome === "flaky" ? 1 : 0);
248
+ const w2 = (t2.outcome === "unexpected" ? 1e3 : 0) + (t2.outcome === "flaky" ? 1 : 0);
249
+ return w2 - w1;
250
+ };
251
+ testFileSummary.tests.sort(testCaseSummaryComparator);
252
+ this._addDataFile(fileId + ".json", testFile);
253
+ }
254
+ const htmlReport = {
255
+ metadata,
256
+ startTime: result.startTime.getTime(),
257
+ duration: result.duration,
258
+ files: [...data.values()].map((e) => e.testFileSummary),
259
+ projectNames: projectSuites.map((r) => r.project().name),
260
+ stats: { ...[...data.values()].reduce((a, e) => addStats(a, e.testFileSummary.stats), emptyStats()) },
261
+ errors: topLevelErrors.map((error) => (0, import_base.formatError)(import_base.internalScreen, error).message),
262
+ options: this._options
263
+ };
264
+ htmlReport.files.sort((f1, f2) => {
265
+ const w1 = f1.stats.unexpected * 1e3 + f1.stats.flaky;
266
+ const w2 = f2.stats.unexpected * 1e3 + f2.stats.flaky;
267
+ return w2 - w1;
268
+ });
269
+ this._addDataFile("report.json", htmlReport);
270
+ let singleTestId;
271
+ if (htmlReport.stats.total === 1) {
272
+ const testFile = data.values().next().value.testFile;
273
+ singleTestId = testFile.tests[0].testId;
274
+ }
275
+ const appFolder = import_path.default.join(require.resolve("playwright-core"), "..", "lib", "vite", "htmlReport");
276
+ await (0, import_utils.copyFileAndMakeWritable)(import_path.default.join(appFolder, "index.html"), import_path.default.join(this._reportFolder, "index.html"));
277
+ if (this._hasTraces) {
278
+ const traceViewerFolder = import_path.default.join(require.resolve("playwright-core"), "..", "lib", "vite", "traceViewer");
279
+ const traceViewerTargetFolder = import_path.default.join(this._reportFolder, "trace");
280
+ const traceViewerAssetsTargetFolder = import_path.default.join(traceViewerTargetFolder, "assets");
281
+ import_fs.default.mkdirSync(traceViewerAssetsTargetFolder, { recursive: true });
282
+ for (const file of import_fs.default.readdirSync(traceViewerFolder)) {
283
+ if (file.endsWith(".map") || file.includes("watch") || file.includes("assets"))
284
+ continue;
285
+ await (0, import_utils.copyFileAndMakeWritable)(import_path.default.join(traceViewerFolder, file), import_path.default.join(traceViewerTargetFolder, file));
286
+ }
287
+ for (const file of import_fs.default.readdirSync(import_path.default.join(traceViewerFolder, "assets"))) {
288
+ if (file.endsWith(".map") || file.includes("xtermModule"))
289
+ continue;
290
+ await (0, import_utils.copyFileAndMakeWritable)(import_path.default.join(traceViewerFolder, "assets", file), import_path.default.join(traceViewerAssetsTargetFolder, file));
291
+ }
292
+ }
293
+ await this._writeReportData(import_path.default.join(this._reportFolder, "index.html"));
294
+ return { ok, singleTestId };
295
+ }
296
+ async _writeReportData(filePath) {
297
+ import_fs.default.appendFileSync(filePath, '<script id="playwrightReportBase64" type="application/zip">data:application/zip;base64,');
298
+ await new Promise((f) => {
299
+ this._dataZipFile.end(void 0, () => {
300
+ this._dataZipFile.outputStream.pipe(new Base64Encoder()).pipe(import_fs.default.createWriteStream(filePath, { flags: "a" })).on("close", f);
301
+ });
302
+ });
303
+ import_fs.default.appendFileSync(filePath, "</script>");
304
+ }
305
+ _addDataFile(fileName, data) {
306
+ this._dataZipFile.addBuffer(Buffer.from(JSON.stringify(data)), fileName);
307
+ }
308
+ _createEntryForSuite(data, projectName, suite, fileName, deep) {
309
+ const fileId = (0, import_utils.calculateSha1)(fileName).slice(0, 20);
310
+ let fileEntry = data.get(fileId);
311
+ if (!fileEntry) {
312
+ fileEntry = {
313
+ testFile: { fileId, fileName, tests: [] },
314
+ testFileSummary: { fileId, fileName, tests: [], stats: emptyStats() }
315
+ };
316
+ data.set(fileId, fileEntry);
317
+ }
318
+ const { testFile, testFileSummary } = fileEntry;
319
+ const testEntries = [];
320
+ this._processSuite(suite, projectName, [], deep, testEntries);
321
+ for (const test of testEntries) {
322
+ testFile.tests.push(test.testCase);
323
+ testFileSummary.tests.push(test.testCaseSummary);
324
+ }
325
+ }
326
+ _processSuite(suite, projectName, path2, deep, outTests) {
327
+ const newPath = [...path2, suite.title];
328
+ suite.entries().forEach((e) => {
329
+ if (e.type === "test")
330
+ outTests.push(this._createTestEntry(e, projectName, newPath));
331
+ else if (deep)
332
+ this._processSuite(e, projectName, newPath, deep, outTests);
333
+ });
334
+ }
335
+ _createTestEntry(test, projectName, path2) {
336
+ const duration = test.results.reduce((a, r) => a + r.duration, 0);
337
+ const location = this._relativeLocation(test.location);
338
+ path2 = path2.slice(1).filter((path3) => path3.length > 0);
339
+ const results = test.results.map((r) => this._createTestResult(test, r));
340
+ return {
341
+ testCase: {
342
+ testId: test.id,
343
+ title: test.title,
344
+ projectName,
345
+ location,
346
+ duration,
347
+ annotations: this._serializeAnnotations(test.annotations),
348
+ tags: test.tags,
349
+ outcome: test.outcome(),
350
+ path: path2,
351
+ results,
352
+ ok: test.outcome() === "expected" || test.outcome() === "flaky"
353
+ },
354
+ testCaseSummary: {
355
+ testId: test.id,
356
+ title: test.title,
357
+ projectName,
358
+ location,
359
+ duration,
360
+ annotations: this._serializeAnnotations(test.annotations),
361
+ tags: test.tags,
362
+ outcome: test.outcome(),
363
+ path: path2,
364
+ ok: test.outcome() === "expected" || test.outcome() === "flaky",
365
+ results: results.map((result) => {
366
+ return { attachments: result.attachments.map((a) => ({ name: a.name, contentType: a.contentType, path: a.path })) };
367
+ })
368
+ }
369
+ };
370
+ }
371
+ _serializeAttachments(attachments) {
372
+ let lastAttachment;
373
+ return attachments.map((a) => {
374
+ if (a.name === "trace")
375
+ this._hasTraces = true;
376
+ if ((a.name === "stdout" || a.name === "stderr") && a.contentType === "text/plain") {
377
+ if (lastAttachment && lastAttachment.name === a.name && lastAttachment.contentType === a.contentType) {
378
+ lastAttachment.body += (0, import_util.stripAnsiEscapes)(a.body);
379
+ return null;
380
+ }
381
+ a.body = (0, import_util.stripAnsiEscapes)(a.body);
382
+ lastAttachment = a;
383
+ return a;
384
+ }
385
+ if (a.path) {
386
+ let fileName = a.path;
387
+ try {
388
+ const buffer = import_fs.default.readFileSync(a.path);
389
+ const sha1 = (0, import_utils.calculateSha1)(buffer) + import_path.default.extname(a.path);
390
+ fileName = this._attachmentsBaseURL + sha1;
391
+ import_fs.default.mkdirSync(import_path.default.join(this._reportFolder, "data"), { recursive: true });
392
+ import_fs.default.writeFileSync(import_path.default.join(this._reportFolder, "data", sha1), buffer);
393
+ } catch (e) {
394
+ }
395
+ return {
396
+ name: a.name,
397
+ contentType: a.contentType,
398
+ path: fileName,
399
+ body: a.body
400
+ };
401
+ }
402
+ if (a.body instanceof Buffer) {
403
+ if (isTextContentType(a.contentType)) {
404
+ const charset = a.contentType.match(/charset=(.*)/)?.[1];
405
+ try {
406
+ const body = a.body.toString(charset || "utf-8");
407
+ return {
408
+ name: a.name,
409
+ contentType: a.contentType,
410
+ body
411
+ };
412
+ } catch (e) {
413
+ }
414
+ }
415
+ import_fs.default.mkdirSync(import_path.default.join(this._reportFolder, "data"), { recursive: true });
416
+ const extension = (0, import_utils.sanitizeForFilePath)(import_path.default.extname(a.name).replace(/^\./, "")) || import_utilsBundle2.mime.getExtension(a.contentType) || "dat";
417
+ const sha1 = (0, import_utils.calculateSha1)(a.body) + "." + extension;
418
+ import_fs.default.writeFileSync(import_path.default.join(this._reportFolder, "data", sha1), a.body);
419
+ return {
420
+ name: a.name,
421
+ contentType: a.contentType,
422
+ path: this._attachmentsBaseURL + sha1
423
+ };
424
+ }
425
+ return {
426
+ name: a.name,
427
+ contentType: a.contentType,
428
+ body: a.body
429
+ };
430
+ }).filter(Boolean);
431
+ }
432
+ _serializeAnnotations(annotations) {
433
+ return annotations.map((a) => ({
434
+ type: a.type,
435
+ description: a.description === void 0 ? void 0 : String(a.description),
436
+ location: a.location ? {
437
+ file: a.location.file,
438
+ line: a.location.line,
439
+ column: a.location.column
440
+ } : void 0
441
+ }));
442
+ }
443
+ _createTestResult(test, result) {
444
+ return {
445
+ duration: result.duration,
446
+ startTime: result.startTime.toISOString(),
447
+ retry: result.retry,
448
+ steps: dedupeSteps(result.steps).map((s) => this._createTestStep(s, result)),
449
+ errors: (0, import_base.formatResultFailure)(import_base.internalScreen, test, result, "").map((error) => {
450
+ return {
451
+ message: error.message,
452
+ codeframe: error.location ? createErrorCodeframe(error.message, error.location) : void 0
453
+ };
454
+ }),
455
+ status: result.status,
456
+ annotations: this._serializeAnnotations(result.annotations),
457
+ attachments: this._serializeAttachments([
458
+ ...result.attachments,
459
+ ...result.stdout.map((m) => stdioAttachment(m, "stdout")),
460
+ ...result.stderr.map((m) => stdioAttachment(m, "stderr"))
461
+ ])
462
+ };
463
+ }
464
+ _createTestStep(dedupedStep, result) {
465
+ const { step, duration, count } = dedupedStep;
466
+ const skipped = dedupedStep.step.annotations?.find((a) => a.type === "skip");
467
+ let title = step.title;
468
+ if (skipped)
469
+ title = `${title} (skipped${skipped.description ? ": " + skipped.description : ""})`;
470
+ const testStep = {
471
+ title,
472
+ startTime: step.startTime.toISOString(),
473
+ duration,
474
+ steps: dedupeSteps(step.steps).map((s) => this._createTestStep(s, result)),
475
+ attachments: step.attachments.map((s) => {
476
+ const index = result.attachments.indexOf(s);
477
+ if (index === -1)
478
+ throw new Error("Unexpected, attachment not found");
479
+ return index;
480
+ }),
481
+ location: this._relativeLocation(step.location),
482
+ error: step.error?.message,
483
+ count,
484
+ skipped: !!skipped
485
+ };
486
+ if (step.location)
487
+ this._stepsInFile.set(step.location.file, testStep);
488
+ return testStep;
489
+ }
490
+ _relativeLocation(location) {
491
+ if (!location)
492
+ return void 0;
493
+ const file = (0, import_utils.toPosixPath)(import_path.default.relative(this._config.rootDir, location.file));
494
+ return {
495
+ file,
496
+ line: location.line,
497
+ column: location.column
498
+ };
499
+ }
500
+ }
501
+ const emptyStats = () => {
502
+ return {
503
+ total: 0,
504
+ expected: 0,
505
+ unexpected: 0,
506
+ flaky: 0,
507
+ skipped: 0,
508
+ ok: true
509
+ };
510
+ };
511
+ const addStats = (stats, delta) => {
512
+ stats.total += delta.total;
513
+ stats.skipped += delta.skipped;
514
+ stats.expected += delta.expected;
515
+ stats.unexpected += delta.unexpected;
516
+ stats.flaky += delta.flaky;
517
+ stats.ok = stats.ok && delta.ok;
518
+ return stats;
519
+ };
520
+ class Base64Encoder extends import_stream.Transform {
521
+ _transform(chunk, encoding, callback) {
522
+ if (this._remainder) {
523
+ chunk = Buffer.concat([this._remainder, chunk]);
524
+ this._remainder = void 0;
525
+ }
526
+ const remaining = chunk.length % 3;
527
+ if (remaining) {
528
+ this._remainder = chunk.slice(chunk.length - remaining);
529
+ chunk = chunk.slice(0, chunk.length - remaining);
530
+ }
531
+ chunk = chunk.toString("base64");
532
+ this.push(Buffer.from(chunk));
533
+ callback();
534
+ }
535
+ _flush(callback) {
536
+ if (this._remainder)
537
+ this.push(Buffer.from(this._remainder.toString("base64")));
538
+ callback();
539
+ }
540
+ }
541
+ function isTextContentType(contentType) {
542
+ return contentType.startsWith("text/") || contentType.startsWith("application/json");
543
+ }
544
+ function stdioAttachment(chunk, type) {
545
+ return {
546
+ name: type,
547
+ contentType: "text/plain",
548
+ body: typeof chunk === "string" ? chunk : chunk.toString("utf-8")
549
+ };
550
+ }
551
+ function dedupeSteps(steps) {
552
+ const result = [];
553
+ let lastResult = void 0;
554
+ for (const step of steps) {
555
+ const canDedupe = !step.error && step.duration >= 0 && step.location?.file && !step.steps.length;
556
+ const lastStep = lastResult?.step;
557
+ if (canDedupe && lastResult && lastStep && step.category === lastStep.category && step.title === lastStep.title && step.location?.file === lastStep.location?.file && step.location?.line === lastStep.location?.line && step.location?.column === lastStep.location?.column) {
558
+ ++lastResult.count;
559
+ lastResult.duration += step.duration;
560
+ continue;
561
+ }
562
+ lastResult = { step, count: 1, duration: step.duration };
563
+ result.push(lastResult);
564
+ if (!canDedupe)
565
+ lastResult = void 0;
566
+ }
567
+ return result;
568
+ }
569
+ function createSnippets(stepsInFile) {
570
+ for (const file of stepsInFile.keys()) {
571
+ let source;
572
+ try {
573
+ source = import_fs.default.readFileSync(file, "utf-8") + "\n//";
574
+ } catch (e) {
575
+ continue;
576
+ }
577
+ const lines = source.split("\n").length;
578
+ const highlighted = (0, import_babelBundle.codeFrameColumns)(source, { start: { line: lines, column: 1 } }, { highlightCode: true, linesAbove: lines, linesBelow: 0 });
579
+ const highlightedLines = highlighted.split("\n");
580
+ const lineWithArrow = highlightedLines[highlightedLines.length - 1];
581
+ for (const step of stepsInFile.get(file)) {
582
+ if (step.location.line < 2 || step.location.line >= lines)
583
+ continue;
584
+ const snippetLines = highlightedLines.slice(step.location.line - 2, step.location.line + 1);
585
+ const index = lineWithArrow.indexOf("^");
586
+ const shiftedArrow = lineWithArrow.slice(0, index) + " ".repeat(step.location.column - 1) + lineWithArrow.slice(index);
587
+ snippetLines.splice(2, 0, shiftedArrow);
588
+ step.snippet = snippetLines.join("\n");
589
+ }
590
+ }
591
+ }
592
+ function createErrorCodeframe(message, location) {
593
+ let source;
594
+ try {
595
+ source = import_fs.default.readFileSync(location.file, "utf-8") + "\n//";
596
+ } catch (e) {
597
+ return;
598
+ }
599
+ return (0, import_babelBundle.codeFrameColumns)(
600
+ source,
601
+ {
602
+ start: {
603
+ line: location.line,
604
+ column: location.column
605
+ }
606
+ },
607
+ {
608
+ highlightCode: false,
609
+ linesAbove: 100,
610
+ linesBelow: 100,
611
+ message: (0, import_util.stripAnsiEscapes)(message).split("\n")[0] || void 0
612
+ }
613
+ );
614
+ }
615
+ function writeLine(line) {
616
+ process.stdout.write(line + "\n");
617
+ }
618
+ var html_default = HtmlReporter;
619
+ // Annotate the CommonJS export names for ESM import in node:
620
+ 0 && (module.exports = {
621
+ showHTMLReport,
622
+ startHtmlReportServer
623
+ });