patchright-bun-core 1.58.2 → 1.59.0

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 (272) hide show
  1. package/ThirdPartyNotices.txt +126 -650
  2. package/browsers.json +16 -14
  3. package/lib/bootstrap.js +77 -0
  4. package/lib/cli/browserActions.js +308 -0
  5. package/lib/cli/driver.js +3 -2
  6. package/lib/cli/installActions.js +171 -0
  7. package/lib/cli/program.js +47 -411
  8. package/lib/client/android.js +4 -4
  9. package/lib/client/api.js +3 -3
  10. package/lib/client/browser.js +8 -0
  11. package/lib/client/browserContext.js +18 -37
  12. package/lib/client/browserType.js +19 -51
  13. package/lib/client/cdpSession.js +6 -2
  14. package/lib/client/channelOwner.js +1 -1
  15. package/lib/client/{webSocket.js → connect.js} +57 -7
  16. package/lib/client/connection.js +8 -4
  17. package/lib/client/consoleMessage.js +3 -0
  18. package/lib/client/debugger.js +57 -0
  19. package/lib/client/dialog.js +8 -1
  20. package/lib/client/disposable.js +76 -0
  21. package/lib/client/electron.js +1 -0
  22. package/lib/client/elementHandle.js +1 -4
  23. package/lib/client/events.js +3 -3
  24. package/lib/client/fetch.js +0 -1
  25. package/lib/client/frame.js +0 -5
  26. package/lib/client/harRouter.js +13 -1
  27. package/lib/client/jsHandle.js +0 -4
  28. package/lib/client/locator.js +5 -7
  29. package/lib/client/network.js +14 -11
  30. package/lib/client/page.js +34 -48
  31. package/lib/client/platform.js +0 -3
  32. package/lib/client/screencast.js +88 -0
  33. package/lib/client/selectors.js +3 -1
  34. package/lib/client/tracing.js +11 -4
  35. package/lib/client/video.js +13 -20
  36. package/lib/generated/bindingsControllerSource.js +1 -1
  37. package/lib/generated/clockSource.js +1 -1
  38. package/lib/generated/injectedScriptSource.js +1 -1
  39. package/lib/generated/pollingRecorderSource.js +1 -1
  40. package/lib/generated/storageScriptSource.js +1 -1
  41. package/lib/generated/utilityScriptSource.js +1 -1
  42. package/lib/mcpBundle.js +0 -6
  43. package/lib/mcpBundleImpl.js +91 -0
  44. package/lib/protocol/validator.js +216 -118
  45. package/lib/protocol/validatorPrimitives.js +1 -1
  46. package/lib/remote/playwrightConnection.js +10 -8
  47. package/lib/remote/playwrightPipeServer.js +100 -0
  48. package/lib/remote/playwrightServer.js +13 -8
  49. package/lib/remote/playwrightWebSocketServer.js +73 -0
  50. package/lib/remote/serverTransport.js +96 -0
  51. package/lib/server/android/android.js +2 -2
  52. package/lib/server/bidi/bidiBrowser.js +30 -8
  53. package/lib/server/bidi/bidiChromium.js +18 -5
  54. package/lib/server/bidi/bidiNetworkManager.js +39 -11
  55. package/lib/server/bidi/bidiPage.js +31 -15
  56. package/lib/server/bidi/third_party/firefoxPrefs.js +3 -1
  57. package/lib/server/browser.js +84 -21
  58. package/lib/server/browserContext.js +97 -58
  59. package/lib/server/browserType.js +14 -12
  60. package/lib/server/chromium/chromium.js +15 -13
  61. package/lib/server/chromium/crBrowser.js +18 -10
  62. package/lib/server/chromium/crNetworkManager.js +4 -4
  63. package/lib/server/chromium/crPage.js +26 -64
  64. package/lib/server/chromium/crServiceWorker.js +5 -4
  65. package/lib/server/clock.js +33 -33
  66. package/lib/server/console.js +5 -1
  67. package/lib/server/debugController.js +12 -6
  68. package/lib/server/debugger.js +40 -47
  69. package/lib/server/deviceDescriptorsSource.json +137 -137
  70. package/lib/server/dispatchers/browserContextDispatcher.js +27 -30
  71. package/lib/server/dispatchers/browserDispatcher.js +11 -5
  72. package/lib/server/dispatchers/browserTypeDispatcher.js +7 -0
  73. package/lib/server/dispatchers/cdpSessionDispatcher.js +4 -1
  74. package/lib/server/dispatchers/debuggerDispatcher.js +84 -0
  75. package/lib/server/dispatchers/dispatcher.js +1 -1
  76. package/lib/server/dispatchers/disposableDispatcher.js +39 -0
  77. package/lib/server/dispatchers/electronDispatcher.js +2 -1
  78. package/lib/server/dispatchers/frameDispatcher.js +3 -3
  79. package/lib/server/dispatchers/localUtilsDispatcher.js +37 -1
  80. package/lib/server/dispatchers/networkDispatchers.js +6 -5
  81. package/lib/server/dispatchers/pageDispatcher.js +101 -38
  82. package/lib/server/dispatchers/webSocketRouteDispatcher.js +4 -5
  83. package/lib/server/disposable.js +41 -0
  84. package/lib/server/dom.js +44 -26
  85. package/lib/server/download.js +3 -2
  86. package/lib/server/electron/electron.js +12 -7
  87. package/lib/server/firefox/ffBrowser.js +9 -19
  88. package/lib/server/firefox/ffInput.js +21 -5
  89. package/lib/server/firefox/ffNetworkManager.js +2 -2
  90. package/lib/server/firefox/ffPage.js +24 -27
  91. package/lib/server/frames.js +40 -11
  92. package/lib/server/har/harRecorder.js +2 -2
  93. package/lib/server/har/harTracer.js +5 -4
  94. package/lib/server/input.js +49 -4
  95. package/lib/server/instrumentation.js +5 -0
  96. package/lib/server/launchApp.js +0 -1
  97. package/lib/server/localUtils.js +6 -6
  98. package/lib/server/network.js +9 -8
  99. package/lib/server/overlay.js +138 -0
  100. package/lib/server/page.js +111 -51
  101. package/lib/server/progress.js +6 -0
  102. package/lib/server/recorder/recorderApp.js +9 -8
  103. package/lib/server/recorder.js +76 -40
  104. package/lib/server/registry/index.js +54 -81
  105. package/lib/server/registry/nativeDeps.js +1 -0
  106. package/lib/server/screencast.js +90 -143
  107. package/lib/server/trace/recorder/snapshotter.js +2 -2
  108. package/lib/server/trace/recorder/tracing.js +87 -36
  109. package/lib/server/trace/viewer/traceViewer.js +3 -4
  110. package/lib/server/usKeyboardLayout.js +7 -0
  111. package/lib/server/utils/comparators.js +1 -1
  112. package/lib/server/utils/disposable.js +32 -0
  113. package/lib/server/utils/eventsHelper.js +3 -1
  114. package/lib/server/utils/fileUtils.js +16 -2
  115. package/lib/server/utils/happyEyeballs.js +15 -12
  116. package/lib/server/utils/hostPlatform.js +0 -15
  117. package/lib/server/utils/httpServer.js +5 -3
  118. package/lib/server/utils/network.js +2 -1
  119. package/lib/server/utils/nodePlatform.js +0 -6
  120. package/lib/server/utils/processLauncher.js +8 -6
  121. package/lib/server/utils/zipFile.js +2 -2
  122. package/lib/server/videoRecorder.js +82 -12
  123. package/lib/server/webkit/wkBrowser.js +1 -6
  124. package/lib/server/webkit/wkPage.js +27 -25
  125. package/lib/server/webkit/wkWorkers.js +2 -1
  126. package/lib/serverRegistry.js +156 -0
  127. package/lib/tools/backend/browserBackend.js +79 -0
  128. package/lib/tools/backend/common.js +63 -0
  129. package/lib/tools/backend/config.js +41 -0
  130. package/lib/tools/backend/console.js +66 -0
  131. package/lib/tools/backend/context.js +296 -0
  132. package/lib/tools/backend/cookies.js +152 -0
  133. package/lib/tools/backend/devtools.js +69 -0
  134. package/lib/tools/backend/dialogs.js +59 -0
  135. package/lib/tools/backend/evaluate.js +64 -0
  136. package/lib/tools/backend/files.js +60 -0
  137. package/lib/tools/backend/form.js +64 -0
  138. package/lib/tools/backend/keyboard.js +155 -0
  139. package/lib/tools/backend/logFile.js +95 -0
  140. package/lib/tools/backend/mouse.js +168 -0
  141. package/lib/tools/backend/navigate.js +106 -0
  142. package/lib/tools/backend/network.js +135 -0
  143. package/lib/tools/backend/pdf.js +48 -0
  144. package/lib/tools/backend/response.js +305 -0
  145. package/lib/tools/backend/route.js +140 -0
  146. package/lib/tools/backend/runCode.js +77 -0
  147. package/lib/tools/backend/screenshot.js +88 -0
  148. package/lib/tools/backend/sessionLog.js +74 -0
  149. package/lib/tools/backend/snapshot.js +208 -0
  150. package/lib/tools/backend/storage.js +68 -0
  151. package/lib/tools/backend/tab.js +445 -0
  152. package/lib/tools/backend/tabs.js +67 -0
  153. package/lib/tools/backend/tool.js +47 -0
  154. package/lib/tools/backend/tools.js +102 -0
  155. package/lib/tools/backend/tracing.js +78 -0
  156. package/lib/tools/backend/utils.js +83 -0
  157. package/lib/tools/backend/verify.js +151 -0
  158. package/lib/tools/backend/video.js +98 -0
  159. package/lib/tools/backend/wait.js +63 -0
  160. package/lib/tools/backend/webstorage.js +223 -0
  161. package/lib/tools/cli-client/cli.js +6 -0
  162. package/lib/tools/cli-client/help.json +399 -0
  163. package/lib/tools/cli-client/minimist.js +128 -0
  164. package/lib/tools/cli-client/program.js +350 -0
  165. package/lib/tools/cli-client/registry.js +176 -0
  166. package/lib/tools/cli-client/session.js +289 -0
  167. package/lib/tools/cli-client/skill/SKILL.md +328 -0
  168. package/lib/tools/cli-client/skill/references/element-attributes.md +23 -0
  169. package/lib/tools/cli-client/skill/references/playwright-tests.md +39 -0
  170. package/lib/tools/cli-client/skill/references/request-mocking.md +87 -0
  171. package/lib/tools/cli-client/skill/references/running-code.md +231 -0
  172. package/lib/tools/cli-client/skill/references/session-management.md +169 -0
  173. package/lib/tools/cli-client/skill/references/storage-state.md +275 -0
  174. package/lib/tools/cli-client/skill/references/test-generation.md +88 -0
  175. package/lib/tools/cli-client/skill/references/tracing.md +139 -0
  176. package/lib/tools/cli-client/skill/references/video-recording.md +143 -0
  177. package/lib/tools/cli-daemon/command.js +73 -0
  178. package/lib/tools/cli-daemon/commands.js +956 -0
  179. package/lib/tools/cli-daemon/daemon.js +157 -0
  180. package/lib/tools/cli-daemon/helpGenerator.js +177 -0
  181. package/lib/tools/cli-daemon/program.js +129 -0
  182. package/lib/tools/dashboard/appIcon.png +0 -0
  183. package/lib/tools/dashboard/dashboardApp.js +284 -0
  184. package/lib/tools/dashboard/dashboardController.js +296 -0
  185. package/lib/tools/exports.js +60 -0
  186. package/lib/tools/mcp/browserFactory.js +233 -0
  187. package/lib/tools/mcp/cdpRelay.js +352 -0
  188. package/lib/tools/mcp/cli-stub.js +7 -0
  189. package/lib/tools/mcp/config.d.js +16 -0
  190. package/lib/tools/mcp/config.js +446 -0
  191. package/lib/tools/mcp/configIni.js +189 -0
  192. package/lib/tools/mcp/extensionContextFactory.js +55 -0
  193. package/lib/tools/mcp/index.js +62 -0
  194. package/lib/tools/mcp/log.js +35 -0
  195. package/lib/tools/mcp/program.js +107 -0
  196. package/lib/tools/mcp/protocol.js +28 -0
  197. package/lib/tools/mcp/watchdog.js +44 -0
  198. package/lib/tools/trace/SKILL.md +171 -0
  199. package/lib/{server/trace/viewer/traceParser.js → tools/trace/installSkill.js} +15 -39
  200. package/lib/tools/trace/traceActions.js +142 -0
  201. package/lib/tools/trace/traceAttachments.js +69 -0
  202. package/lib/tools/trace/traceCli.js +87 -0
  203. package/lib/tools/trace/traceConsole.js +97 -0
  204. package/lib/tools/trace/traceErrors.js +55 -0
  205. package/lib/tools/trace/traceOpen.js +69 -0
  206. package/lib/tools/trace/traceParser.js +96 -0
  207. package/lib/tools/trace/traceRequests.js +182 -0
  208. package/lib/tools/trace/traceScreenshot.js +68 -0
  209. package/lib/tools/trace/traceSnapshot.js +149 -0
  210. package/lib/tools/trace/traceUtils.js +153 -0
  211. package/lib/tools/utils/connect.js +32 -0
  212. package/lib/tools/utils/mcp/http.js +152 -0
  213. package/lib/tools/utils/mcp/server.js +230 -0
  214. package/lib/tools/utils/mcp/tool.js +47 -0
  215. package/lib/tools/utils/socketConnection.js +108 -0
  216. package/lib/utils/isomorphic/formatUtils.js +64 -0
  217. package/lib/utils/isomorphic/jsonSchema.js +89 -0
  218. package/lib/utils/isomorphic/mimeType.js +7 -2
  219. package/lib/utils/isomorphic/protocolFormatter.js +2 -2
  220. package/lib/utils/isomorphic/protocolMetainfo.js +127 -106
  221. package/lib/utils/isomorphic/stringUtils.js +3 -3
  222. package/lib/utils/isomorphic/timeoutRunner.js +3 -3
  223. package/lib/utils/isomorphic/trace/snapshotRenderer.js +35 -42
  224. package/lib/utils/isomorphic/trace/traceLoader.js +15 -14
  225. package/lib/utils/isomorphic/trace/traceModel.js +3 -2
  226. package/lib/utils/isomorphic/trace/traceModernizer.js +1 -0
  227. package/lib/utils/isomorphic/urlMatch.js +54 -1
  228. package/lib/utils/isomorphic/utilityScriptSerializers.js +11 -0
  229. package/lib/utils.js +6 -2
  230. package/lib/utilsBundle.js +3 -21
  231. package/lib/utilsBundleImpl/index.js +132 -133
  232. package/lib/vite/dashboard/assets/index-BAOybkp8.js +50 -0
  233. package/lib/vite/dashboard/assets/index-CZAYOG76.css +1 -0
  234. package/lib/vite/dashboard/index.html +28 -0
  235. package/lib/vite/htmlReport/index.html +2 -70
  236. package/lib/vite/htmlReport/report.css +1 -0
  237. package/lib/vite/htmlReport/report.js +72 -0
  238. package/lib/vite/recorder/assets/{codeMirrorModule-DadYNm1I.js → codeMirrorModule-C8KMvO9L.js} +20 -20
  239. package/lib/vite/recorder/assets/index-CqAYX1I3.js +193 -0
  240. package/lib/vite/recorder/index.html +1 -1
  241. package/lib/vite/traceViewer/assets/{codeMirrorModule-a5XoALAZ.js → codeMirrorModule-DS0FLvoc.js} +20 -20
  242. package/lib/vite/traceViewer/assets/defaultSettingsView-GTWI-W_B.js +262 -0
  243. package/lib/vite/traceViewer/defaultSettingsView.B4dS75f0.css +1 -0
  244. package/lib/vite/traceViewer/{index.BVu7tZDe.css → index.CzXZzn5A.css} +1 -1
  245. package/lib/vite/traceViewer/{index.BDwrLSGN.js → index.Dtstcb7U.js} +1 -1
  246. package/lib/vite/traceViewer/index.html +4 -4
  247. package/lib/vite/traceViewer/sw.bundle.js +4 -4
  248. package/lib/vite/traceViewer/uiMode.Vipi55dB.js +6 -0
  249. package/lib/vite/traceViewer/uiMode.html +3 -3
  250. package/lib/zipBundleImpl.js +2 -2
  251. package/lib/zodBundle.js +39 -0
  252. package/lib/zodBundleImpl.js +40 -0
  253. package/package.json +6 -1
  254. package/types/protocol.d.ts +947 -51
  255. package/types/types.d.ts +854 -74
  256. package/lib/client/pageAgent.js +0 -64
  257. package/lib/mcpBundleImpl/index.js +0 -147
  258. package/lib/server/agent/actionRunner.js +0 -335
  259. package/lib/server/agent/actions.js +0 -128
  260. package/lib/server/agent/codegen.js +0 -111
  261. package/lib/server/agent/context.js +0 -150
  262. package/lib/server/agent/expectTools.js +0 -156
  263. package/lib/server/agent/pageAgent.js +0 -204
  264. package/lib/server/agent/performTools.js +0 -262
  265. package/lib/server/agent/tool.js +0 -109
  266. package/lib/server/dispatchers/pageAgentDispatcher.js +0 -96
  267. package/lib/vite/recorder/assets/index-BhTWtUlo.js +0 -193
  268. package/lib/vite/traceViewer/assets/defaultSettingsView-CJSZINFr.js +0 -266
  269. package/lib/vite/traceViewer/defaultSettingsView.7ch9cixO.css +0 -1
  270. package/lib/vite/traceViewer/uiMode.CQJ9SCIQ.js +0 -5
  271. /package/lib/{server/utils → utils/isomorphic}/imageUtils.js +0 -0
  272. /package/lib/utils/isomorphic/{traceUtils.js → trace/traceUtils.js} +0 -0
