@smoothdeploy/playwright-core 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 +7 -4070
- package/browsers.json +16 -14
- package/cli.js +4 -1
- package/index.js +1 -1
- package/lib/bootstrap.js +77 -0
- package/lib/coreBundle.js +70057 -0
- package/lib/entry/cliDaemon.js +5 -0
- package/lib/entry/dashboardApp.js +3 -0
- package/lib/entry/mcp.js +10 -0
- package/lib/entry/oopBrowserDownload.js +3 -0
- package/lib/{server/deviceDescriptors.js → package.js} +18 -7
- package/lib/server/deviceDescriptorsSource.json +137 -137
- package/lib/server/electron/loader.js +99 -13
- package/lib/serverRegistry.js +7343 -0
- package/lib/serverRegistry.js.LICENSE +354 -0
- package/lib/tools/cli-client/channelSessions.js +141 -0
- package/lib/tools/cli-client/cli.js +6 -0
- package/lib/tools/cli-client/help.json +679 -0
- package/lib/tools/cli-client/minimist.js +128 -0
- package/lib/tools/cli-client/output.js +343 -0
- package/lib/tools/cli-client/program.js +380 -0
- package/lib/tools/cli-client/registry.js +176 -0
- package/lib/tools/cli-client/session.js +265 -0
- package/lib/tools/cli-client/skill/SKILL.md +388 -0
- package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
- package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
- package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
- package/lib/tools/cli-client/skill/references/running-code.md +241 -0
- package/lib/tools/cli-client/skill/references/session-management.md +225 -0
- package/lib/tools/cli-client/skill/references/spec-driven-testing.md +305 -0
- package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
- package/lib/tools/cli-client/skill/references/test-generation.md +134 -0
- package/lib/tools/cli-client/skill/references/tracing.md +139 -0
- package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
- package/lib/tools/dashboard/appIcon.png +0 -0
- package/lib/tools/trace/SKILL.md +171 -0
- package/lib/{server/utils/profiler.js → tools/utils/extension.js} +42 -29
- package/lib/tools/utils/socketConnection.js +108 -0
- package/lib/utilsBundle.js +85377 -68
- package/lib/utilsBundle.js.LICENSE +2002 -0
- package/lib/vite/dashboard/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/dashboard/assets/firefox-1bWoP6pv.svg +1 -0
- package/lib/vite/dashboard/assets/firefox-beta-k3eOH_eK.svg +1 -0
- package/lib/vite/dashboard/assets/firefox-nightly-Cp5nfeDT.svg +1 -0
- package/lib/vite/dashboard/assets/index-BY2S1tHT.css +1 -0
- package/lib/vite/dashboard/assets/index-DpEq2p62.js +52 -0
- package/lib/vite/dashboard/assets/safari-na3_-uQk.svg +1 -0
- package/lib/vite/dashboard/index.html +29 -0
- package/lib/vite/dashboard/playwright-logo.svg +24 -0
- package/lib/vite/htmlReport/index.html +2 -70
- package/lib/vite/htmlReport/report.css +1 -0
- package/lib/vite/htmlReport/report.js +72 -0
- package/lib/vite/recorder/assets/{codeMirrorModule-SGmxtuwi.js → codeMirrorModule-DyIpd_mA.js} +20 -20
- package/lib/vite/recorder/assets/index-4ZiSSCmn.css +1 -0
- package/lib/vite/recorder/assets/index-5q9Mg4LR.js +195 -0
- package/lib/vite/recorder/index.html +2 -2
- package/lib/vite/traceViewer/assets/{codeMirrorModule-BOUrQdmH.js → codeMirrorModule-DZq9EItR.js} +20 -20
- package/lib/vite/traceViewer/assets/defaultSettingsView-D4EpQvB-.js +262 -0
- package/lib/vite/traceViewer/assets/urlMatch-BYQrIQwR.js +1 -0
- package/lib/vite/traceViewer/defaultSettingsView.BDKsFU3c.css +1 -0
- package/lib/vite/traceViewer/index.CcoKXsOB.js +2 -0
- package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
- package/lib/vite/traceViewer/index.html +5 -4
- package/lib/vite/traceViewer/snapshot.html +4 -15
- package/lib/vite/traceViewer/snapshot.v8KI4P3m.js +2 -0
- package/lib/vite/traceViewer/sw.bundle.js +4 -4
- package/lib/vite/traceViewer/uiMode.B1W9rAxj.js +6 -0
- package/lib/vite/traceViewer/uiMode.html +4 -3
- package/package.json +4 -14
- package/types/protocol.d.ts +1084 -343
- package/types/types.d.ts +6035 -4360
- package/lib/androidServerImpl.js +0 -65
- package/lib/browserServerImpl.js +0 -120
- package/lib/cli/driver.js +0 -97
- package/lib/cli/program.js +0 -589
- package/lib/cli/programWithTestStub.js +0 -74
- package/lib/client/android.js +0 -361
- package/lib/client/api.js +0 -137
- package/lib/client/artifact.js +0 -79
- package/lib/client/browser.js +0 -161
- package/lib/client/browserContext.js +0 -582
- package/lib/client/browserType.js +0 -185
- package/lib/client/cdpSession.js +0 -51
- package/lib/client/channelOwner.js +0 -195
- package/lib/client/clientHelper.js +0 -64
- package/lib/client/clientInstrumentation.js +0 -65
- package/lib/client/clientStackTrace.js +0 -69
- package/lib/client/clock.js +0 -68
- package/lib/client/connection.js +0 -318
- package/lib/client/consoleMessage.js +0 -58
- package/lib/client/coverage.js +0 -44
- package/lib/client/dialog.js +0 -56
- package/lib/client/download.js +0 -62
- package/lib/client/electron.js +0 -138
- package/lib/client/elementHandle.js +0 -284
- package/lib/client/errors.js +0 -77
- package/lib/client/eventEmitter.js +0 -314
- package/lib/client/events.js +0 -103
- package/lib/client/fetch.js +0 -368
- package/lib/client/fileChooser.js +0 -46
- package/lib/client/fileUtils.js +0 -34
- package/lib/client/frame.js +0 -409
- package/lib/client/harRouter.js +0 -87
- package/lib/client/input.js +0 -84
- package/lib/client/jsHandle.js +0 -109
- package/lib/client/jsonPipe.js +0 -39
- package/lib/client/localUtils.js +0 -60
- package/lib/client/locator.js +0 -369
- package/lib/client/network.js +0 -747
- package/lib/client/page.js +0 -745
- package/lib/client/pageAgent.js +0 -64
- package/lib/client/platform.js +0 -77
- package/lib/client/playwright.js +0 -71
- package/lib/client/selectors.js +0 -55
- package/lib/client/stream.js +0 -39
- package/lib/client/timeoutSettings.js +0 -79
- package/lib/client/tracing.js +0 -119
- package/lib/client/types.js +0 -28
- package/lib/client/video.js +0 -59
- package/lib/client/waiter.js +0 -142
- package/lib/client/webError.js +0 -39
- package/lib/client/webSocket.js +0 -93
- package/lib/client/worker.js +0 -85
- package/lib/client/writableStream.js +0 -39
- package/lib/generated/bindingsControllerSource.js +0 -28
- package/lib/generated/clockSource.js +0 -28
- package/lib/generated/injectedScriptSource.js +0 -28
- package/lib/generated/pollingRecorderSource.js +0 -28
- package/lib/generated/storageScriptSource.js +0 -28
- package/lib/generated/utilityScriptSource.js +0 -28
- package/lib/generated/webSocketMockSource.js +0 -336
- package/lib/inProcessFactory.js +0 -60
- package/lib/inprocess.js +0 -3
- package/lib/mcpBundle.js +0 -84
- package/lib/mcpBundleImpl/index.js +0 -147
- package/lib/outofprocess.js +0 -76
- package/lib/protocol/serializers.js +0 -197
- package/lib/protocol/validator.js +0 -3023
- package/lib/protocol/validatorPrimitives.js +0 -193
- package/lib/remote/playwrightConnection.js +0 -129
- package/lib/remote/playwrightServer.js +0 -334
- package/lib/server/agent/actionRunner.js +0 -335
- package/lib/server/agent/actions.js +0 -128
- package/lib/server/agent/codegen.js +0 -111
- package/lib/server/agent/context.js +0 -150
- package/lib/server/agent/expectTools.js +0 -156
- package/lib/server/agent/pageAgent.js +0 -204
- package/lib/server/agent/performTools.js +0 -262
- package/lib/server/agent/tool.js +0 -109
- package/lib/server/android/android.js +0 -465
- package/lib/server/android/backendAdb.js +0 -177
- package/lib/server/artifact.js +0 -127
- package/lib/server/bidi/bidiBrowser.js +0 -549
- package/lib/server/bidi/bidiChromium.js +0 -149
- package/lib/server/bidi/bidiConnection.js +0 -213
- package/lib/server/bidi/bidiDeserializer.js +0 -116
- package/lib/server/bidi/bidiExecutionContext.js +0 -267
- package/lib/server/bidi/bidiFirefox.js +0 -128
- package/lib/server/bidi/bidiInput.js +0 -146
- package/lib/server/bidi/bidiNetworkManager.js +0 -383
- package/lib/server/bidi/bidiOverCdp.js +0 -102
- package/lib/server/bidi/bidiPage.js +0 -583
- package/lib/server/bidi/bidiPdf.js +0 -106
- package/lib/server/bidi/third_party/bidiCommands.d.js +0 -22
- package/lib/server/bidi/third_party/bidiKeyboard.js +0 -256
- package/lib/server/bidi/third_party/bidiProtocol.js +0 -24
- package/lib/server/bidi/third_party/bidiProtocolCore.js +0 -180
- package/lib/server/bidi/third_party/bidiProtocolPermissions.js +0 -42
- package/lib/server/bidi/third_party/bidiSerializer.js +0 -148
- package/lib/server/bidi/third_party/firefoxPrefs.js +0 -259
- package/lib/server/browser.js +0 -149
- package/lib/server/browserContext.js +0 -700
- package/lib/server/browserType.js +0 -336
- package/lib/server/callLog.js +0 -82
- package/lib/server/chromium/chromium.js +0 -397
- package/lib/server/chromium/chromiumSwitches.js +0 -104
- package/lib/server/chromium/crBrowser.js +0 -520
- package/lib/server/chromium/crConnection.js +0 -197
- package/lib/server/chromium/crCoverage.js +0 -235
- package/lib/server/chromium/crDevTools.js +0 -111
- package/lib/server/chromium/crDragDrop.js +0 -131
- package/lib/server/chromium/crExecutionContext.js +0 -146
- package/lib/server/chromium/crInput.js +0 -187
- package/lib/server/chromium/crNetworkManager.js +0 -707
- package/lib/server/chromium/crPage.js +0 -1001
- package/lib/server/chromium/crPdf.js +0 -121
- package/lib/server/chromium/crProtocolHelper.js +0 -145
- package/lib/server/chromium/crServiceWorker.js +0 -136
- package/lib/server/chromium/defaultFontFamilies.js +0 -162
- package/lib/server/chromium/protocol.d.js +0 -16
- package/lib/server/clock.js +0 -149
- package/lib/server/codegen/csharp.js +0 -327
- package/lib/server/codegen/java.js +0 -274
- package/lib/server/codegen/javascript.js +0 -247
- package/lib/server/codegen/jsonl.js +0 -52
- package/lib/server/codegen/language.js +0 -133
- package/lib/server/codegen/languages.js +0 -68
- package/lib/server/codegen/python.js +0 -279
- package/lib/server/codegen/types.js +0 -16
- package/lib/server/console.js +0 -57
- package/lib/server/cookieStore.js +0 -206
- package/lib/server/debugController.js +0 -181
- package/lib/server/debugger.js +0 -119
- package/lib/server/dialog.js +0 -116
- package/lib/server/dispatchers/androidDispatcher.js +0 -325
- package/lib/server/dispatchers/artifactDispatcher.js +0 -118
- package/lib/server/dispatchers/browserContextDispatcher.js +0 -384
- package/lib/server/dispatchers/browserDispatcher.js +0 -118
- package/lib/server/dispatchers/browserTypeDispatcher.js +0 -64
- package/lib/server/dispatchers/cdpSessionDispatcher.js +0 -44
- package/lib/server/dispatchers/debugControllerDispatcher.js +0 -78
- package/lib/server/dispatchers/dialogDispatcher.js +0 -47
- package/lib/server/dispatchers/dispatcher.js +0 -364
- package/lib/server/dispatchers/electronDispatcher.js +0 -89
- package/lib/server/dispatchers/elementHandlerDispatcher.js +0 -181
- package/lib/server/dispatchers/frameDispatcher.js +0 -227
- package/lib/server/dispatchers/jsHandleDispatcher.js +0 -85
- package/lib/server/dispatchers/jsonPipeDispatcher.js +0 -58
- package/lib/server/dispatchers/localUtilsDispatcher.js +0 -149
- package/lib/server/dispatchers/networkDispatchers.js +0 -213
- package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
- package/lib/server/dispatchers/pageDispatcher.js +0 -393
- package/lib/server/dispatchers/playwrightDispatcher.js +0 -108
- package/lib/server/dispatchers/streamDispatcher.js +0 -67
- package/lib/server/dispatchers/tracingDispatcher.js +0 -68
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +0 -165
- package/lib/server/dispatchers/writableStreamDispatcher.js +0 -79
- package/lib/server/dom.js +0 -815
- package/lib/server/download.js +0 -70
- package/lib/server/electron/electron.js +0 -273
- package/lib/server/errors.js +0 -69
- package/lib/server/fetch.js +0 -621
- package/lib/server/fileChooser.js +0 -43
- package/lib/server/fileUploadUtils.js +0 -84
- package/lib/server/firefox/ffBrowser.js +0 -418
- package/lib/server/firefox/ffConnection.js +0 -142
- package/lib/server/firefox/ffExecutionContext.js +0 -150
- package/lib/server/firefox/ffInput.js +0 -159
- package/lib/server/firefox/ffNetworkManager.js +0 -256
- package/lib/server/firefox/ffPage.js +0 -497
- package/lib/server/firefox/firefox.js +0 -114
- package/lib/server/firefox/protocol.d.js +0 -16
- package/lib/server/formData.js +0 -147
- package/lib/server/frameSelectors.js +0 -160
- package/lib/server/frames.js +0 -1471
- package/lib/server/har/harRecorder.js +0 -147
- package/lib/server/har/harTracer.js +0 -607
- package/lib/server/harBackend.js +0 -157
- package/lib/server/helper.js +0 -96
- package/lib/server/index.js +0 -58
- package/lib/server/input.js +0 -277
- package/lib/server/instrumentation.js +0 -72
- package/lib/server/javascript.js +0 -291
- package/lib/server/launchApp.js +0 -128
- package/lib/server/localUtils.js +0 -214
- package/lib/server/macEditingCommands.js +0 -143
- package/lib/server/network.js +0 -667
- package/lib/server/page.js +0 -830
- package/lib/server/pipeTransport.js +0 -89
- package/lib/server/playwright.js +0 -69
- package/lib/server/progress.js +0 -132
- package/lib/server/protocolError.js +0 -52
- package/lib/server/recorder/chat.js +0 -161
- package/lib/server/recorder/recorderApp.js +0 -366
- package/lib/server/recorder/recorderRunner.js +0 -138
- package/lib/server/recorder/recorderSignalProcessor.js +0 -83
- package/lib/server/recorder/recorderUtils.js +0 -157
- package/lib/server/recorder/throttledFile.js +0 -57
- package/lib/server/recorder.js +0 -554
- package/lib/server/registry/browserFetcher.js +0 -177
- package/lib/server/registry/dependencies.js +0 -371
- package/lib/server/registry/index.js +0 -1422
- package/lib/server/registry/nativeDeps.js +0 -1280
- package/lib/server/registry/oopDownloadBrowserMain.js +0 -127
- package/lib/server/screencast.js +0 -190
- package/lib/server/screenshotCompositor.js +0 -153
- package/lib/server/screenshotter.js +0 -333
- package/lib/server/selectors.js +0 -112
- package/lib/server/socksClientCertificatesInterceptor.js +0 -383
- package/lib/server/socksInterceptor.js +0 -95
- package/lib/server/trace/recorder/snapshotter.js +0 -147
- package/lib/server/trace/recorder/snapshotterInjected.js +0 -561
- package/lib/server/trace/recorder/tracing.js +0 -604
- package/lib/server/trace/viewer/traceParser.js +0 -72
- package/lib/server/trace/viewer/traceViewer.js +0 -245
- package/lib/server/transport.js +0 -181
- package/lib/server/types.js +0 -28
- package/lib/server/usKeyboardLayout.js +0 -145
- package/lib/server/utils/ascii.js +0 -44
- package/lib/server/utils/comparators.js +0 -139
- package/lib/server/utils/crypto.js +0 -216
- package/lib/server/utils/debug.js +0 -42
- package/lib/server/utils/debugLogger.js +0 -122
- package/lib/server/utils/env.js +0 -73
- package/lib/server/utils/eventsHelper.js +0 -39
- package/lib/server/utils/expectUtils.js +0 -123
- package/lib/server/utils/fileUtils.js +0 -191
- package/lib/server/utils/happyEyeballs.js +0 -207
- package/lib/server/utils/hostPlatform.js +0 -138
- package/lib/server/utils/httpServer.js +0 -203
- package/lib/server/utils/imageUtils.js +0 -141
- package/lib/server/utils/image_tools/colorUtils.js +0 -89
- package/lib/server/utils/image_tools/compare.js +0 -109
- package/lib/server/utils/image_tools/imageChannel.js +0 -78
- package/lib/server/utils/image_tools/stats.js +0 -102
- package/lib/server/utils/linuxUtils.js +0 -71
- package/lib/server/utils/network.js +0 -242
- package/lib/server/utils/nodePlatform.js +0 -154
- package/lib/server/utils/pipeTransport.js +0 -84
- package/lib/server/utils/processLauncher.js +0 -241
- package/lib/server/utils/socksProxy.js +0 -511
- package/lib/server/utils/spawnAsync.js +0 -41
- package/lib/server/utils/task.js +0 -51
- package/lib/server/utils/userAgent.js +0 -98
- package/lib/server/utils/wsServer.js +0 -121
- package/lib/server/utils/zipFile.js +0 -74
- package/lib/server/utils/zones.js +0 -57
- package/lib/server/videoRecorder.js +0 -124
- package/lib/server/webkit/protocol.d.js +0 -16
- package/lib/server/webkit/webkit.js +0 -108
- package/lib/server/webkit/wkBrowser.js +0 -335
- package/lib/server/webkit/wkConnection.js +0 -144
- package/lib/server/webkit/wkExecutionContext.js +0 -154
- package/lib/server/webkit/wkInput.js +0 -181
- package/lib/server/webkit/wkInterceptableRequest.js +0 -197
- package/lib/server/webkit/wkPage.js +0 -1159
- package/lib/server/webkit/wkProvisionalPage.js +0 -83
- package/lib/server/webkit/wkWorkers.js +0 -105
- package/lib/third_party/pixelmatch.js +0 -255
- package/lib/utils/isomorphic/ariaSnapshot.js +0 -455
- package/lib/utils/isomorphic/assert.js +0 -31
- package/lib/utils/isomorphic/colors.js +0 -72
- package/lib/utils/isomorphic/cssParser.js +0 -245
- package/lib/utils/isomorphic/cssTokenizer.js +0 -1051
- package/lib/utils/isomorphic/headers.js +0 -53
- package/lib/utils/isomorphic/locatorGenerators.js +0 -689
- package/lib/utils/isomorphic/locatorParser.js +0 -176
- package/lib/utils/isomorphic/locatorUtils.js +0 -81
- package/lib/utils/isomorphic/lruCache.js +0 -51
- package/lib/utils/isomorphic/manualPromise.js +0 -114
- package/lib/utils/isomorphic/mimeType.js +0 -459
- package/lib/utils/isomorphic/multimap.js +0 -80
- package/lib/utils/isomorphic/protocolFormatter.js +0 -81
- package/lib/utils/isomorphic/protocolMetainfo.js +0 -330
- package/lib/utils/isomorphic/rtti.js +0 -43
- package/lib/utils/isomorphic/selectorParser.js +0 -386
- package/lib/utils/isomorphic/semaphore.js +0 -54
- package/lib/utils/isomorphic/stackTrace.js +0 -158
- package/lib/utils/isomorphic/stringUtils.js +0 -204
- package/lib/utils/isomorphic/time.js +0 -49
- package/lib/utils/isomorphic/timeoutRunner.js +0 -66
- package/lib/utils/isomorphic/trace/entries.js +0 -16
- package/lib/utils/isomorphic/trace/snapshotRenderer.js +0 -499
- package/lib/utils/isomorphic/trace/snapshotServer.js +0 -120
- package/lib/utils/isomorphic/trace/snapshotStorage.js +0 -89
- package/lib/utils/isomorphic/trace/traceLoader.js +0 -131
- package/lib/utils/isomorphic/trace/traceModel.js +0 -365
- package/lib/utils/isomorphic/trace/traceModernizer.js +0 -400
- package/lib/utils/isomorphic/trace/versions/traceV3.js +0 -16
- package/lib/utils/isomorphic/trace/versions/traceV4.js +0 -16
- package/lib/utils/isomorphic/trace/versions/traceV5.js +0 -16
- package/lib/utils/isomorphic/trace/versions/traceV6.js +0 -16
- package/lib/utils/isomorphic/trace/versions/traceV7.js +0 -16
- package/lib/utils/isomorphic/trace/versions/traceV8.js +0 -16
- package/lib/utils/isomorphic/traceUtils.js +0 -58
- package/lib/utils/isomorphic/types.js +0 -16
- package/lib/utils/isomorphic/urlMatch.js +0 -190
- package/lib/utils/isomorphic/utilityScriptSerializers.js +0 -251
- package/lib/utils/isomorphic/yaml.js +0 -84
- package/lib/utils.js +0 -111
- package/lib/utilsBundleImpl/index.js +0 -218
- package/lib/vite/recorder/assets/index-BSjZa4pk.css +0 -1
- package/lib/vite/recorder/assets/index-xK8wYVpV.js +0 -195
- package/lib/vite/traceViewer/assets/defaultSettingsView-k0nPICvc.js +0 -266
- package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
- package/lib/vite/traceViewer/index.DDDCQ_xS.js +0 -2
- package/lib/vite/traceViewer/uiMode.C7uDu3VD.js +0 -5
- package/lib/zipBundle.js +0 -34
- package/lib/zipBundleImpl.js +0 -5
- /package/lib/{utilsBundleImpl/xdg-open → xdg-open} +0 -0
|
@@ -1,176 +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 locatorParser_exports = {};
|
|
20
|
-
__export(locatorParser_exports, {
|
|
21
|
-
locatorOrSelectorAsSelector: () => locatorOrSelectorAsSelector,
|
|
22
|
-
unsafeLocatorOrSelectorAsSelector: () => unsafeLocatorOrSelectorAsSelector
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(locatorParser_exports);
|
|
25
|
-
var import_locatorGenerators = require("./locatorGenerators");
|
|
26
|
-
var import_selectorParser = require("./selectorParser");
|
|
27
|
-
var import_stringUtils = require("./stringUtils");
|
|
28
|
-
function parseLocator(locator, testIdAttributeName) {
|
|
29
|
-
locator = locator.replace(/AriaRole\s*\.\s*([\w]+)/g, (_, group) => group.toLowerCase()).replace(/(get_by_role|getByRole)\s*\(\s*(?:["'`])([^'"`]+)['"`]/g, (_, group1, group2) => `${group1}(${group2.toLowerCase()}`);
|
|
30
|
-
const params = [];
|
|
31
|
-
let template = "";
|
|
32
|
-
for (let i = 0; i < locator.length; ++i) {
|
|
33
|
-
const quote = locator[i];
|
|
34
|
-
if (quote !== '"' && quote !== "'" && quote !== "`" && quote !== "/") {
|
|
35
|
-
template += quote;
|
|
36
|
-
continue;
|
|
37
|
-
}
|
|
38
|
-
const isRegexEscaping = locator[i - 1] === "r" || locator[i] === "/";
|
|
39
|
-
++i;
|
|
40
|
-
let text = "";
|
|
41
|
-
while (i < locator.length) {
|
|
42
|
-
if (locator[i] === "\\") {
|
|
43
|
-
if (isRegexEscaping) {
|
|
44
|
-
if (locator[i + 1] !== quote)
|
|
45
|
-
text += locator[i];
|
|
46
|
-
++i;
|
|
47
|
-
text += locator[i];
|
|
48
|
-
} else {
|
|
49
|
-
++i;
|
|
50
|
-
if (locator[i] === "n")
|
|
51
|
-
text += "\n";
|
|
52
|
-
else if (locator[i] === "r")
|
|
53
|
-
text += "\r";
|
|
54
|
-
else if (locator[i] === "t")
|
|
55
|
-
text += " ";
|
|
56
|
-
else
|
|
57
|
-
text += locator[i];
|
|
58
|
-
}
|
|
59
|
-
++i;
|
|
60
|
-
continue;
|
|
61
|
-
}
|
|
62
|
-
if (locator[i] !== quote) {
|
|
63
|
-
text += locator[i++];
|
|
64
|
-
continue;
|
|
65
|
-
}
|
|
66
|
-
break;
|
|
67
|
-
}
|
|
68
|
-
params.push({ quote, text });
|
|
69
|
-
template += (quote === "/" ? "r" : "") + "$" + params.length;
|
|
70
|
-
}
|
|
71
|
-
template = template.toLowerCase().replace(/get_by_alt_text/g, "getbyalttext").replace(/get_by_test_id/g, "getbytestid").replace(/get_by_([\w]+)/g, "getby$1").replace(/has_not_text/g, "hasnottext").replace(/has_text/g, "hastext").replace(/has_not/g, "hasnot").replace(/frame_locator/g, "framelocator").replace(/content_frame/g, "contentframe").replace(/[{}\s]/g, "").replace(/new\(\)/g, "").replace(/new[\w]+\.[\w]+options\(\)/g, "").replace(/\.set/g, ",set").replace(/\.or_\(/g, "or(").replace(/\.and_\(/g, "and(").replace(/:/g, "=").replace(/,re\.ignorecase/g, "i").replace(/,pattern.case_insensitive/g, "i").replace(/,regexoptions.ignorecase/g, "i").replace(/re.compile\(([^)]+)\)/g, "$1").replace(/pattern.compile\(([^)]+)\)/g, "r$1").replace(/newregex\(([^)]+)\)/g, "r$1").replace(/string=/g, "=").replace(/regex=/g, "=").replace(/,,/g, ",").replace(/,\)/g, ")");
|
|
72
|
-
const preferredQuote = params.map((p) => p.quote).filter((quote) => "'\"`".includes(quote))[0];
|
|
73
|
-
return { selector: transform(template, params, testIdAttributeName), preferredQuote };
|
|
74
|
-
}
|
|
75
|
-
function countParams(template) {
|
|
76
|
-
return [...template.matchAll(/\$\d+/g)].length;
|
|
77
|
-
}
|
|
78
|
-
function shiftParams(template, sub) {
|
|
79
|
-
return template.replace(/\$(\d+)/g, (_, ordinal) => `$${ordinal - sub}`);
|
|
80
|
-
}
|
|
81
|
-
function transform(template, params, testIdAttributeName) {
|
|
82
|
-
while (true) {
|
|
83
|
-
const hasMatch = template.match(/filter\(,?(has=|hasnot=|sethas\(|sethasnot\()/);
|
|
84
|
-
if (!hasMatch)
|
|
85
|
-
break;
|
|
86
|
-
const start = hasMatch.index + hasMatch[0].length;
|
|
87
|
-
let balance = 0;
|
|
88
|
-
let end = start;
|
|
89
|
-
for (; end < template.length; end++) {
|
|
90
|
-
if (template[end] === "(")
|
|
91
|
-
balance++;
|
|
92
|
-
else if (template[end] === ")")
|
|
93
|
-
balance--;
|
|
94
|
-
if (balance < 0)
|
|
95
|
-
break;
|
|
96
|
-
}
|
|
97
|
-
let prefix = template.substring(0, start);
|
|
98
|
-
let extraSymbol = 0;
|
|
99
|
-
if (["sethas(", "sethasnot("].includes(hasMatch[1])) {
|
|
100
|
-
extraSymbol = 1;
|
|
101
|
-
prefix = prefix.replace(/sethas\($/, "has=").replace(/sethasnot\($/, "hasnot=");
|
|
102
|
-
}
|
|
103
|
-
const paramsCountBeforeHas = countParams(template.substring(0, start));
|
|
104
|
-
const hasTemplate = shiftParams(template.substring(start, end), paramsCountBeforeHas);
|
|
105
|
-
const paramsCountInHas = countParams(hasTemplate);
|
|
106
|
-
const hasParams = params.slice(paramsCountBeforeHas, paramsCountBeforeHas + paramsCountInHas);
|
|
107
|
-
const hasSelector = JSON.stringify(transform(hasTemplate, hasParams, testIdAttributeName));
|
|
108
|
-
template = prefix.replace(/=$/, "2=") + `$${paramsCountBeforeHas + 1}` + shiftParams(template.substring(end + extraSymbol), paramsCountInHas - 1);
|
|
109
|
-
const paramsBeforeHas = params.slice(0, paramsCountBeforeHas);
|
|
110
|
-
const paramsAfterHas = params.slice(paramsCountBeforeHas + paramsCountInHas);
|
|
111
|
-
params = paramsBeforeHas.concat([{ quote: '"', text: hasSelector }]).concat(paramsAfterHas);
|
|
112
|
-
}
|
|
113
|
-
template = template.replace(/\,set([\w]+)\(([^)]+)\)/g, (_, group1, group2) => "," + group1.toLowerCase() + "=" + group2.toLowerCase()).replace(/framelocator\(([^)]+)\)/g, "$1.internal:control=enter-frame").replace(/contentframe(\(\))?/g, "internal:control=enter-frame").replace(/locator\(([^)]+),hastext=([^),]+)\)/g, "locator($1).internal:has-text=$2").replace(/locator\(([^)]+),hasnottext=([^),]+)\)/g, "locator($1).internal:has-not-text=$2").replace(/locator\(([^)]+),hastext=([^),]+)\)/g, "locator($1).internal:has-text=$2").replace(/locator\(([^)]+)\)/g, "$1").replace(/getbyrole\(([^)]+)\)/g, "internal:role=$1").replace(/getbytext\(([^)]+)\)/g, "internal:text=$1").replace(/getbylabel\(([^)]+)\)/g, "internal:label=$1").replace(/getbytestid\(([^)]+)\)/g, `internal:testid=[${testIdAttributeName}=$1]`).replace(/getby(placeholder|alt|title)(?:text)?\(([^)]+)\)/g, "internal:attr=[$1=$2]").replace(/first(\(\))?/g, "nth=0").replace(/last(\(\))?/g, "nth=-1").replace(/nth\(([^)]+)\)/g, "nth=$1").replace(/filter\(,?visible=true\)/g, "visible=true").replace(/filter\(,?visible=false\)/g, "visible=false").replace(/filter\(,?hastext=([^)]+)\)/g, "internal:has-text=$1").replace(/filter\(,?hasnottext=([^)]+)\)/g, "internal:has-not-text=$1").replace(/filter\(,?has2=([^)]+)\)/g, "internal:has=$1").replace(/filter\(,?hasnot2=([^)]+)\)/g, "internal:has-not=$1").replace(/,exact=false/g, "").replace(/,exact=true/g, "s").replace(/,includehidden=/g, ",include-hidden=").replace(/\,/g, "][");
|
|
114
|
-
const parts = template.split(".");
|
|
115
|
-
for (let index = 0; index < parts.length - 1; index++) {
|
|
116
|
-
if (parts[index] === "internal:control=enter-frame" && parts[index + 1].startsWith("nth=")) {
|
|
117
|
-
const [nth] = parts.splice(index, 1);
|
|
118
|
-
parts.splice(index + 1, 0, nth);
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
return parts.map((t) => {
|
|
122
|
-
if (!t.startsWith("internal:") || t === "internal:control")
|
|
123
|
-
return t.replace(/\$(\d+)/g, (_, ordinal) => {
|
|
124
|
-
const param = params[+ordinal - 1];
|
|
125
|
-
return param.text;
|
|
126
|
-
});
|
|
127
|
-
t = t.includes("[") ? t.replace(/\]/, "") + "]" : t;
|
|
128
|
-
t = t.replace(/(?:r)\$(\d+)(i)?/g, (_, ordinal, suffix) => {
|
|
129
|
-
const param = params[+ordinal - 1];
|
|
130
|
-
if (t.startsWith("internal:attr") || t.startsWith("internal:testid") || t.startsWith("internal:role"))
|
|
131
|
-
return (0, import_stringUtils.escapeForAttributeSelector)(new RegExp(param.text), false) + (suffix || "");
|
|
132
|
-
return (0, import_stringUtils.escapeForTextSelector)(new RegExp(param.text, suffix), false);
|
|
133
|
-
}).replace(/\$(\d+)(i|s)?/g, (_, ordinal, suffix) => {
|
|
134
|
-
const param = params[+ordinal - 1];
|
|
135
|
-
if (t.startsWith("internal:has=") || t.startsWith("internal:has-not="))
|
|
136
|
-
return param.text;
|
|
137
|
-
if (t.startsWith("internal:testid"))
|
|
138
|
-
return (0, import_stringUtils.escapeForAttributeSelector)(param.text, true);
|
|
139
|
-
if (t.startsWith("internal:attr") || t.startsWith("internal:role"))
|
|
140
|
-
return (0, import_stringUtils.escapeForAttributeSelector)(param.text, suffix === "s");
|
|
141
|
-
return (0, import_stringUtils.escapeForTextSelector)(param.text, suffix === "s");
|
|
142
|
-
});
|
|
143
|
-
return t;
|
|
144
|
-
}).join(" >> ");
|
|
145
|
-
}
|
|
146
|
-
function locatorOrSelectorAsSelector(language, locator, testIdAttributeName) {
|
|
147
|
-
try {
|
|
148
|
-
return unsafeLocatorOrSelectorAsSelector(language, locator, testIdAttributeName);
|
|
149
|
-
} catch (e) {
|
|
150
|
-
return "";
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
function unsafeLocatorOrSelectorAsSelector(language, locator, testIdAttributeName) {
|
|
154
|
-
try {
|
|
155
|
-
(0, import_selectorParser.parseSelector)(locator);
|
|
156
|
-
return locator;
|
|
157
|
-
} catch (e) {
|
|
158
|
-
}
|
|
159
|
-
const { selector, preferredQuote } = parseLocator(locator, testIdAttributeName);
|
|
160
|
-
const locators = (0, import_locatorGenerators.asLocators)(language, selector, void 0, void 0, preferredQuote);
|
|
161
|
-
const digest = digestForComparison(language, locator);
|
|
162
|
-
if (locators.some((candidate) => digestForComparison(language, candidate) === digest))
|
|
163
|
-
return selector;
|
|
164
|
-
return "";
|
|
165
|
-
}
|
|
166
|
-
function digestForComparison(language, locator) {
|
|
167
|
-
locator = locator.replace(/\s/g, "");
|
|
168
|
-
if (language === "javascript")
|
|
169
|
-
locator = locator.replace(/\\?["`]/g, "'").replace(/,{}/g, "");
|
|
170
|
-
return locator;
|
|
171
|
-
}
|
|
172
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
173
|
-
0 && (module.exports = {
|
|
174
|
-
locatorOrSelectorAsSelector,
|
|
175
|
-
unsafeLocatorOrSelectorAsSelector
|
|
176
|
-
});
|
|
@@ -1,81 +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 locatorUtils_exports = {};
|
|
20
|
-
__export(locatorUtils_exports, {
|
|
21
|
-
getByAltTextSelector: () => getByAltTextSelector,
|
|
22
|
-
getByLabelSelector: () => getByLabelSelector,
|
|
23
|
-
getByPlaceholderSelector: () => getByPlaceholderSelector,
|
|
24
|
-
getByRoleSelector: () => getByRoleSelector,
|
|
25
|
-
getByTestIdSelector: () => getByTestIdSelector,
|
|
26
|
-
getByTextSelector: () => getByTextSelector,
|
|
27
|
-
getByTitleSelector: () => getByTitleSelector
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(locatorUtils_exports);
|
|
30
|
-
var import_stringUtils = require("./stringUtils");
|
|
31
|
-
function getByAttributeTextSelector(attrName, text, options) {
|
|
32
|
-
return `internal:attr=[${attrName}=${(0, import_stringUtils.escapeForAttributeSelector)(text, options?.exact || false)}]`;
|
|
33
|
-
}
|
|
34
|
-
function getByTestIdSelector(testIdAttributeName, testId) {
|
|
35
|
-
return `internal:testid=[${testIdAttributeName}=${(0, import_stringUtils.escapeForAttributeSelector)(testId, true)}]`;
|
|
36
|
-
}
|
|
37
|
-
function getByLabelSelector(text, options) {
|
|
38
|
-
return "internal:label=" + (0, import_stringUtils.escapeForTextSelector)(text, !!options?.exact);
|
|
39
|
-
}
|
|
40
|
-
function getByAltTextSelector(text, options) {
|
|
41
|
-
return getByAttributeTextSelector("alt", text, options);
|
|
42
|
-
}
|
|
43
|
-
function getByTitleSelector(text, options) {
|
|
44
|
-
return getByAttributeTextSelector("title", text, options);
|
|
45
|
-
}
|
|
46
|
-
function getByPlaceholderSelector(text, options) {
|
|
47
|
-
return getByAttributeTextSelector("placeholder", text, options);
|
|
48
|
-
}
|
|
49
|
-
function getByTextSelector(text, options) {
|
|
50
|
-
return "internal:text=" + (0, import_stringUtils.escapeForTextSelector)(text, !!options?.exact);
|
|
51
|
-
}
|
|
52
|
-
function getByRoleSelector(role, options = {}) {
|
|
53
|
-
const props = [];
|
|
54
|
-
if (options.checked !== void 0)
|
|
55
|
-
props.push(["checked", String(options.checked)]);
|
|
56
|
-
if (options.disabled !== void 0)
|
|
57
|
-
props.push(["disabled", String(options.disabled)]);
|
|
58
|
-
if (options.selected !== void 0)
|
|
59
|
-
props.push(["selected", String(options.selected)]);
|
|
60
|
-
if (options.expanded !== void 0)
|
|
61
|
-
props.push(["expanded", String(options.expanded)]);
|
|
62
|
-
if (options.includeHidden !== void 0)
|
|
63
|
-
props.push(["include-hidden", String(options.includeHidden)]);
|
|
64
|
-
if (options.level !== void 0)
|
|
65
|
-
props.push(["level", String(options.level)]);
|
|
66
|
-
if (options.name !== void 0)
|
|
67
|
-
props.push(["name", (0, import_stringUtils.escapeForAttributeSelector)(options.name, !!options.exact)]);
|
|
68
|
-
if (options.pressed !== void 0)
|
|
69
|
-
props.push(["pressed", String(options.pressed)]);
|
|
70
|
-
return `internal:role=${role}${props.map(([n, v]) => `[${n}=${v}]`).join("")}`;
|
|
71
|
-
}
|
|
72
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
73
|
-
0 && (module.exports = {
|
|
74
|
-
getByAltTextSelector,
|
|
75
|
-
getByLabelSelector,
|
|
76
|
-
getByPlaceholderSelector,
|
|
77
|
-
getByRoleSelector,
|
|
78
|
-
getByTestIdSelector,
|
|
79
|
-
getByTextSelector,
|
|
80
|
-
getByTitleSelector
|
|
81
|
-
});
|
|
@@ -1,51 +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 lruCache_exports = {};
|
|
20
|
-
__export(lruCache_exports, {
|
|
21
|
-
LRUCache: () => LRUCache
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(lruCache_exports);
|
|
24
|
-
class LRUCache {
|
|
25
|
-
constructor(maxSize) {
|
|
26
|
-
this._maxSize = maxSize;
|
|
27
|
-
this._map = /* @__PURE__ */ new Map();
|
|
28
|
-
this._size = 0;
|
|
29
|
-
}
|
|
30
|
-
getOrCompute(key, compute) {
|
|
31
|
-
if (this._map.has(key)) {
|
|
32
|
-
const result2 = this._map.get(key);
|
|
33
|
-
this._map.delete(key);
|
|
34
|
-
this._map.set(key, result2);
|
|
35
|
-
return result2.value;
|
|
36
|
-
}
|
|
37
|
-
const result = compute();
|
|
38
|
-
while (this._map.size && this._size + result.size > this._maxSize) {
|
|
39
|
-
const [firstKey, firstValue] = this._map.entries().next().value;
|
|
40
|
-
this._size -= firstValue.size;
|
|
41
|
-
this._map.delete(firstKey);
|
|
42
|
-
}
|
|
43
|
-
this._map.set(key, result);
|
|
44
|
-
this._size += result.size;
|
|
45
|
-
return result.value;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
49
|
-
0 && (module.exports = {
|
|
50
|
-
LRUCache
|
|
51
|
-
});
|
|
@@ -1,114 +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 manualPromise_exports = {};
|
|
20
|
-
__export(manualPromise_exports, {
|
|
21
|
-
LongStandingScope: () => LongStandingScope,
|
|
22
|
-
ManualPromise: () => ManualPromise
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(manualPromise_exports);
|
|
25
|
-
var import_stackTrace = require("./stackTrace");
|
|
26
|
-
class ManualPromise extends Promise {
|
|
27
|
-
constructor() {
|
|
28
|
-
let resolve;
|
|
29
|
-
let reject;
|
|
30
|
-
super((f, r) => {
|
|
31
|
-
resolve = f;
|
|
32
|
-
reject = r;
|
|
33
|
-
});
|
|
34
|
-
this._isDone = false;
|
|
35
|
-
this._resolve = resolve;
|
|
36
|
-
this._reject = reject;
|
|
37
|
-
}
|
|
38
|
-
isDone() {
|
|
39
|
-
return this._isDone;
|
|
40
|
-
}
|
|
41
|
-
resolve(t) {
|
|
42
|
-
this._isDone = true;
|
|
43
|
-
this._resolve(t);
|
|
44
|
-
}
|
|
45
|
-
reject(e) {
|
|
46
|
-
this._isDone = true;
|
|
47
|
-
this._reject(e);
|
|
48
|
-
}
|
|
49
|
-
static get [Symbol.species]() {
|
|
50
|
-
return Promise;
|
|
51
|
-
}
|
|
52
|
-
get [Symbol.toStringTag]() {
|
|
53
|
-
return "ManualPromise";
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
class LongStandingScope {
|
|
57
|
-
constructor() {
|
|
58
|
-
this._terminatePromises = /* @__PURE__ */ new Map();
|
|
59
|
-
this._isClosed = false;
|
|
60
|
-
}
|
|
61
|
-
reject(error) {
|
|
62
|
-
this._isClosed = true;
|
|
63
|
-
this._terminateError = error;
|
|
64
|
-
for (const p of this._terminatePromises.keys())
|
|
65
|
-
p.resolve(error);
|
|
66
|
-
}
|
|
67
|
-
close(error) {
|
|
68
|
-
this._isClosed = true;
|
|
69
|
-
this._closeError = error;
|
|
70
|
-
for (const [p, frames] of this._terminatePromises)
|
|
71
|
-
p.resolve(cloneError(error, frames));
|
|
72
|
-
}
|
|
73
|
-
isClosed() {
|
|
74
|
-
return this._isClosed;
|
|
75
|
-
}
|
|
76
|
-
static async raceMultiple(scopes, promise) {
|
|
77
|
-
return Promise.race(scopes.map((s) => s.race(promise)));
|
|
78
|
-
}
|
|
79
|
-
async race(promise) {
|
|
80
|
-
return this._race(Array.isArray(promise) ? promise : [promise], false);
|
|
81
|
-
}
|
|
82
|
-
async safeRace(promise, defaultValue) {
|
|
83
|
-
return this._race([promise], true, defaultValue);
|
|
84
|
-
}
|
|
85
|
-
async _race(promises, safe, defaultValue) {
|
|
86
|
-
const terminatePromise = new ManualPromise();
|
|
87
|
-
const frames = (0, import_stackTrace.captureRawStack)();
|
|
88
|
-
if (this._terminateError)
|
|
89
|
-
terminatePromise.resolve(this._terminateError);
|
|
90
|
-
if (this._closeError)
|
|
91
|
-
terminatePromise.resolve(cloneError(this._closeError, frames));
|
|
92
|
-
this._terminatePromises.set(terminatePromise, frames);
|
|
93
|
-
try {
|
|
94
|
-
return await Promise.race([
|
|
95
|
-
terminatePromise.then((e) => safe ? defaultValue : Promise.reject(e)),
|
|
96
|
-
...promises
|
|
97
|
-
]);
|
|
98
|
-
} finally {
|
|
99
|
-
this._terminatePromises.delete(terminatePromise);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
function cloneError(error, frames) {
|
|
104
|
-
const clone = new Error();
|
|
105
|
-
clone.name = error.name;
|
|
106
|
-
clone.message = error.message;
|
|
107
|
-
clone.stack = [error.name + ":" + error.message, ...frames].join("\n");
|
|
108
|
-
return clone;
|
|
109
|
-
}
|
|
110
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
111
|
-
0 && (module.exports = {
|
|
112
|
-
LongStandingScope,
|
|
113
|
-
ManualPromise
|
|
114
|
-
});
|