@smoothdeploy/playwright-core 1.58.4 → 1.60.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.
- 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.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
- package/lib/vite/traceViewer/index.html +5 -4
- package/lib/vite/traceViewer/index.uj4g7lWX.js +2 -0
- 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.CVz8LATg.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,274 +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 java_exports = {};
|
|
20
|
-
__export(java_exports, {
|
|
21
|
-
JavaLanguageGenerator: () => JavaLanguageGenerator
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(java_exports);
|
|
24
|
-
var import_language = require("./language");
|
|
25
|
-
var import_deviceDescriptors = require("../deviceDescriptors");
|
|
26
|
-
var import_javascript = require("./javascript");
|
|
27
|
-
var import_utils = require("../../utils");
|
|
28
|
-
class JavaLanguageGenerator {
|
|
29
|
-
constructor(mode) {
|
|
30
|
-
this.groupName = "Java";
|
|
31
|
-
this.highlighter = "java";
|
|
32
|
-
if (mode === "library") {
|
|
33
|
-
this.name = "Library";
|
|
34
|
-
this.id = "java";
|
|
35
|
-
} else if (mode === "junit") {
|
|
36
|
-
this.name = "JUnit";
|
|
37
|
-
this.id = "java-junit";
|
|
38
|
-
} else {
|
|
39
|
-
throw new Error(`Unknown Java language mode: ${mode}`);
|
|
40
|
-
}
|
|
41
|
-
this._mode = mode;
|
|
42
|
-
}
|
|
43
|
-
generateAction(actionInContext) {
|
|
44
|
-
const action = actionInContext.action;
|
|
45
|
-
const pageAlias = actionInContext.frame.pageAlias;
|
|
46
|
-
const offset = this._mode === "junit" ? 4 : 6;
|
|
47
|
-
const formatter = new import_javascript.JavaScriptFormatter(offset);
|
|
48
|
-
if (this._mode !== "library" && (action.name === "openPage" || action.name === "closePage"))
|
|
49
|
-
return "";
|
|
50
|
-
if (action.name === "openPage") {
|
|
51
|
-
formatter.add(`Page ${pageAlias} = context.newPage();`);
|
|
52
|
-
if (action.url && action.url !== "about:blank" && action.url !== "chrome://newtab/")
|
|
53
|
-
formatter.add(`${pageAlias}.navigate(${quote(action.url)});`);
|
|
54
|
-
return formatter.format();
|
|
55
|
-
}
|
|
56
|
-
const locators = actionInContext.frame.framePath.map((selector) => `.${this._asLocator(selector, false)}.contentFrame()`);
|
|
57
|
-
const subject = `${pageAlias}${locators.join("")}`;
|
|
58
|
-
const signals = (0, import_language.toSignalMap)(action);
|
|
59
|
-
if (signals.dialog) {
|
|
60
|
-
formatter.add(` ${pageAlias}.onceDialog(dialog -> {
|
|
61
|
-
System.out.println(String.format("Dialog message: %s", dialog.message()));
|
|
62
|
-
dialog.dismiss();
|
|
63
|
-
});`);
|
|
64
|
-
}
|
|
65
|
-
let code = this._generateActionCall(subject, actionInContext, !!actionInContext.frame.framePath.length);
|
|
66
|
-
if (signals.popup) {
|
|
67
|
-
code = `Page ${signals.popup.popupAlias} = ${pageAlias}.waitForPopup(() -> {
|
|
68
|
-
${code}
|
|
69
|
-
});`;
|
|
70
|
-
}
|
|
71
|
-
if (signals.download) {
|
|
72
|
-
code = `Download download${signals.download.downloadAlias} = ${pageAlias}.waitForDownload(() -> {
|
|
73
|
-
${code}
|
|
74
|
-
});`;
|
|
75
|
-
}
|
|
76
|
-
formatter.add(code);
|
|
77
|
-
return formatter.format();
|
|
78
|
-
}
|
|
79
|
-
_generateActionCall(subject, actionInContext, inFrameLocator) {
|
|
80
|
-
const action = actionInContext.action;
|
|
81
|
-
switch (action.name) {
|
|
82
|
-
case "openPage":
|
|
83
|
-
throw Error("Not reached");
|
|
84
|
-
case "closePage":
|
|
85
|
-
return `${subject}.close();`;
|
|
86
|
-
case "click": {
|
|
87
|
-
let method = "click";
|
|
88
|
-
if (action.clickCount === 2)
|
|
89
|
-
method = "dblclick";
|
|
90
|
-
const options = (0, import_language.toClickOptionsForSourceCode)(action);
|
|
91
|
-
const optionsText = formatClickOptions(options);
|
|
92
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.${method}(${optionsText});`;
|
|
93
|
-
}
|
|
94
|
-
case "hover": {
|
|
95
|
-
const optionsText = action.position ? `new Locator.HoverOptions().setPosition(${action.position.x}, ${action.position.y})` : "";
|
|
96
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.hover(${optionsText});`;
|
|
97
|
-
}
|
|
98
|
-
case "check":
|
|
99
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.check();`;
|
|
100
|
-
case "uncheck":
|
|
101
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.uncheck();`;
|
|
102
|
-
case "fill":
|
|
103
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.fill(${quote(action.text)});`;
|
|
104
|
-
case "setInputFiles":
|
|
105
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.setInputFiles(${formatPath(action.files.length === 1 ? action.files[0] : action.files)});`;
|
|
106
|
-
case "press": {
|
|
107
|
-
const modifiers = (0, import_language.toKeyboardModifiers)(action.modifiers);
|
|
108
|
-
const shortcut = [...modifiers, action.key].join("+");
|
|
109
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.press(${quote(shortcut)});`;
|
|
110
|
-
}
|
|
111
|
-
case "navigate":
|
|
112
|
-
return `${subject}.navigate(${quote(action.url)});`;
|
|
113
|
-
case "select":
|
|
114
|
-
return `${subject}.${this._asLocator(action.selector, inFrameLocator)}.selectOption(${formatSelectOption(action.options.length === 1 ? action.options[0] : action.options)});`;
|
|
115
|
-
case "assertText":
|
|
116
|
-
return `assertThat(${subject}.${this._asLocator(action.selector, inFrameLocator)}).${action.substring ? "containsText" : "hasText"}(${quote(action.text)});`;
|
|
117
|
-
case "assertChecked":
|
|
118
|
-
return `assertThat(${subject}.${this._asLocator(action.selector, inFrameLocator)})${action.checked ? "" : ".not()"}.isChecked();`;
|
|
119
|
-
case "assertVisible":
|
|
120
|
-
return `assertThat(${subject}.${this._asLocator(action.selector, inFrameLocator)}).isVisible();`;
|
|
121
|
-
case "assertValue": {
|
|
122
|
-
const assertion = action.value ? `hasValue(${quote(action.value)})` : `isEmpty()`;
|
|
123
|
-
return `assertThat(${subject}.${this._asLocator(action.selector, inFrameLocator)}).${assertion};`;
|
|
124
|
-
}
|
|
125
|
-
case "assertSnapshot":
|
|
126
|
-
return `assertThat(${subject}.${this._asLocator(action.selector, inFrameLocator)}).matchesAriaSnapshot(${quote(action.ariaSnapshot)});`;
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
_asLocator(selector, inFrameLocator) {
|
|
130
|
-
return (0, import_utils.asLocator)("java", selector, inFrameLocator);
|
|
131
|
-
}
|
|
132
|
-
generateHeader(options) {
|
|
133
|
-
const formatter = new import_javascript.JavaScriptFormatter();
|
|
134
|
-
if (this._mode === "junit") {
|
|
135
|
-
formatter.add(`
|
|
136
|
-
import com.microsoft.playwright.junit.UsePlaywright;
|
|
137
|
-
import com.microsoft.playwright.Page;
|
|
138
|
-
import com.microsoft.playwright.options.*;
|
|
139
|
-
|
|
140
|
-
${options.contextOptions.recordHar ? `import java.nio.file.Paths;
|
|
141
|
-
` : ""}import org.junit.jupiter.api.*;
|
|
142
|
-
import static com.microsoft.playwright.assertions.PlaywrightAssertions.*;
|
|
143
|
-
|
|
144
|
-
@UsePlaywright
|
|
145
|
-
public class TestExample {
|
|
146
|
-
@Test
|
|
147
|
-
void test(Page page) {`);
|
|
148
|
-
if (options.contextOptions.recordHar) {
|
|
149
|
-
const url = options.contextOptions.recordHar.urlFilter;
|
|
150
|
-
const recordHarOptions = typeof url === "string" ? `, new Page.RouteFromHAROptions()
|
|
151
|
-
.setUrl(${quote(url)})` : "";
|
|
152
|
-
formatter.add(` page.routeFromHAR(Paths.get(${quote(options.contextOptions.recordHar.path)})${recordHarOptions});`);
|
|
153
|
-
}
|
|
154
|
-
return formatter.format();
|
|
155
|
-
}
|
|
156
|
-
formatter.add(`
|
|
157
|
-
import com.microsoft.playwright.*;
|
|
158
|
-
import com.microsoft.playwright.options.*;
|
|
159
|
-
import static com.microsoft.playwright.assertions.PlaywrightAssertions.assertThat;
|
|
160
|
-
${options.contextOptions.recordHar ? `import java.nio.file.Paths;
|
|
161
|
-
` : ""}import java.util.*;
|
|
162
|
-
|
|
163
|
-
public class Example {
|
|
164
|
-
public static void main(String[] args) {
|
|
165
|
-
try (Playwright playwright = Playwright.create()) {
|
|
166
|
-
Browser browser = playwright.${options.browserName}().launch(${formatLaunchOptions(options.launchOptions)});
|
|
167
|
-
BrowserContext context = browser.newContext(${formatContextOptions(options.contextOptions, options.deviceName)});`);
|
|
168
|
-
if (options.contextOptions.recordHar) {
|
|
169
|
-
const url = options.contextOptions.recordHar.urlFilter;
|
|
170
|
-
const recordHarOptions = typeof url === "string" ? `, new BrowserContext.RouteFromHAROptions()
|
|
171
|
-
.setUrl(${quote(url)})` : "";
|
|
172
|
-
formatter.add(` context.routeFromHAR(Paths.get(${quote(options.contextOptions.recordHar.path)})${recordHarOptions});`);
|
|
173
|
-
}
|
|
174
|
-
return formatter.format();
|
|
175
|
-
}
|
|
176
|
-
generateFooter(saveStorage) {
|
|
177
|
-
const storageStateLine = saveStorage ? `
|
|
178
|
-
context.storageState(new BrowserContext.StorageStateOptions().setPath(${quote(saveStorage)}));
|
|
179
|
-
` : "";
|
|
180
|
-
if (this._mode === "junit") {
|
|
181
|
-
return `${storageStateLine} }
|
|
182
|
-
}`;
|
|
183
|
-
}
|
|
184
|
-
return `${storageStateLine} }
|
|
185
|
-
}
|
|
186
|
-
}`;
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
function formatPath(files) {
|
|
190
|
-
if (Array.isArray(files)) {
|
|
191
|
-
if (files.length === 0)
|
|
192
|
-
return "new Path[0]";
|
|
193
|
-
return `new Path[] {${files.map((s) => "Paths.get(" + quote(s) + ")").join(", ")}}`;
|
|
194
|
-
}
|
|
195
|
-
return `Paths.get(${quote(files)})`;
|
|
196
|
-
}
|
|
197
|
-
function formatSelectOption(options) {
|
|
198
|
-
if (Array.isArray(options)) {
|
|
199
|
-
if (options.length === 0)
|
|
200
|
-
return "new String[0]";
|
|
201
|
-
return `new String[] {${options.map((s) => quote(s)).join(", ")}}`;
|
|
202
|
-
}
|
|
203
|
-
return quote(options);
|
|
204
|
-
}
|
|
205
|
-
function formatLaunchOptions(options) {
|
|
206
|
-
const lines = [];
|
|
207
|
-
if (!Object.keys(options).filter((key) => options[key] !== void 0).length)
|
|
208
|
-
return "";
|
|
209
|
-
lines.push("new BrowserType.LaunchOptions()");
|
|
210
|
-
if (options.channel)
|
|
211
|
-
lines.push(` .setChannel(${quote(options.channel)})`);
|
|
212
|
-
if (typeof options.headless === "boolean")
|
|
213
|
-
lines.push(` .setHeadless(false)`);
|
|
214
|
-
return lines.join("\n");
|
|
215
|
-
}
|
|
216
|
-
function formatContextOptions(contextOptions, deviceName) {
|
|
217
|
-
const lines = [];
|
|
218
|
-
if (!Object.keys(contextOptions).length && !deviceName)
|
|
219
|
-
return "";
|
|
220
|
-
const device = deviceName ? import_deviceDescriptors.deviceDescriptors[deviceName] : {};
|
|
221
|
-
const options = { ...device, ...contextOptions };
|
|
222
|
-
lines.push("new Browser.NewContextOptions()");
|
|
223
|
-
if (options.acceptDownloads)
|
|
224
|
-
lines.push(` .setAcceptDownloads(true)`);
|
|
225
|
-
if (options.bypassCSP)
|
|
226
|
-
lines.push(` .setBypassCSP(true)`);
|
|
227
|
-
if (options.colorScheme)
|
|
228
|
-
lines.push(` .setColorScheme(ColorScheme.${options.colorScheme.toUpperCase()})`);
|
|
229
|
-
if (options.deviceScaleFactor)
|
|
230
|
-
lines.push(` .setDeviceScaleFactor(${options.deviceScaleFactor})`);
|
|
231
|
-
if (options.geolocation)
|
|
232
|
-
lines.push(` .setGeolocation(${options.geolocation.latitude}, ${options.geolocation.longitude})`);
|
|
233
|
-
if (options.hasTouch)
|
|
234
|
-
lines.push(` .setHasTouch(${options.hasTouch})`);
|
|
235
|
-
if (options.isMobile)
|
|
236
|
-
lines.push(` .setIsMobile(${options.isMobile})`);
|
|
237
|
-
if (options.locale)
|
|
238
|
-
lines.push(` .setLocale(${quote(options.locale)})`);
|
|
239
|
-
if (options.proxy)
|
|
240
|
-
lines.push(` .setProxy(new Proxy(${quote(options.proxy.server)}))`);
|
|
241
|
-
if (options.serviceWorkers)
|
|
242
|
-
lines.push(` .setServiceWorkers(ServiceWorkerPolicy.${options.serviceWorkers.toUpperCase()})`);
|
|
243
|
-
if (options.storageState)
|
|
244
|
-
lines.push(` .setStorageStatePath(Paths.get(${quote(options.storageState)}))`);
|
|
245
|
-
if (options.timezoneId)
|
|
246
|
-
lines.push(` .setTimezoneId(${quote(options.timezoneId)})`);
|
|
247
|
-
if (options.userAgent)
|
|
248
|
-
lines.push(` .setUserAgent(${quote(options.userAgent)})`);
|
|
249
|
-
if (options.viewport)
|
|
250
|
-
lines.push(` .setViewportSize(${options.viewport.width}, ${options.viewport.height})`);
|
|
251
|
-
return lines.join("\n");
|
|
252
|
-
}
|
|
253
|
-
function formatClickOptions(options) {
|
|
254
|
-
const lines = [];
|
|
255
|
-
if (options.button)
|
|
256
|
-
lines.push(` .setButton(MouseButton.${options.button.toUpperCase()})`);
|
|
257
|
-
if (options.modifiers)
|
|
258
|
-
lines.push(` .setModifiers(Arrays.asList(${options.modifiers.map((m) => `KeyboardModifier.${m.toUpperCase()}`).join(", ")}))`);
|
|
259
|
-
if (options.clickCount)
|
|
260
|
-
lines.push(` .setClickCount(${options.clickCount})`);
|
|
261
|
-
if (options.position)
|
|
262
|
-
lines.push(` .setPosition(${options.position.x}, ${options.position.y})`);
|
|
263
|
-
if (!lines.length)
|
|
264
|
-
return "";
|
|
265
|
-
lines.unshift(`new Locator.ClickOptions()`);
|
|
266
|
-
return lines.join("\n");
|
|
267
|
-
}
|
|
268
|
-
function quote(text) {
|
|
269
|
-
return (0, import_utils.escapeWithQuotes)(text, '"');
|
|
270
|
-
}
|
|
271
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
272
|
-
0 && (module.exports = {
|
|
273
|
-
JavaLanguageGenerator
|
|
274
|
-
});
|
|
@@ -1,247 +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 javascript_exports = {};
|
|
20
|
-
__export(javascript_exports, {
|
|
21
|
-
JavaScriptFormatter: () => JavaScriptFormatter,
|
|
22
|
-
JavaScriptLanguageGenerator: () => JavaScriptLanguageGenerator,
|
|
23
|
-
quoteMultiline: () => quoteMultiline
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(javascript_exports);
|
|
26
|
-
var import_language = require("./language");
|
|
27
|
-
var import_utils = require("../../utils");
|
|
28
|
-
var import_deviceDescriptors = require("../deviceDescriptors");
|
|
29
|
-
class JavaScriptLanguageGenerator {
|
|
30
|
-
constructor(isTest) {
|
|
31
|
-
this.groupName = "Node.js";
|
|
32
|
-
this.highlighter = "javascript";
|
|
33
|
-
this.id = isTest ? "playwright-test" : "javascript";
|
|
34
|
-
this.name = isTest ? "Test Runner" : "Library";
|
|
35
|
-
this._isTest = isTest;
|
|
36
|
-
}
|
|
37
|
-
generateAction(actionInContext) {
|
|
38
|
-
const action = actionInContext.action;
|
|
39
|
-
if (this._isTest && (action.name === "openPage" || action.name === "closePage"))
|
|
40
|
-
return "";
|
|
41
|
-
const pageAlias = actionInContext.frame.pageAlias;
|
|
42
|
-
const formatter = new JavaScriptFormatter(2);
|
|
43
|
-
if (action.name === "openPage") {
|
|
44
|
-
formatter.add(`const ${pageAlias} = await context.newPage();`);
|
|
45
|
-
if (action.url && action.url !== "about:blank" && action.url !== "chrome://newtab/")
|
|
46
|
-
formatter.add(`await ${pageAlias}.goto(${quote(action.url)});`);
|
|
47
|
-
return formatter.format();
|
|
48
|
-
}
|
|
49
|
-
const locators = actionInContext.frame.framePath.map((selector) => `.${this._asLocator(selector)}.contentFrame()`);
|
|
50
|
-
const subject = `${pageAlias}${locators.join("")}`;
|
|
51
|
-
const signals = (0, import_language.toSignalMap)(action);
|
|
52
|
-
if (signals.dialog) {
|
|
53
|
-
formatter.add(` ${pageAlias}.once('dialog', dialog => {
|
|
54
|
-
console.log(\`Dialog message: \${dialog.message()}\`);
|
|
55
|
-
dialog.dismiss().catch(() => {});
|
|
56
|
-
});`);
|
|
57
|
-
}
|
|
58
|
-
if (signals.popup)
|
|
59
|
-
formatter.add(`const ${signals.popup.popupAlias}Promise = ${pageAlias}.waitForEvent('popup');`);
|
|
60
|
-
if (signals.download)
|
|
61
|
-
formatter.add(`const download${signals.download.downloadAlias}Promise = ${pageAlias}.waitForEvent('download');`);
|
|
62
|
-
formatter.add(wrapWithStep(actionInContext.description, this._generateActionCall(subject, actionInContext)));
|
|
63
|
-
if (signals.popup)
|
|
64
|
-
formatter.add(`const ${signals.popup.popupAlias} = await ${signals.popup.popupAlias}Promise;`);
|
|
65
|
-
if (signals.download)
|
|
66
|
-
formatter.add(`const download${signals.download.downloadAlias} = await download${signals.download.downloadAlias}Promise;`);
|
|
67
|
-
return formatter.format();
|
|
68
|
-
}
|
|
69
|
-
_generateActionCall(subject, actionInContext) {
|
|
70
|
-
const action = actionInContext.action;
|
|
71
|
-
switch (action.name) {
|
|
72
|
-
case "openPage":
|
|
73
|
-
throw Error("Not reached");
|
|
74
|
-
case "closePage":
|
|
75
|
-
return `await ${subject}.close();`;
|
|
76
|
-
case "click": {
|
|
77
|
-
let method = "click";
|
|
78
|
-
if (action.clickCount === 2)
|
|
79
|
-
method = "dblclick";
|
|
80
|
-
const options = (0, import_language.toClickOptionsForSourceCode)(action);
|
|
81
|
-
const optionsString = formatOptions(options, false);
|
|
82
|
-
return `await ${subject}.${this._asLocator(action.selector)}.${method}(${optionsString});`;
|
|
83
|
-
}
|
|
84
|
-
case "hover":
|
|
85
|
-
return `await ${subject}.${this._asLocator(action.selector)}.hover(${formatOptions({ position: action.position }, false)});`;
|
|
86
|
-
case "check":
|
|
87
|
-
return `await ${subject}.${this._asLocator(action.selector)}.check();`;
|
|
88
|
-
case "uncheck":
|
|
89
|
-
return `await ${subject}.${this._asLocator(action.selector)}.uncheck();`;
|
|
90
|
-
case "fill":
|
|
91
|
-
return `await ${subject}.${this._asLocator(action.selector)}.fill(${quote(action.text)});`;
|
|
92
|
-
case "setInputFiles":
|
|
93
|
-
return `await ${subject}.${this._asLocator(action.selector)}.setInputFiles(${(0, import_utils.formatObject)(action.files.length === 1 ? action.files[0] : action.files)});`;
|
|
94
|
-
case "press": {
|
|
95
|
-
const modifiers = (0, import_language.toKeyboardModifiers)(action.modifiers);
|
|
96
|
-
const shortcut = [...modifiers, action.key].join("+");
|
|
97
|
-
return `await ${subject}.${this._asLocator(action.selector)}.press(${quote(shortcut)});`;
|
|
98
|
-
}
|
|
99
|
-
case "navigate":
|
|
100
|
-
return `await ${subject}.goto(${quote(action.url)});`;
|
|
101
|
-
case "select":
|
|
102
|
-
return `await ${subject}.${this._asLocator(action.selector)}.selectOption(${(0, import_utils.formatObject)(action.options.length === 1 ? action.options[0] : action.options)});`;
|
|
103
|
-
case "assertText":
|
|
104
|
-
return `${this._isTest ? "" : "// "}await expect(${subject}.${this._asLocator(action.selector)}).${action.substring ? "toContainText" : "toHaveText"}(${quote(action.text)});`;
|
|
105
|
-
case "assertChecked":
|
|
106
|
-
return `${this._isTest ? "" : "// "}await expect(${subject}.${this._asLocator(action.selector)})${action.checked ? "" : ".not"}.toBeChecked();`;
|
|
107
|
-
case "assertVisible":
|
|
108
|
-
return `${this._isTest ? "" : "// "}await expect(${subject}.${this._asLocator(action.selector)}).toBeVisible();`;
|
|
109
|
-
case "assertValue": {
|
|
110
|
-
const assertion = action.value ? `toHaveValue(${quote(action.value)})` : `toBeEmpty()`;
|
|
111
|
-
return `${this._isTest ? "" : "// "}await expect(${subject}.${this._asLocator(action.selector)}).${assertion};`;
|
|
112
|
-
}
|
|
113
|
-
case "assertSnapshot": {
|
|
114
|
-
const commentIfNeeded = this._isTest ? "" : "// ";
|
|
115
|
-
return `${commentIfNeeded}await expect(${subject}.${this._asLocator(action.selector)}).toMatchAriaSnapshot(${quoteMultiline(action.ariaSnapshot, `${commentIfNeeded} `)});`;
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
_asLocator(selector) {
|
|
120
|
-
return (0, import_utils.asLocator)("javascript", selector);
|
|
121
|
-
}
|
|
122
|
-
generateHeader(options) {
|
|
123
|
-
if (this._isTest)
|
|
124
|
-
return this.generateTestHeader(options);
|
|
125
|
-
return this.generateStandaloneHeader(options);
|
|
126
|
-
}
|
|
127
|
-
generateFooter(saveStorage) {
|
|
128
|
-
if (this._isTest)
|
|
129
|
-
return this.generateTestFooter(saveStorage);
|
|
130
|
-
return this.generateStandaloneFooter(saveStorage);
|
|
131
|
-
}
|
|
132
|
-
generateTestHeader(options) {
|
|
133
|
-
const formatter = new JavaScriptFormatter();
|
|
134
|
-
const useText = formatContextOptions(options.contextOptions, options.deviceName, this._isTest);
|
|
135
|
-
formatter.add(`
|
|
136
|
-
import { test, expect${options.deviceName ? ", devices" : ""} } from '@playwright/test';
|
|
137
|
-
${useText ? "\ntest.use(" + useText + ");\n" : ""}
|
|
138
|
-
test('test', async ({ page }) => {`);
|
|
139
|
-
if (options.contextOptions.recordHar) {
|
|
140
|
-
const url = options.contextOptions.recordHar.urlFilter;
|
|
141
|
-
formatter.add(` await page.routeFromHAR(${quote(options.contextOptions.recordHar.path)}${url ? `, ${formatOptions({ url }, false)}` : ""});`);
|
|
142
|
-
}
|
|
143
|
-
return formatter.format();
|
|
144
|
-
}
|
|
145
|
-
generateTestFooter(saveStorage) {
|
|
146
|
-
return `});`;
|
|
147
|
-
}
|
|
148
|
-
generateStandaloneHeader(options) {
|
|
149
|
-
const formatter = new JavaScriptFormatter();
|
|
150
|
-
formatter.add(`
|
|
151
|
-
const { ${options.browserName}${options.deviceName ? ", devices" : ""} } = require('playwright');
|
|
152
|
-
|
|
153
|
-
(async () => {
|
|
154
|
-
const browser = await ${options.browserName}.launch(${(0, import_utils.formatObjectOrVoid)(options.launchOptions)});
|
|
155
|
-
const context = await browser.newContext(${formatContextOptions(options.contextOptions, options.deviceName, false)});`);
|
|
156
|
-
if (options.contextOptions.recordHar)
|
|
157
|
-
formatter.add(` await context.routeFromHAR(${quote(options.contextOptions.recordHar.path)});`);
|
|
158
|
-
return formatter.format();
|
|
159
|
-
}
|
|
160
|
-
generateStandaloneFooter(saveStorage) {
|
|
161
|
-
const storageStateLine = saveStorage ? `
|
|
162
|
-
await context.storageState({ path: ${quote(saveStorage)} });` : "";
|
|
163
|
-
return `
|
|
164
|
-
// ---------------------${storageStateLine}
|
|
165
|
-
await context.close();
|
|
166
|
-
await browser.close();
|
|
167
|
-
})();`;
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
function formatOptions(value, hasArguments) {
|
|
171
|
-
const keys = Object.keys(value).filter((key) => value[key] !== void 0);
|
|
172
|
-
if (!keys.length)
|
|
173
|
-
return "";
|
|
174
|
-
return (hasArguments ? ", " : "") + (0, import_utils.formatObject)(value);
|
|
175
|
-
}
|
|
176
|
-
function formatContextOptions(options, deviceName, isTest) {
|
|
177
|
-
const device = deviceName && import_deviceDescriptors.deviceDescriptors[deviceName];
|
|
178
|
-
options = { ...options, recordHar: void 0 };
|
|
179
|
-
if (!device)
|
|
180
|
-
return (0, import_utils.formatObjectOrVoid)(options);
|
|
181
|
-
let serializedObject = (0, import_utils.formatObjectOrVoid)((0, import_language.sanitizeDeviceOptions)(device, options));
|
|
182
|
-
if (!serializedObject)
|
|
183
|
-
serializedObject = "{\n}";
|
|
184
|
-
const lines = serializedObject.split("\n");
|
|
185
|
-
lines.splice(1, 0, `...devices[${quote(deviceName)}],`);
|
|
186
|
-
return lines.join("\n");
|
|
187
|
-
}
|
|
188
|
-
class JavaScriptFormatter {
|
|
189
|
-
constructor(offset = 0) {
|
|
190
|
-
this._lines = [];
|
|
191
|
-
this._baseIndent = " ".repeat(2);
|
|
192
|
-
this._baseOffset = " ".repeat(offset);
|
|
193
|
-
}
|
|
194
|
-
prepend(text) {
|
|
195
|
-
const trim = isMultilineString(text) ? (line) => line : (line) => line.trim();
|
|
196
|
-
this._lines = text.trim().split("\n").map(trim).concat(this._lines);
|
|
197
|
-
}
|
|
198
|
-
add(text) {
|
|
199
|
-
const trim = isMultilineString(text) ? (line) => line : (line) => line.trim();
|
|
200
|
-
this._lines.push(...text.trim().split("\n").map(trim));
|
|
201
|
-
}
|
|
202
|
-
newLine() {
|
|
203
|
-
this._lines.push("");
|
|
204
|
-
}
|
|
205
|
-
format() {
|
|
206
|
-
let spaces = "";
|
|
207
|
-
let previousLine = "";
|
|
208
|
-
return this._lines.map((line) => {
|
|
209
|
-
if (line === "")
|
|
210
|
-
return line;
|
|
211
|
-
if (line.startsWith("}") || line.startsWith("]"))
|
|
212
|
-
spaces = spaces.substring(this._baseIndent.length);
|
|
213
|
-
const extraSpaces = /^(for|while|if|try).*\(.*\)$/.test(previousLine) ? this._baseIndent : "";
|
|
214
|
-
previousLine = line;
|
|
215
|
-
const callCarryOver = line.startsWith(".set");
|
|
216
|
-
line = spaces + extraSpaces + (callCarryOver ? this._baseIndent : "") + line;
|
|
217
|
-
if (line.endsWith("{") || line.endsWith("["))
|
|
218
|
-
spaces += this._baseIndent;
|
|
219
|
-
return this._baseOffset + line;
|
|
220
|
-
}).join("\n");
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
function quote(text) {
|
|
224
|
-
return (0, import_utils.escapeWithQuotes)(text, "'");
|
|
225
|
-
}
|
|
226
|
-
function wrapWithStep(description, body) {
|
|
227
|
-
return description ? `await test.step(\`${description}\`, async () => {
|
|
228
|
-
${body}
|
|
229
|
-
});` : body;
|
|
230
|
-
}
|
|
231
|
-
function quoteMultiline(text, indent = " ") {
|
|
232
|
-
const escape = (text2) => text2.replace(/\\/g, "\\\\").replace(/`/g, "\\`").replace(/\$\{/g, "\\${");
|
|
233
|
-
const lines = text.split("\n");
|
|
234
|
-
if (lines.length === 1)
|
|
235
|
-
return "`" + escape(text) + "`";
|
|
236
|
-
return "`\n" + lines.map((line) => indent + escape(line).replace(/\${/g, "\\${")).join("\n") + `
|
|
237
|
-
${indent}\``;
|
|
238
|
-
}
|
|
239
|
-
function isMultilineString(text) {
|
|
240
|
-
return text.match(/`[\S\s]*`/)?.[0].includes("\n");
|
|
241
|
-
}
|
|
242
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
243
|
-
0 && (module.exports = {
|
|
244
|
-
JavaScriptFormatter,
|
|
245
|
-
JavaScriptLanguageGenerator,
|
|
246
|
-
quoteMultiline
|
|
247
|
-
});
|
|
@@ -1,52 +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 jsonl_exports = {};
|
|
20
|
-
__export(jsonl_exports, {
|
|
21
|
-
JsonlLanguageGenerator: () => JsonlLanguageGenerator
|
|
22
|
-
});
|
|
23
|
-
module.exports = __toCommonJS(jsonl_exports);
|
|
24
|
-
var import_utils = require("../../utils");
|
|
25
|
-
class JsonlLanguageGenerator {
|
|
26
|
-
constructor() {
|
|
27
|
-
this.id = "jsonl";
|
|
28
|
-
this.groupName = "";
|
|
29
|
-
this.name = "JSONL";
|
|
30
|
-
this.highlighter = "javascript";
|
|
31
|
-
}
|
|
32
|
-
generateAction(actionInContext) {
|
|
33
|
-
const locator = actionInContext.action.selector ? JSON.parse((0, import_utils.asLocator)("jsonl", actionInContext.action.selector)) : void 0;
|
|
34
|
-
const entry = {
|
|
35
|
-
...actionInContext.action,
|
|
36
|
-
...actionInContext.frame,
|
|
37
|
-
locator,
|
|
38
|
-
ariaSnapshot: void 0
|
|
39
|
-
};
|
|
40
|
-
return JSON.stringify(entry);
|
|
41
|
-
}
|
|
42
|
-
generateHeader(options) {
|
|
43
|
-
return JSON.stringify(options);
|
|
44
|
-
}
|
|
45
|
-
generateFooter(saveStorage) {
|
|
46
|
-
return "";
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
50
|
-
0 && (module.exports = {
|
|
51
|
-
JsonlLanguageGenerator
|
|
52
|
-
});
|