@@ -0,0 +1,87 @@
1
+ # Request Mocking
2
+
3
+ Intercept, mock, modify, and block network requests.
4
+
5
+ ## CLI Route Commands
6
+
7
+ ```bash
8
+ # Mock with custom status
9
+ playwright-cli route "**/*.jpg" --status=404
10
+
11
+ # Mock with JSON body
12
+ playwright-cli route "**/api/users" --body='[{"id":1,"name":"Alice"}]' --content-type=application/json
13
+
14
+ # Mock with custom headers
15
+ playwright-cli route "**/api/data" --body='{"ok":true}' --header="X-Custom: value"
16
+
17
+ # Remove headers from requests
18
+ playwright-cli route "**/*" --remove-header=cookie,authorization
19
+
20
+ # List active routes
21
+ playwright-cli route-list
22
+
23
+ # Remove a route or all routes
24
+ playwright-cli unroute "**/*.jpg"
25
+ playwright-cli unroute
26
+ ```
27
+
28
+ ## URL Patterns
29
+
30
+ ```
31
+ **/api/users - Exact path match
32
+ **/api/*/details - Wildcard in path
33
+ **/*.{png,jpg,jpeg} - Match file extensions
34
+ **/search?q=* - Match query parameters
35
+ ```
36
+
37
+ ## Advanced Mocking with run-code
38
+
39
+ For conditional responses, request body inspection, response modification, or delays:
40
+
41
+ ### Conditional Response Based on Request
42
+
43
+ ```bash
44
+ playwright-cli run-code "async page => {
45
+ await page.route('**/api/login', route => {
46
+ const body = route.request().postDataJSON();
47
+ if (body.username === 'admin') {
48
+ route.fulfill({ body: JSON.stringify({ token: 'mock-token' }) });
49
+ } else {
50
+ route.fulfill({ status: 401, body: JSON.stringify({ error: 'Invalid' }) });
51
+ }
52
+ });
53
+ }"
54
+ ```
55
+
56
+ ### Modify Real Response
57
+
58
+ ```bash
59
+ playwright-cli run-code "async page => {
60
+ await page.route('**/api/user', async route => {
61
+ const response = await route.fetch();
62
+ const json = await response.json();
63
+ json.isPremium = true;
64
+ await route.fulfill({ response, json });
65
+ });
66
+ }"
67
+ ```
68
+
69
+ ### Simulate Network Failures
70
+
71
+ ```bash
72
+ playwright-cli run-code "async page => {
73
+ await page.route('**/api/offline', route => route.abort('internetdisconnected'));
74
+ }"
75
+ # Options: connectionrefused, timedout, connectionreset, internetdisconnected
76
+ ```
77
+
78
+ ### Delayed Response
79
+
80
+ ```bash
81
+ playwright-cli run-code "async page => {
82
+ await page.route('**/api/slow', async route => {
83
+ await new Promise(r => setTimeout(r, 3000));
84
+ route.fulfill({ body: JSON.stringify({ data: 'loaded' }) });
85
+ });
86
+ }"
87
+ ```
@@ -0,0 +1,231 @@
1
+ # Running Custom Playwright Code
2
+
3
+ Use `run-code` to execute arbitrary Playwright code for advanced scenarios not covered by CLI commands.
4
+
5
+ ## Syntax
6
+
7
+ ```bash
8
+ playwright-cli run-code "async page => {
9
+ // Your Playwright code here
10
+ // Access page.context() for browser context operations
11
+ }"
12
+ ```
13
+
14
+ ## Geolocation
15
+
16
+ ```bash
17
+ # Grant geolocation permission and set location
18
+ playwright-cli run-code "async page => {
19
+ await page.context().grantPermissions(['geolocation']);
20
+ await page.context().setGeolocation({ latitude: 37.7749, longitude: -122.4194 });
21
+ }"
22
+
23
+ # Set location to London
24
+ playwright-cli run-code "async page => {
25
+ await page.context().grantPermissions(['geolocation']);
26
+ await page.context().setGeolocation({ latitude: 51.5074, longitude: -0.1278 });
27
+ }"
28
+
29
+ # Clear geolocation override
30
+ playwright-cli run-code "async page => {
31
+ await page.context().clearPermissions();
32
+ }"
33
+ ```
34
+
35
+ ## Permissions
36
+
37
+ ```bash
38
+ # Grant multiple permissions
39
+ playwright-cli run-code "async page => {
40
+ await page.context().grantPermissions([
41
+ 'geolocation',
42
+ 'notifications',
43
+ 'camera',
44
+ 'microphone'
45
+ ]);
46
+ }"
47
+
48
+ # Grant permissions for specific origin
49
+ playwright-cli run-code "async page => {
50
+ await page.context().grantPermissions(['clipboard-read'], {
51
+ origin: 'https://example.com'
52
+ });
53
+ }"
54
+ ```
55
+
56
+ ## Media Emulation
57
+
58
+ ```bash
59
+ # Emulate dark color scheme
60
+ playwright-cli run-code "async page => {
61
+ await page.emulateMedia({ colorScheme: 'dark' });
62
+ }"
63
+
64
+ # Emulate light color scheme
65
+ playwright-cli run-code "async page => {
66
+ await page.emulateMedia({ colorScheme: 'light' });
67
+ }"
68
+
69
+ # Emulate reduced motion
70
+ playwright-cli run-code "async page => {
71
+ await page.emulateMedia({ reducedMotion: 'reduce' });
72
+ }"
73
+
74
+ # Emulate print media
75
+ playwright-cli run-code "async page => {
76
+ await page.emulateMedia({ media: 'print' });
77
+ }"
78
+ ```
79
+
80
+ ## Wait Strategies
81
+
82
+ ```bash
83
+ # Wait for network idle
84
+ playwright-cli run-code "async page => {
85
+ await page.waitForLoadState('networkidle');
86
+ }"
87
+
88
+ # Wait for specific element
89
+ playwright-cli run-code "async page => {
90
+ await page.locator('.loading').waitFor({ state: 'hidden' });
91
+ }"
92
+
93
+ # Wait for function to return true
94
+ playwright-cli run-code "async page => {
95
+ await page.waitForFunction(() => window.appReady === true);
96
+ }"
97
+
98
+ # Wait with timeout
99
+ playwright-cli run-code "async page => {
100
+ await page.locator('.result').waitFor({ timeout: 10000 });
101
+ }"
102
+ ```
103
+
104
+ ## Frames and Iframes
105
+
106
+ ```bash
107
+ # Work with iframe
108
+ playwright-cli run-code "async page => {
109
+ const frame = page.locator('iframe#my-iframe').contentFrame();
110
+ await frame.locator('button').click();
111
+ }"
112
+
113
+ # Get all frames
114
+ playwright-cli run-code "async page => {
115
+ const frames = page.frames();
116
+ return frames.map(f => f.url());
117
+ }"
118
+ ```
119
+
120
+ ## File Downloads
121
+
122
+ ```bash
123
+ # Handle file download
124
+ playwright-cli run-code "async page => {
125
+ const downloadPromise = page.waitForEvent('download');
126
+ await page.getByRole('link', { name: 'Download' }).click();
127
+ const download = await downloadPromise;
128
+ await download.saveAs('./downloaded-file.pdf');
129
+ return download.suggestedFilename();
130
+ }"
131
+ ```
132
+
133
+ ## Clipboard
134
+
135
+ ```bash
136
+ # Read clipboard (requires permission)
137
+ playwright-cli run-code "async page => {
138
+ await page.context().grantPermissions(['clipboard-read']);
139
+ return await page.evaluate(() => navigator.clipboard.readText());
140
+ }"
141
+
142
+ # Write to clipboard
143
+ playwright-cli run-code "async page => {
144
+ await page.evaluate(text => navigator.clipboard.writeText(text), 'Hello clipboard!');
145
+ }"
146
+ ```
147
+
148
+ ## Page Information
149
+
150
+ ```bash
151
+ # Get page title
152
+ playwright-cli run-code "async page => {
153
+ return await page.title();
154
+ }"
155
+
156
+ # Get current URL
157
+ playwright-cli run-code "async page => {
158
+ return page.url();
159
+ }"
160
+
161
+ # Get page content
162
+ playwright-cli run-code "async page => {
163
+ return await page.content();
164
+ }"
165
+
166
+ # Get viewport size
167
+ playwright-cli run-code "async page => {
168
+ return page.viewportSize();
169
+ }"
170
+ ```
171
+
172
+ ## JavaScript Execution
173
+
174
+ ```bash
175
+ # Execute JavaScript and return result
176
+ playwright-cli run-code "async page => {
177
+ return await page.evaluate(() => {
178
+ return {
179
+ userAgent: navigator.userAgent,
180
+ language: navigator.language,
181
+ cookiesEnabled: navigator.cookieEnabled
182
+ };
183
+ });
184
+ }"
185
+
186
+ # Pass arguments to evaluate
187
+ playwright-cli run-code "async page => {
188
+ const multiplier = 5;
189
+ return await page.evaluate(m => document.querySelectorAll('li').length * m, multiplier);
190
+ }"
191
+ ```
192
+
193
+ ## Error Handling
194
+
195
+ ```bash
196
+ # Try-catch in run-code
197
+ playwright-cli run-code "async page => {
198
+ try {
199
+ await page.getByRole('button', { name: 'Submit' }).click({ timeout: 1000 });
200
+ return 'clicked';
201
+ } catch (e) {
202
+ return 'element not found';
203
+ }
204
+ }"
205
+ ```
206
+
207
+ ## Complex Workflows
208
+
209
+ ```bash
210
+ # Login and save state
211
+ playwright-cli run-code "async page => {
212
+ await page.goto('https://example.com/login');
213
+ await page.getByRole('textbox', { name: 'Email' }).fill('user@example.com');
214
+ await page.getByRole('textbox', { name: 'Password' }).fill('secret');
215
+ await page.getByRole('button', { name: 'Sign in' }).click();
216
+ await page.waitForURL('**/dashboard');
217
+ await page.context().storageState({ path: 'auth.json' });
218
+ return 'Login successful';
219
+ }"
220
+
221
+ # Scrape data from multiple pages
222
+ playwright-cli run-code "async page => {
223
+ const results = [];
224
+ for (let i = 1; i <= 3; i++) {
225
+ await page.goto(\`https://example.com/page/\${i}\`);
226
+ const items = await page.locator('.item').allTextContents();
227
+ results.push(...items);
228
+ }
229
+ return results;
230
+ }"
231
+ ```
@@ -0,0 +1,169 @@
1
+ # Browser Session Management
2
+
3
+ Run multiple isolated browser sessions concurrently with state persistence.
4
+
5
+ ## Named Browser Sessions
6
+
7
+ Use `-s` flag to isolate browser contexts:
8
+
9
+ ```bash
10
+ # Browser 1: Authentication flow
11
+ playwright-cli -s=auth open https://app.example.com/login
12
+
13
+ # Browser 2: Public browsing (separate cookies, storage)
14
+ playwright-cli -s=public open https://example.com
15
+
16
+ # Commands are isolated by browser session
17
+ playwright-cli -s=auth fill e1 "user@example.com"
18
+ playwright-cli -s=public snapshot
19
+ ```
20
+
21
+ ## Browser Session Isolation Properties
22
+
23
+ Each browser session has independent:
24
+ - Cookies
25
+ - LocalStorage / SessionStorage
26
+ - IndexedDB
27
+ - Cache
28
+ - Browsing history
29
+ - Open tabs
30
+
31
+ ## Browser Session Commands
32
+
33
+ ```bash
34
+ # List all browser sessions
35
+ playwright-cli list
36
+
37
+ # Stop a browser session (close the browser)
38
+ playwright-cli close # stop the default browser
39
+ playwright-cli -s=mysession close # stop a named browser
40
+
41
+ # Stop all browser sessions
42
+ playwright-cli close-all
43
+
44
+ # Forcefully kill all daemon processes (for stale/zombie processes)
45
+ playwright-cli kill-all
46
+
47
+ # Delete browser session user data (profile directory)
48
+ playwright-cli delete-data # delete default browser data
49
+ playwright-cli -s=mysession delete-data # delete named browser data
50
+ ```
51
+
52
+ ## Environment Variable
53
+
54
+ Set a default browser session name via environment variable:
55
+
56
+ ```bash
57
+ export PLAYWRIGHT_CLI_SESSION="mysession"
58
+ playwright-cli open example.com # Uses "mysession" automatically
59
+ ```
60
+
61
+ ## Common Patterns
62
+
63
+ ### Concurrent Scraping
64
+
65
+ ```bash
66
+ #!/bin/bash
67
+ # Scrape multiple sites concurrently
68
+
69
+ # Start all browsers
70
+ playwright-cli -s=site1 open https://site1.com &
71
+ playwright-cli -s=site2 open https://site2.com &
72
+ playwright-cli -s=site3 open https://site3.com &
73
+ wait
74
+
75
+ # Take snapshots from each
76
+ playwright-cli -s=site1 snapshot
77
+ playwright-cli -s=site2 snapshot
78
+ playwright-cli -s=site3 snapshot
79
+
80
+ # Cleanup
81
+ playwright-cli close-all
82
+ ```
83
+
84
+ ### A/B Testing Sessions
85
+
86
+ ```bash
87
+ # Test different user experiences
88
+ playwright-cli -s=variant-a open "https://app.com?variant=a"
89
+ playwright-cli -s=variant-b open "https://app.com?variant=b"
90
+
91
+ # Compare
92
+ playwright-cli -s=variant-a screenshot
93
+ playwright-cli -s=variant-b screenshot
94
+ ```
95
+
96
+ ### Persistent Profile
97
+
98
+ By default, browser profile is kept in memory only. Use `--persistent` flag on `open` to persist the browser profile to disk:
99
+
100
+ ```bash
101
+ # Use persistent profile (auto-generated location)
102
+ playwright-cli open https://example.com --persistent
103
+
104
+ # Use persistent profile with custom directory
105
+ playwright-cli open https://example.com --profile=/path/to/profile
106
+ ```
107
+
108
+ ## Default Browser Session
109
+
110
+ When `-s` is omitted, commands use the default browser session:
111
+
112
+ ```bash
113
+ # These use the same default browser session
114
+ playwright-cli open https://example.com
115
+ playwright-cli snapshot
116
+ playwright-cli close # Stops default browser
117
+ ```
118
+
119
+ ## Browser Session Configuration
120
+
121
+ Configure a browser session with specific settings when opening:
122
+
123
+ ```bash
124
+ # Open with config file
125
+ playwright-cli open https://example.com --config=.playwright/my-cli.json
126
+
127
+ # Open with specific browser
128
+ playwright-cli open https://example.com --browser=firefox
129
+
130
+ # Open in headed mode
131
+ playwright-cli open https://example.com --headed
132
+
133
+ # Open with persistent profile
134
+ playwright-cli open https://example.com --persistent
135
+ ```
136
+
137
+ ## Best Practices
138
+
139
+ ### 1. Name Browser Sessions Semantically
140
+
141
+ ```bash
142
+ # GOOD: Clear purpose
143
+ playwright-cli -s=github-auth open https://github.com
144
+ playwright-cli -s=docs-scrape open https://docs.example.com
145
+
146
+ # AVOID: Generic names
147
+ playwright-cli -s=s1 open https://github.com
148
+ ```
149
+
150
+ ### 2. Always Clean Up
151
+
152
+ ```bash
153
+ # Stop browsers when done
154
+ playwright-cli -s=auth close
155
+ playwright-cli -s=scrape close
156
+
157
+ # Or stop all at once
158
+ playwright-cli close-all
159
+
160
+ # If browsers become unresponsive or zombie processes remain
161
+ playwright-cli kill-all
162
+ ```
163
+
164
+ ### 3. Delete Stale Browser Data
165
+
166
+ ```bash
167
+ # Remove old browser data to free disk space
168
+ playwright-cli -s=oldsession delete-data
169
+ ```