isomorfeus-puppetmaster 0.5.5 → 0.5.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/isomorfeus/puppetmaster/console_message.rb +18 -18
- data/lib/isomorfeus/puppetmaster/cookie.rb +46 -46
- data/lib/isomorfeus/puppetmaster/driver/puppeteer.rb +413 -415
- data/lib/isomorfeus/puppetmaster/driver/puppeteer_document.rb +953 -953
- data/lib/isomorfeus/puppetmaster/driver/puppeteer_node.rb +851 -851
- data/lib/isomorfeus/puppetmaster/errors.rb +90 -90
- data/lib/isomorfeus/puppetmaster/iframe.rb +16 -16
- data/lib/isomorfeus/puppetmaster/node/content_editable.rb +17 -17
- data/lib/isomorfeus/puppetmaster/node/input.rb +20 -20
- data/lib/isomorfeus/puppetmaster/node/select.rb +35 -35
- data/lib/isomorfeus/puppetmaster/node.rb +279 -279
- data/lib/isomorfeus/puppetmaster/request.rb +16 -16
- data/lib/isomorfeus/puppetmaster/response.rb +25 -25
- data/lib/isomorfeus/puppetmaster/self_forwardable.rb +38 -38
- data/lib/isomorfeus/puppetmaster/version.rb +3 -3
- data/lib/isomorfeus/puppetmaster.rb +85 -85
- data/lib/isomorfeus-puppetmaster.rb +1 -0
- data/node_modules/.bin/extract-zip +12 -12
- data/node_modules/.bin/extract-zip.ps1 +28 -28
- data/node_modules/.bin/rimraf +12 -12
- data/node_modules/.bin/rimraf.ps1 +28 -28
- data/node_modules/.package-lock.json +530 -585
- data/node_modules/@types/node/LICENSE +21 -21
- data/node_modules/@types/node/assert/strict.d.ts +8 -8
- data/node_modules/@types/node/assert.d.ts +912 -912
- data/node_modules/@types/node/async_hooks.d.ts +497 -497
- data/node_modules/@types/node/buffer.d.ts +2142 -2142
- data/node_modules/@types/node/child_process.d.ts +1355 -1355
- data/node_modules/@types/node/cluster.d.ts +414 -414
- data/node_modules/@types/node/console.d.ts +407 -407
- data/node_modules/@types/node/constants.d.ts +18 -18
- data/node_modules/@types/node/crypto.d.ts +3224 -3224
- data/node_modules/@types/node/dgram.d.ts +545 -545
- data/node_modules/@types/node/diagnostics_channel.d.ts +128 -128
- data/node_modules/@types/node/dns/promises.d.ts +357 -357
- data/node_modules/@types/node/dns.d.ts +643 -643
- data/node_modules/@types/node/domain.d.ts +169 -169
- data/node_modules/@types/node/events.d.ts +623 -623
- data/node_modules/@types/node/fs/promises.d.ts +997 -997
- data/node_modules/@types/node/fs.d.ts +3723 -3723
- data/node_modules/@types/node/globals.d.ts +285 -285
- data/node_modules/@types/node/globals.global.d.ts +1 -1
- data/node_modules/@types/node/http.d.ts +1358 -1358
- data/node_modules/@types/node/http2.d.ts +2100 -2100
- data/node_modules/@types/node/https.d.ts +391 -391
- data/node_modules/@types/node/index.d.ts +131 -131
- data/node_modules/@types/node/inspector.d.ts +2738 -2738
- data/node_modules/@types/node/module.d.ts +114 -114
- data/node_modules/@types/node/net.d.ts +783 -783
- data/node_modules/@types/node/os.d.ts +455 -455
- data/node_modules/@types/node/package.json +229 -229
- data/node_modules/@types/node/path.d.ts +172 -172
- data/node_modules/@types/node/perf_hooks.d.ts +555 -555
- data/node_modules/@types/node/process.d.ts +1477 -1477
- data/node_modules/@types/node/punycode.d.ts +117 -117
- data/node_modules/@types/node/querystring.d.ts +131 -131
- data/node_modules/@types/node/readline.d.ts +542 -542
- data/node_modules/@types/node/repl.d.ts +424 -424
- data/node_modules/@types/node/stream/consumers.d.ts +24 -24
- data/node_modules/@types/node/stream/promises.d.ts +42 -42
- data/node_modules/@types/node/stream/web.d.ts +6 -6
- data/node_modules/@types/node/stream.d.ts +1181 -1181
- data/node_modules/@types/node/string_decoder.d.ts +67 -67
- data/node_modules/@types/node/timers/promises.d.ts +68 -68
- data/node_modules/@types/node/timers.d.ts +94 -94
- data/node_modules/@types/node/tls.d.ts +1019 -1019
- data/node_modules/@types/node/trace_events.d.ts +161 -161
- data/node_modules/@types/node/tty.d.ts +206 -206
- data/node_modules/@types/node/url.d.ts +798 -798
- data/node_modules/@types/node/util.d.ts +1556 -1556
- data/node_modules/@types/node/v8.d.ts +378 -378
- data/node_modules/@types/node/vm.d.ts +504 -504
- data/node_modules/@types/node/wasi.d.ts +153 -153
- data/node_modules/@types/node/worker_threads.d.ts +649 -649
- data/node_modules/@types/node/zlib.d.ts +517 -517
- data/node_modules/@types/yauzl/LICENSE +21 -21
- data/node_modules/@types/yauzl/index.d.ts +98 -98
- data/node_modules/@types/yauzl/package.json +26 -26
- data/node_modules/agent-base/README.md +145 -145
- data/node_modules/agent-base/dist/src/index.d.ts +78 -78
- data/node_modules/agent-base/dist/src/index.js +202 -202
- data/node_modules/agent-base/dist/src/promisify.d.ts +4 -4
- data/node_modules/agent-base/dist/src/promisify.js +17 -17
- data/node_modules/agent-base/package.json +64 -64
- data/node_modules/agent-base/src/index.ts +345 -345
- data/node_modules/agent-base/src/promisify.ts +33 -33
- data/node_modules/balanced-match/.github/FUNDING.yml +2 -2
- data/node_modules/balanced-match/LICENSE.md +21 -21
- data/node_modules/balanced-match/README.md +97 -97
- data/node_modules/balanced-match/index.js +62 -62
- data/node_modules/balanced-match/package.json +48 -48
- data/node_modules/base64-js/LICENSE +21 -21
- data/node_modules/base64-js/README.md +34 -34
- data/node_modules/base64-js/index.d.ts +3 -3
- data/node_modules/base64-js/index.js +150 -150
- data/node_modules/base64-js/package.json +47 -47
- data/node_modules/bl/.travis.yml +17 -17
- data/node_modules/bl/BufferList.js +396 -396
- data/node_modules/bl/LICENSE.md +13 -13
- data/node_modules/bl/README.md +247 -247
- data/node_modules/bl/bl.js +84 -84
- data/node_modules/bl/package.json +37 -37
- data/node_modules/bl/test/convert.js +21 -21
- data/node_modules/bl/test/indexOf.js +492 -492
- data/node_modules/bl/test/isBufferList.js +32 -32
- data/node_modules/bl/test/test.js +869 -869
- data/node_modules/brace-expansion/LICENSE +21 -21
- data/node_modules/brace-expansion/README.md +129 -129
- data/node_modules/brace-expansion/index.js +201 -201
- data/node_modules/brace-expansion/package.json +47 -47
- data/node_modules/buffer/AUTHORS.md +70 -70
- data/node_modules/buffer/LICENSE +21 -21
- data/node_modules/buffer/README.md +410 -410
- data/node_modules/buffer/index.d.ts +186 -186
- data/node_modules/buffer/index.js +1817 -1817
- data/node_modules/buffer/package.json +96 -96
- data/node_modules/buffer-crc32/LICENSE +19 -19
- data/node_modules/buffer-crc32/README.md +47 -47
- data/node_modules/buffer-crc32/index.js +111 -111
- data/node_modules/buffer-crc32/package.json +39 -39
- data/node_modules/chownr/LICENSE +15 -15
- data/node_modules/chownr/README.md +3 -3
- data/node_modules/chownr/chownr.js +167 -167
- data/node_modules/chownr/package.json +29 -29
- data/node_modules/concat-map/.travis.yml +4 -4
- data/node_modules/concat-map/LICENSE +18 -18
- data/node_modules/concat-map/README.markdown +62 -62
- data/node_modules/concat-map/example/map.js +6 -6
- data/node_modules/concat-map/index.js +13 -13
- data/node_modules/concat-map/package.json +43 -43
- data/node_modules/concat-map/test/map.js +39 -39
- data/node_modules/debug/LICENSE +19 -19
- data/node_modules/debug/README.md +455 -455
- data/node_modules/debug/package.json +59 -59
- data/node_modules/debug/src/browser.js +269 -269
- data/node_modules/debug/src/common.js +274 -274
- data/node_modules/debug/src/index.js +10 -10
- data/node_modules/debug/src/node.js +263 -263
- data/node_modules/devtools-protocol/LICENSE +27 -27
- data/node_modules/devtools-protocol/README.md +12 -12
- data/node_modules/devtools-protocol/json/browser_protocol.json +20985 -20640
- data/node_modules/devtools-protocol/json/js_protocol.json +3531 -3580
- data/node_modules/devtools-protocol/package.json +17 -18
- data/node_modules/devtools-protocol/pdl/browser_protocol.pdl +9849 -9637
- data/node_modules/devtools-protocol/pdl/js_protocol.pdl +1653 -1678
- data/node_modules/devtools-protocol/types/protocol-mapping.d.ts +4333 -4321
- data/node_modules/devtools-protocol/types/protocol-proxy-api.d.ts +3695 -3683
- data/node_modules/devtools-protocol/types/protocol.d.ts +15714 -15538
- data/node_modules/end-of-stream/LICENSE +20 -20
- data/node_modules/end-of-stream/README.md +54 -54
- data/node_modules/end-of-stream/index.js +94 -94
- data/node_modules/end-of-stream/package.json +37 -37
- data/node_modules/extract-zip/LICENSE +23 -23
- data/node_modules/extract-zip/cli.js +19 -19
- data/node_modules/extract-zip/index.d.ts +21 -21
- data/node_modules/extract-zip/index.js +173 -173
- data/node_modules/extract-zip/package.json +80 -80
- data/node_modules/extract-zip/readme.md +57 -57
- data/node_modules/fd-slicer/.npmignore +2 -2
- data/node_modules/fd-slicer/.travis.yml +7 -7
- data/node_modules/fd-slicer/CHANGELOG.md +49 -49
- data/node_modules/fd-slicer/LICENSE +21 -21
- data/node_modules/fd-slicer/README.md +199 -199
- data/node_modules/fd-slicer/index.js +296 -296
- data/node_modules/fd-slicer/package.json +36 -36
- data/node_modules/fd-slicer/test/test.js +350 -350
- data/node_modules/find-up/index.d.ts +137 -137
- data/node_modules/find-up/index.js +89 -89
- data/node_modules/find-up/license +9 -9
- data/node_modules/find-up/package.json +53 -53
- data/node_modules/find-up/readme.md +156 -156
- data/node_modules/fs-constants/LICENSE +21 -21
- data/node_modules/fs-constants/README.md +26 -26
- data/node_modules/fs-constants/browser.js +1 -1
- data/node_modules/fs-constants/index.js +1 -1
- data/node_modules/fs-constants/package.json +19 -19
- data/node_modules/fs.realpath/LICENSE +43 -43
- data/node_modules/fs.realpath/README.md +33 -33
- data/node_modules/fs.realpath/index.js +66 -66
- data/node_modules/fs.realpath/old.js +303 -303
- data/node_modules/fs.realpath/package.json +26 -26
- data/node_modules/get-stream/buffer-stream.js +52 -52
- data/node_modules/get-stream/index.d.ts +108 -108
- data/node_modules/get-stream/index.js +60 -60
- data/node_modules/get-stream/license +9 -9
- data/node_modules/get-stream/package.json +50 -50
- data/node_modules/get-stream/readme.md +124 -124
- data/node_modules/glob/LICENSE +21 -21
- data/node_modules/glob/README.md +375 -375
- data/node_modules/glob/changelog.md +67 -67
- data/node_modules/glob/common.js +234 -234
- data/node_modules/glob/glob.js +788 -788
- data/node_modules/glob/package.json +51 -51
- data/node_modules/glob/sync.js +484 -484
- data/node_modules/https-proxy-agent/README.md +137 -137
- data/node_modules/https-proxy-agent/dist/agent.d.ts +30 -30
- data/node_modules/https-proxy-agent/dist/agent.js +179 -179
- data/node_modules/https-proxy-agent/dist/index.d.ts +23 -23
- data/node_modules/https-proxy-agent/dist/index.js +13 -13
- data/node_modules/https-proxy-agent/dist/parse-proxy-response.d.ts +7 -7
- data/node_modules/https-proxy-agent/dist/parse-proxy-response.js +65 -65
- data/node_modules/https-proxy-agent/package.json +56 -56
- data/node_modules/ieee754/LICENSE +11 -11
- data/node_modules/ieee754/README.md +51 -51
- data/node_modules/ieee754/index.d.ts +9 -9
- data/node_modules/ieee754/index.js +85 -85
- data/node_modules/ieee754/package.json +52 -52
- data/node_modules/inflight/LICENSE +15 -15
- data/node_modules/inflight/README.md +37 -37
- data/node_modules/inflight/inflight.js +54 -54
- data/node_modules/inflight/package.json +29 -29
- data/node_modules/inherits/LICENSE +16 -16
- data/node_modules/inherits/README.md +42 -42
- data/node_modules/inherits/inherits.js +9 -9
- data/node_modules/inherits/inherits_browser.js +27 -27
- data/node_modules/inherits/package.json +29 -29
- data/node_modules/locate-path/index.d.ts +83 -83
- data/node_modules/locate-path/index.js +65 -65
- data/node_modules/locate-path/license +9 -9
- data/node_modules/locate-path/package.json +45 -45
- data/node_modules/locate-path/readme.md +122 -122
- data/node_modules/minimatch/LICENSE +15 -15
- data/node_modules/minimatch/README.md +209 -209
- data/node_modules/minimatch/minimatch.js +923 -923
- data/node_modules/minimatch/package.json +30 -30
- data/node_modules/mkdirp-classic/LICENSE +21 -21
- data/node_modules/mkdirp-classic/README.md +18 -18
- data/node_modules/mkdirp-classic/index.js +98 -98
- data/node_modules/mkdirp-classic/package.json +18 -18
- data/node_modules/ms/index.js +162 -162
- data/node_modules/ms/license.md +21 -21
- data/node_modules/ms/package.json +37 -37
- data/node_modules/ms/readme.md +60 -60
- data/node_modules/node-fetch/LICENSE.md +22 -22
- data/node_modules/node-fetch/README.md +590 -590
- data/node_modules/node-fetch/browser.js +24 -24
- data/node_modules/node-fetch/lib/index.es.js +1662 -1662
- data/node_modules/node-fetch/lib/index.js +1671 -1671
- data/node_modules/node-fetch/lib/index.mjs +1660 -1660
- data/node_modules/node-fetch/package.json +68 -68
- data/node_modules/once/LICENSE +15 -15
- data/node_modules/once/README.md +79 -79
- data/node_modules/once/once.js +42 -42
- data/node_modules/once/package.json +33 -33
- data/node_modules/p-limit/index.d.ts +38 -38
- data/node_modules/p-limit/index.js +57 -57
- data/node_modules/p-limit/license +9 -9
- data/node_modules/p-limit/package.json +52 -52
- data/node_modules/p-limit/readme.md +101 -101
- data/node_modules/p-locate/index.d.ts +64 -64
- data/node_modules/p-locate/index.js +52 -52
- data/node_modules/p-locate/license +9 -9
- data/node_modules/p-locate/package.json +53 -53
- data/node_modules/p-locate/readme.md +90 -90
- data/node_modules/p-try/index.d.ts +39 -39
- data/node_modules/p-try/index.js +9 -9
- data/node_modules/p-try/license +9 -9
- data/node_modules/p-try/package.json +42 -42
- data/node_modules/p-try/readme.md +58 -58
- data/node_modules/path-exists/index.d.ts +28 -28
- data/node_modules/path-exists/index.js +23 -23
- data/node_modules/path-exists/license +9 -9
- data/node_modules/path-exists/package.json +39 -39
- data/node_modules/path-exists/readme.md +52 -52
- data/node_modules/path-is-absolute/index.js +20 -20
- data/node_modules/path-is-absolute/license +21 -21
- data/node_modules/path-is-absolute/package.json +43 -43
- data/node_modules/path-is-absolute/readme.md +59 -59
- data/node_modules/pend/LICENSE +23 -23
- data/node_modules/pend/README.md +41 -41
- data/node_modules/pend/index.js +55 -55
- data/node_modules/pend/package.json +18 -18
- data/node_modules/pend/test.js +137 -137
- data/node_modules/pkg-dir/index.d.ts +44 -44
- data/node_modules/pkg-dir/index.js +17 -17
- data/node_modules/pkg-dir/license +9 -9
- data/node_modules/pkg-dir/package.json +56 -56
- data/node_modules/pkg-dir/readme.md +66 -66
- data/node_modules/progress/CHANGELOG.md +115 -115
- data/node_modules/progress/LICENSE +22 -22
- data/node_modules/progress/Makefile +8 -8
- data/node_modules/progress/Readme.md +146 -146
- data/node_modules/progress/index.js +1 -1
- data/node_modules/progress/lib/node-progress.js +236 -236
- data/node_modules/progress/package.json +26 -26
- data/node_modules/proxy-from-env/.eslintrc +29 -29
- data/node_modules/proxy-from-env/.travis.yml +10 -10
- data/node_modules/proxy-from-env/LICENSE +20 -20
- data/node_modules/proxy-from-env/README.md +131 -131
- data/node_modules/proxy-from-env/index.js +108 -108
- data/node_modules/proxy-from-env/package.json +34 -34
- data/node_modules/proxy-from-env/test.js +483 -483
- data/node_modules/pump/.travis.yml +5 -5
- data/node_modules/pump/LICENSE +20 -20
- data/node_modules/pump/README.md +65 -65
- data/node_modules/pump/index.js +82 -82
- data/node_modules/pump/package.json +24 -24
- data/node_modules/pump/test-browser.js +66 -66
- data/node_modules/pump/test-node.js +53 -53
- data/node_modules/puppeteer-core/CHANGELOG.md +319 -290
- data/node_modules/puppeteer-core/LICENSE +202 -202
- data/node_modules/puppeteer-core/README.md +481 -481
- data/node_modules/puppeteer-core/cjs-entry-core.js +29 -29
- data/node_modules/puppeteer-core/cjs-entry.js +29 -29
- data/node_modules/puppeteer-core/install.js +89 -89
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/api-docs-entry.d.ts +110 -110
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/api-docs-entry.js +80 -80
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Accessibility.d.ts +175 -175
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Accessibility.js +360 -360
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.js +84 -84
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Browser.d.ts +455 -455
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Browser.js +540 -540
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserConnector.d.ts +53 -53
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserConnector.js +97 -97
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserWebSocketTransport.d.ts +25 -25
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserWebSocketTransport.js +34 -34
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Connection.d.ts +135 -135
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Connection.js +298 -298
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConnectionTransport.d.ts +24 -24
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConnectionTransport.js +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConsoleMessage.d.ts +72 -72
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConsoleMessage.js +64 -64
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Coverage.d.ts +204 -204
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Coverage.js +335 -335
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DOMWorld.d.ts +175 -175
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DOMWorld.js +662 -662
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Debug.d.ts +52 -52
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Debug.js +81 -81
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DeviceDescriptors.d.ts +40 -40
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DeviceDescriptors.js +1070 -1070
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Dialog.d.ts +74 -74
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Dialog.js +97 -97
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EmulationManager.d.ts +24 -24
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EmulationManager.js +37 -37
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Errors.d.ts +50 -50
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Errors.js +56 -56
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EvalTypes.d.ts +60 -60
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EvalTypes.js +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EventEmitter.d.ts +92 -92
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EventEmitter.js +116 -116
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Events.d.ts +81 -81
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Events.js +86 -86
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ExecutionContext.d.ts +193 -193
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ExecutionContext.js +321 -321
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FileChooser.d.ts +58 -58
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FileChooser.js +71 -71
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.d.ts +744 -744
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.js +1047 -1047
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.d.ts +350 -345
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.js +549 -549
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.d.ts +134 -125
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.js +184 -164
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Input.d.ts +358 -358
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Input.js +543 -543
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/JSHandle.d.ts +490 -490
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/JSHandle.js +827 -827
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.d.ts +65 -65
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.js +149 -148
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkConditions.d.ts +26 -26
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkConditions.js +33 -33
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.d.ts +126 -97
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.js +467 -342
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PDFOptions.d.ts +161 -161
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PDFOptions.js +34 -34
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Page.d.ts +2055 -2055
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Page.js +2533 -2533
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Product.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Product.js +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Puppeteer.d.ts +159 -159
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Puppeteer.js +161 -161
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PuppeteerViewport.d.ts +51 -51
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PuppeteerViewport.js +2 -2
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/QueryHandler.d.ts +64 -64
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/QueryHandler.js +165 -165
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/SecurityDetails.d.ts +60 -60
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/SecurityDetails.js +76 -76
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Target.d.ts +100 -100
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Target.js +145 -145
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TaskQueue.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TaskQueue.js +29 -29
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TimeoutSettings.d.ts +27 -27
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TimeoutSettings.js +47 -47
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Tracing.d.ts +46 -46
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Tracing.js +109 -109
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/USKeyboardLayout.d.ts +39 -39
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/USKeyboardLayout.js +406 -406
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/WebWorker.d.ts +98 -98
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/WebWorker.js +112 -112
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/assert.d.ts +22 -22
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/assert.js +33 -33
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/fetch.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/fetch.js +43 -43
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/helper.d.ts +84 -84
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/helper.js +327 -327
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/environment.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/environment.js +19 -19
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/global.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/global.js +2 -2
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-node.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-node.js +44 -44
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-web.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-web.js +26 -26
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserFetcher.d.ts +133 -133
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserFetcher.js +500 -500
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.d.ts +40 -39
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.js +256 -230
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/LaunchOptions.d.ts +134 -134
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/LaunchOptions.js +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.js +655 -588
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.js.map +1 -1
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/NodeWebSocketTransport.d.ts +26 -26
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/NodeWebSocketTransport.js +47 -47
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/PipeTransport.d.ts +29 -29
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/PipeTransport.js +64 -64
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Puppeteer.d.ts +153 -153
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Puppeteer.js +188 -188
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/install.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/install.js +173 -173
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node-puppeteer-core.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node-puppeteer-core.js +24 -24
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/node.js +23 -23
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/revisions.d.ts +21 -21
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/revisions.js +22 -22
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/web.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/cjs/puppeteer/web.js +23 -23
- data/node_modules/puppeteer-core/lib/cjs/vendor/mitt/src/index.d.ts +27 -27
- data/node_modules/puppeteer-core/lib/cjs/vendor/mitt/src/index.js +56 -56
- data/node_modules/puppeteer-core/lib/esm/puppeteer/api-docs-entry.d.ts +110 -110
- data/node_modules/puppeteer-core/lib/esm/puppeteer/api-docs-entry.js +80 -80
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Accessibility.d.ts +175 -175
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Accessibility.js +356 -356
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.js +81 -81
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Browser.d.ts +455 -455
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Browser.js +535 -535
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserConnector.d.ts +53 -53
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserConnector.js +74 -74
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserWebSocketTransport.d.ts +25 -25
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserWebSocketTransport.js +30 -30
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Connection.d.ts +135 -135
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Connection.js +293 -293
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConnectionTransport.d.ts +24 -24
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConnectionTransport.js +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConsoleMessage.d.ts +72 -72
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConsoleMessage.js +60 -60
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Coverage.d.ts +204 -204
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Coverage.js +329 -329
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DOMWorld.d.ts +175 -175
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DOMWorld.js +657 -657
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Debug.d.ts +52 -52
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Debug.js +77 -77
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DeviceDescriptors.d.ts +40 -40
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DeviceDescriptors.js +1067 -1067
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Dialog.d.ts +74 -74
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Dialog.js +93 -93
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EmulationManager.d.ts +24 -24
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EmulationManager.js +33 -33
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Errors.d.ts +50 -50
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Errors.js +50 -50
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EvalTypes.d.ts +60 -60
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EvalTypes.js +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EventEmitter.d.ts +92 -92
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EventEmitter.js +109 -109
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Events.d.ts +81 -81
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Events.js +83 -83
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ExecutionContext.d.ts +193 -193
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ExecutionContext.js +317 -317
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FileChooser.d.ts +58 -58
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FileChooser.js +67 -67
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.d.ts +744 -744
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.js +1042 -1042
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.d.ts +350 -345
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.js +545 -545
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.d.ts +134 -125
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.js +180 -160
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Input.d.ts +358 -358
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Input.js +537 -537
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/JSHandle.d.ts +490 -490
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/JSHandle.js +802 -802
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.d.ts +65 -65
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.js +145 -144
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkConditions.d.ts +26 -26
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkConditions.js +30 -30
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.d.ts +126 -97
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.js +463 -338
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PDFOptions.d.ts +161 -161
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PDFOptions.js +31 -31
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Page.d.ts +2055 -2055
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Page.js +2529 -2529
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Product.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Product.js +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Puppeteer.d.ts +159 -159
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Puppeteer.js +157 -157
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PuppeteerViewport.d.ts +51 -51
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PuppeteerViewport.js +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/QueryHandler.d.ts +64 -64
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/QueryHandler.js +157 -157
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/SecurityDetails.d.ts +60 -60
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/SecurityDetails.js +72 -72
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Target.d.ts +100 -100
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Target.js +141 -141
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TaskQueue.d.ts +20 -20
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TaskQueue.js +25 -25
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TimeoutSettings.d.ts +27 -27
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TimeoutSettings.js +43 -43
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Tracing.d.ts +46 -46
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Tracing.js +105 -105
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/USKeyboardLayout.d.ts +39 -39
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/USKeyboardLayout.js +403 -403
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/WebWorker.d.ts +98 -98
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/WebWorker.js +108 -108
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/assert.d.ts +22 -22
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/assert.js +28 -28
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/fetch.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/fetch.js +20 -20
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/helper.d.ts +84 -84
- data/node_modules/puppeteer-core/lib/esm/puppeteer/common/helper.js +305 -305
- data/node_modules/puppeteer-core/lib/esm/puppeteer/environment.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/environment.js +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/global.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/global.js +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-node.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-node.js +37 -37
- data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-web.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-web.js +22 -22
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserFetcher.d.ts +133 -133
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserFetcher.js +474 -474
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.d.ts +40 -39
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.js +230 -204
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/LaunchOptions.d.ts +134 -134
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/LaunchOptions.js +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.d.ts +16 -16
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.d.ts.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.js +633 -566
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.js.map +1 -1
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/NodeWebSocketTransport.d.ts +26 -26
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/NodeWebSocketTransport.js +40 -40
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/PipeTransport.d.ts +29 -29
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/PipeTransport.js +60 -60
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Puppeteer.d.ts +153 -153
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Puppeteer.js +181 -181
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/install.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node/install.js +165 -165
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node-puppeteer-core.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node-puppeteer-core.js +22 -22
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/node.js +21 -21
- data/node_modules/puppeteer-core/lib/esm/puppeteer/revisions.d.ts +21 -21
- data/node_modules/puppeteer-core/lib/esm/puppeteer/revisions.js +19 -19
- data/node_modules/puppeteer-core/lib/esm/puppeteer/web.d.ts +17 -17
- data/node_modules/puppeteer-core/lib/esm/puppeteer/web.js +21 -21
- data/node_modules/puppeteer-core/lib/esm/vendor/mitt/src/index.d.ts +27 -27
- data/node_modules/puppeteer-core/lib/esm/vendor/mitt/src/index.js +53 -53
- data/node_modules/puppeteer-core/lib/types.d.ts +67 -25
- data/node_modules/puppeteer-core/package.json +115 -115
- data/node_modules/puppeteer-core/typescript-if-required.js +61 -61
- data/node_modules/readable-stream/CONTRIBUTING.md +38 -38
- data/node_modules/readable-stream/GOVERNANCE.md +136 -136
- data/node_modules/readable-stream/LICENSE +47 -47
- data/node_modules/readable-stream/README.md +106 -106
- data/node_modules/readable-stream/errors-browser.js +127 -127
- data/node_modules/readable-stream/errors.js +116 -116
- data/node_modules/readable-stream/experimentalWarning.js +17 -17
- data/node_modules/readable-stream/lib/_stream_duplex.js +138 -138
- data/node_modules/readable-stream/lib/_stream_passthrough.js +38 -38
- data/node_modules/readable-stream/lib/_stream_readable.js +1123 -1123
- data/node_modules/readable-stream/lib/_stream_transform.js +200 -200
- data/node_modules/readable-stream/lib/_stream_writable.js +696 -696
- data/node_modules/readable-stream/lib/internal/streams/async_iterator.js +206 -206
- data/node_modules/readable-stream/lib/internal/streams/buffer_list.js +209 -209
- data/node_modules/readable-stream/lib/internal/streams/destroy.js +104 -104
- data/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +103 -103
- data/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -3
- data/node_modules/readable-stream/lib/internal/streams/from.js +63 -63
- data/node_modules/readable-stream/lib/internal/streams/pipeline.js +96 -96
- data/node_modules/readable-stream/lib/internal/streams/state.js +26 -26
- data/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -1
- data/node_modules/readable-stream/lib/internal/streams/stream.js +1 -1
- data/node_modules/readable-stream/package.json +68 -68
- data/node_modules/readable-stream/readable-browser.js +9 -9
- data/node_modules/readable-stream/readable.js +16 -16
- data/node_modules/rimraf/CHANGELOG.md +65 -65
- data/node_modules/rimraf/LICENSE +15 -15
- data/node_modules/rimraf/README.md +101 -101
- data/node_modules/rimraf/bin.js +68 -68
- data/node_modules/rimraf/package.json +32 -32
- data/node_modules/rimraf/rimraf.js +360 -360
- data/node_modules/safe-buffer/LICENSE +21 -21
- data/node_modules/safe-buffer/README.md +584 -584
- data/node_modules/safe-buffer/index.d.ts +186 -186
- data/node_modules/safe-buffer/index.js +65 -65
- data/node_modules/safe-buffer/package.json +51 -51
- data/node_modules/string_decoder/LICENSE +48 -48
- data/node_modules/string_decoder/README.md +47 -47
- data/node_modules/string_decoder/lib/string_decoder.js +295 -295
- data/node_modules/string_decoder/package.json +34 -34
- data/node_modules/tar-fs/.travis.yml +6 -6
- data/node_modules/tar-fs/LICENSE +20 -20
- data/node_modules/tar-fs/README.md +165 -165
- data/node_modules/tar-fs/index.js +351 -351
- data/node_modules/tar-fs/package.json +41 -41
- data/node_modules/tar-fs/test/fixtures/a/hello.txt +1 -1
- data/node_modules/tar-fs/test/fixtures/b/a/test.txt +1 -1
- data/node_modules/tar-fs/test/index.js +346 -346
- data/node_modules/tar-stream/LICENSE +20 -20
- data/node_modules/tar-stream/README.md +168 -168
- data/node_modules/tar-stream/extract.js +257 -257
- data/node_modules/tar-stream/headers.js +295 -295
- data/node_modules/tar-stream/index.js +2 -2
- data/node_modules/tar-stream/pack.js +255 -255
- data/node_modules/tar-stream/package.json +58 -58
- data/node_modules/tar-stream/sandbox.js +11 -11
- data/node_modules/through/.travis.yml +5 -5
- data/node_modules/through/LICENSE.APACHE2 +15 -15
- data/node_modules/through/LICENSE.MIT +24 -24
- data/node_modules/through/index.js +108 -108
- data/node_modules/through/package.json +36 -36
- data/node_modules/through/readme.markdown +64 -64
- data/node_modules/through/test/async.js +28 -28
- data/node_modules/through/test/auto-destroy.js +30 -30
- data/node_modules/through/test/buffering.js +71 -71
- data/node_modules/through/test/end.js +45 -45
- data/node_modules/through/test/index.js +133 -133
- data/node_modules/tr46/.npmignore +4 -4
- data/node_modules/tr46/index.js +193 -193
- data/node_modules/tr46/package.json +31 -31
- data/node_modules/unbzip2-stream/LICENSE +24 -24
- data/node_modules/unbzip2-stream/README.md +59 -59
- data/node_modules/unbzip2-stream/dist/unbzip2-stream.min.js +1 -1
- data/node_modules/unbzip2-stream/index.js +93 -93
- data/node_modules/unbzip2-stream/lib/bit_iterator.js +39 -39
- data/node_modules/unbzip2-stream/lib/bzip2.js +365 -365
- data/node_modules/unbzip2-stream/package.json +51 -51
- data/node_modules/util-deprecate/History.md +16 -16
- data/node_modules/util-deprecate/LICENSE +24 -24
- data/node_modules/util-deprecate/README.md +53 -53
- data/node_modules/util-deprecate/browser.js +67 -67
- data/node_modules/util-deprecate/node.js +6 -6
- data/node_modules/util-deprecate/package.json +27 -27
- data/node_modules/webidl-conversions/LICENSE.md +12 -12
- data/node_modules/webidl-conversions/README.md +53 -53
- data/node_modules/webidl-conversions/lib/index.js +189 -189
- data/node_modules/webidl-conversions/package.json +23 -23
- data/node_modules/whatwg-url/LICENSE.txt +21 -21
- data/node_modules/whatwg-url/README.md +67 -67
- data/node_modules/whatwg-url/lib/URL-impl.js +200 -200
- data/node_modules/whatwg-url/lib/URL.js +196 -196
- data/node_modules/whatwg-url/lib/public-api.js +11 -11
- data/node_modules/whatwg-url/lib/utils.js +20 -20
- data/node_modules/whatwg-url/package.json +32 -32
- data/node_modules/wrappy/LICENSE +15 -15
- data/node_modules/wrappy/README.md +36 -36
- data/node_modules/wrappy/package.json +29 -29
- data/node_modules/wrappy/wrappy.js +33 -33
- data/node_modules/ws/LICENSE +19 -19
- data/node_modules/ws/README.md +493 -493
- data/node_modules/ws/browser.js +8 -8
- data/node_modules/ws/index.js +13 -13
- data/node_modules/ws/lib/buffer-util.js +126 -126
- data/node_modules/ws/lib/constants.js +12 -12
- data/node_modules/ws/lib/event-target.js +266 -266
- data/node_modules/ws/lib/extension.js +203 -203
- data/node_modules/ws/lib/limiter.js +55 -55
- data/node_modules/ws/lib/permessage-deflate.js +511 -511
- data/node_modules/ws/lib/receiver.js +612 -612
- data/node_modules/ws/lib/sender.js +422 -422
- data/node_modules/ws/lib/stream.js +180 -180
- data/node_modules/ws/lib/subprotocol.js +62 -62
- data/node_modules/ws/lib/validation.js +124 -124
- data/node_modules/ws/lib/websocket-server.js +485 -485
- data/node_modules/ws/lib/websocket.js +1149 -1149
- data/node_modules/ws/package.json +61 -61
- data/node_modules/ws/wrapper.mjs +8 -8
- data/node_modules/yauzl/LICENSE +21 -21
- data/node_modules/yauzl/README.md +658 -658
- data/node_modules/yauzl/index.js +796 -796
- data/node_modules/yauzl/package.json +40 -40
- data/package.json +1 -1
- metadata +23 -25
- data/node_modules/devtools-protocol/changelog.md +0 -10491
- data/node_modules/devtools-protocol/externs/protocol_externs.js +0 -9734
@@ -1,828 +1,828 @@
|
|
1
|
-
"use strict";
|
2
|
-
/**
|
3
|
-
* Copyright 2019 Google Inc. All rights reserved.
|
4
|
-
*
|
5
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
-
* you may not use this file except in compliance with the License.
|
7
|
-
* You may obtain a copy of the License at
|
8
|
-
*
|
9
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
10
|
-
*
|
11
|
-
* Unless required by applicable law or agreed to in writing, software
|
12
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
-
* See the License for the specific language governing permissions and
|
15
|
-
* limitations under the License.
|
16
|
-
*/
|
17
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
18
|
-
if (k2 === undefined) k2 = k;
|
19
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
20
|
-
}) : (function(o, m, k, k2) {
|
21
|
-
if (k2 === undefined) k2 = k;
|
22
|
-
o[k2] = m[k];
|
23
|
-
}));
|
24
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
25
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
26
|
-
}) : function(o, v) {
|
27
|
-
o["default"] = v;
|
28
|
-
});
|
29
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
30
|
-
if (mod && mod.__esModule) return mod;
|
31
|
-
var result = {};
|
32
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
33
|
-
__setModuleDefault(result, mod);
|
34
|
-
return result;
|
35
|
-
};
|
36
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
37
|
-
exports.ElementHandle = exports.JSHandle = exports.createJSHandle = void 0;
|
38
|
-
const assert_js_1 = require("./assert.js");
|
39
|
-
const helper_js_1 = require("./helper.js");
|
40
|
-
const QueryHandler_js_1 = require("./QueryHandler.js");
|
41
|
-
const environment_js_1 = require("../environment.js");
|
42
|
-
/**
|
43
|
-
* @internal
|
44
|
-
*/
|
45
|
-
function createJSHandle(context, remoteObject) {
|
46
|
-
const frame = context.frame();
|
47
|
-
if (remoteObject.subtype === 'node' && frame) {
|
48
|
-
const frameManager = frame._frameManager;
|
49
|
-
return new ElementHandle(context, context._client, remoteObject, frameManager.page(), frameManager);
|
50
|
-
}
|
51
|
-
return new JSHandle(context, context._client, remoteObject);
|
52
|
-
}
|
53
|
-
exports.createJSHandle = createJSHandle;
|
54
|
-
/**
|
55
|
-
* Represents an in-page JavaScript object. JSHandles can be created with the
|
56
|
-
* {@link Page.evaluateHandle | page.evaluateHandle} method.
|
57
|
-
*
|
58
|
-
* @example
|
59
|
-
* ```js
|
60
|
-
* const windowHandle = await page.evaluateHandle(() => window);
|
61
|
-
* ```
|
62
|
-
*
|
63
|
-
* JSHandle prevents the referenced JavaScript object from being garbage-collected
|
64
|
-
* unless the handle is {@link JSHandle.dispose | disposed}. JSHandles are auto-
|
65
|
-
* disposed when their origin frame gets navigated or the parent context gets destroyed.
|
66
|
-
*
|
67
|
-
* JSHandle instances can be used as arguments for {@link Page.$eval},
|
68
|
-
* {@link Page.evaluate}, and {@link Page.evaluateHandle}.
|
69
|
-
*
|
70
|
-
* @public
|
71
|
-
*/
|
72
|
-
class JSHandle {
|
73
|
-
/**
|
74
|
-
* @internal
|
75
|
-
*/
|
76
|
-
constructor(context, client, remoteObject) {
|
77
|
-
/**
|
78
|
-
* @internal
|
79
|
-
*/
|
80
|
-
this._disposed = false;
|
81
|
-
this._context = context;
|
82
|
-
this._client = client;
|
83
|
-
this._remoteObject = remoteObject;
|
84
|
-
}
|
85
|
-
/** Returns the execution context the handle belongs to.
|
86
|
-
*/
|
87
|
-
executionContext() {
|
88
|
-
return this._context;
|
89
|
-
}
|
90
|
-
/**
|
91
|
-
* This method passes this handle as the first argument to `pageFunction`.
|
92
|
-
* If `pageFunction` returns a Promise, then `handle.evaluate` would wait
|
93
|
-
* for the promise to resolve and return its value.
|
94
|
-
*
|
95
|
-
* @example
|
96
|
-
* ```js
|
97
|
-
* const tweetHandle = await page.$('.tweet .retweets');
|
98
|
-
* expect(await tweetHandle.evaluate(node => node.innerText)).toBe('10');
|
99
|
-
* ```
|
100
|
-
*/
|
101
|
-
async evaluate(pageFunction, ...args) {
|
102
|
-
return await this.executionContext().evaluate(pageFunction, this, ...args);
|
103
|
-
}
|
104
|
-
/**
|
105
|
-
* This method passes this handle as the first argument to `pageFunction`.
|
106
|
-
*
|
107
|
-
* @remarks
|
108
|
-
*
|
109
|
-
* The only difference between `jsHandle.evaluate` and
|
110
|
-
* `jsHandle.evaluateHandle` is that `jsHandle.evaluateHandle`
|
111
|
-
* returns an in-page object (JSHandle).
|
112
|
-
*
|
113
|
-
* If the function passed to `jsHandle.evaluateHandle` returns a Promise,
|
114
|
-
* then `evaluateHandle.evaluateHandle` waits for the promise to resolve and
|
115
|
-
* returns its value.
|
116
|
-
*
|
117
|
-
* See {@link Page.evaluateHandle} for more details.
|
118
|
-
*/
|
119
|
-
async evaluateHandle(pageFunction, ...args) {
|
120
|
-
return await this.executionContext().evaluateHandle(pageFunction, this, ...args);
|
121
|
-
}
|
122
|
-
/** Fetches a single property from the referenced object.
|
123
|
-
*/
|
124
|
-
async getProperty(propertyName) {
|
125
|
-
const objectHandle = await this.evaluateHandle((object, propertyName) => {
|
126
|
-
const result = { __proto__: null };
|
127
|
-
result[propertyName] = object[propertyName];
|
128
|
-
return result;
|
129
|
-
}, propertyName);
|
130
|
-
const properties = await objectHandle.getProperties();
|
131
|
-
const result = properties.get(propertyName);
|
132
|
-
(0, assert_js_1.assert)(result instanceof JSHandle);
|
133
|
-
await objectHandle.dispose();
|
134
|
-
return result;
|
135
|
-
}
|
136
|
-
/**
|
137
|
-
* The method returns a map with property names as keys and JSHandle
|
138
|
-
* instances for the property values.
|
139
|
-
*
|
140
|
-
* @example
|
141
|
-
* ```js
|
142
|
-
* const listHandle = await page.evaluateHandle(() => document.body.children);
|
143
|
-
* const properties = await listHandle.getProperties();
|
144
|
-
* const children = [];
|
145
|
-
* for (const property of properties.values()) {
|
146
|
-
* const element = property.asElement();
|
147
|
-
* if (element)
|
148
|
-
* children.push(element);
|
149
|
-
* }
|
150
|
-
* children; // holds elementHandles to all children of document.body
|
151
|
-
* ```
|
152
|
-
*/
|
153
|
-
async getProperties() {
|
154
|
-
const response = await this._client.send('Runtime.getProperties', {
|
155
|
-
objectId: this._remoteObject.objectId,
|
156
|
-
ownProperties: true,
|
157
|
-
});
|
158
|
-
const result = new Map();
|
159
|
-
for (const property of response.result) {
|
160
|
-
if (!property.enumerable)
|
161
|
-
continue;
|
162
|
-
result.set(property.name, createJSHandle(this._context, property.value));
|
163
|
-
}
|
164
|
-
return result;
|
165
|
-
}
|
166
|
-
/**
|
167
|
-
* @returns Returns a JSON representation of the object.If the object has a
|
168
|
-
* `toJSON` function, it will not be called.
|
169
|
-
* @remarks
|
170
|
-
*
|
171
|
-
* The JSON is generated by running {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify | JSON.stringify}
|
172
|
-
* on the object in page and consequent {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse} in puppeteer.
|
173
|
-
* **NOTE** The method throws if the referenced object is not stringifiable.
|
174
|
-
*/
|
175
|
-
async jsonValue() {
|
176
|
-
if (this._remoteObject.objectId) {
|
177
|
-
const response = await this._client.send('Runtime.callFunctionOn', {
|
178
|
-
functionDeclaration: 'function() { return this; }',
|
179
|
-
objectId: this._remoteObject.objectId,
|
180
|
-
returnByValue: true,
|
181
|
-
awaitPromise: true,
|
182
|
-
});
|
183
|
-
return helper_js_1.helper.valueFromRemoteObject(response.result);
|
184
|
-
}
|
185
|
-
return helper_js_1.helper.valueFromRemoteObject(this._remoteObject);
|
186
|
-
}
|
187
|
-
/**
|
188
|
-
* @returns Either `null` or the object handle itself, if the object
|
189
|
-
* handle is an instance of {@link ElementHandle}.
|
190
|
-
*/
|
191
|
-
asElement() {
|
192
|
-
/* This always returns null, but subclasses can override this and return an
|
193
|
-
ElementHandle.
|
194
|
-
*/
|
195
|
-
return null;
|
196
|
-
}
|
197
|
-
/**
|
198
|
-
* Stops referencing the element handle, and resolves when the object handle is
|
199
|
-
* successfully disposed of.
|
200
|
-
*/
|
201
|
-
async dispose() {
|
202
|
-
if (this._disposed)
|
203
|
-
return;
|
204
|
-
this._disposed = true;
|
205
|
-
await helper_js_1.helper.releaseObject(this._client, this._remoteObject);
|
206
|
-
}
|
207
|
-
/**
|
208
|
-
* Returns a string representation of the JSHandle.
|
209
|
-
*
|
210
|
-
* @remarks Useful during debugging.
|
211
|
-
*/
|
212
|
-
toString() {
|
213
|
-
if (this._remoteObject.objectId) {
|
214
|
-
const type = this._remoteObject.subtype || this._remoteObject.type;
|
215
|
-
return 'JSHandle@' + type;
|
216
|
-
}
|
217
|
-
return 'JSHandle:' + helper_js_1.helper.valueFromRemoteObject(this._remoteObject);
|
218
|
-
}
|
219
|
-
}
|
220
|
-
exports.JSHandle = JSHandle;
|
221
|
-
/**
|
222
|
-
* ElementHandle represents an in-page DOM element.
|
223
|
-
*
|
224
|
-
* @remarks
|
225
|
-
*
|
226
|
-
* ElementHandles can be created with the {@link Page.$} method.
|
227
|
-
*
|
228
|
-
* ```js
|
229
|
-
* const puppeteer = require('puppeteer');
|
230
|
-
*
|
231
|
-
* (async () => {
|
232
|
-
* const browser = await puppeteer.launch();
|
233
|
-
* const page = await browser.newPage();
|
234
|
-
* await page.goto('https://example.com');
|
235
|
-
* const hrefElement = await page.$('a');
|
236
|
-
* await hrefElement.click();
|
237
|
-
* // ...
|
238
|
-
* })();
|
239
|
-
* ```
|
240
|
-
*
|
241
|
-
* ElementHandle prevents the DOM element from being garbage-collected unless the
|
242
|
-
* handle is {@link JSHandle.dispose | disposed}. ElementHandles are auto-disposed
|
243
|
-
* when their origin frame gets navigated.
|
244
|
-
*
|
245
|
-
* ElementHandle instances can be used as arguments in {@link Page.$eval} and
|
246
|
-
* {@link Page.evaluate} methods.
|
247
|
-
*
|
248
|
-
* If you're using TypeScript, ElementHandle takes a generic argument that
|
249
|
-
* denotes the type of element the handle is holding within. For example, if you
|
250
|
-
* have a handle to a `<select>` element, you can type it as
|
251
|
-
* `ElementHandle<HTMLSelectElement>` and you get some nicer type checks.
|
252
|
-
*
|
253
|
-
* @public
|
254
|
-
*/
|
255
|
-
class ElementHandle extends JSHandle {
|
256
|
-
/**
|
257
|
-
* @internal
|
258
|
-
*/
|
259
|
-
constructor(context, client, remoteObject, page, frameManager) {
|
260
|
-
super(context, client, remoteObject);
|
261
|
-
this._client = client;
|
262
|
-
this._remoteObject = remoteObject;
|
263
|
-
this._page = page;
|
264
|
-
this._frameManager = frameManager;
|
265
|
-
}
|
266
|
-
asElement() {
|
267
|
-
return this;
|
268
|
-
}
|
269
|
-
/**
|
270
|
-
* Resolves to the content frame for element handles referencing
|
271
|
-
* iframe nodes, or null otherwise
|
272
|
-
*/
|
273
|
-
async contentFrame() {
|
274
|
-
const nodeInfo = await this._client.send('DOM.describeNode', {
|
275
|
-
objectId: this._remoteObject.objectId,
|
276
|
-
});
|
277
|
-
if (typeof nodeInfo.node.frameId !== 'string')
|
278
|
-
return null;
|
279
|
-
return this._frameManager.frame(nodeInfo.node.frameId);
|
280
|
-
}
|
281
|
-
async _scrollIntoViewIfNeeded() {
|
282
|
-
const error = await this.evaluate(async (element, pageJavascriptEnabled) => {
|
283
|
-
if (!element.isConnected)
|
284
|
-
return 'Node is detached from document';
|
285
|
-
if (element.nodeType !== Node.ELEMENT_NODE)
|
286
|
-
return 'Node is not of type HTMLElement';
|
287
|
-
// force-scroll if page's javascript is disabled.
|
288
|
-
if (!pageJavascriptEnabled) {
|
289
|
-
element.scrollIntoView({
|
290
|
-
block: 'center',
|
291
|
-
inline: 'center',
|
292
|
-
// @ts-expect-error Chrome still supports behavior: instant but
|
293
|
-
// it's not in the spec so TS shouts We don't want to make this
|
294
|
-
// breaking change in Puppeteer yet so we'll ignore the line.
|
295
|
-
behavior: 'instant',
|
296
|
-
});
|
297
|
-
return false;
|
298
|
-
}
|
299
|
-
const visibleRatio = await new Promise((resolve) => {
|
300
|
-
const observer = new IntersectionObserver((entries) => {
|
301
|
-
resolve(entries[0].intersectionRatio);
|
302
|
-
observer.disconnect();
|
303
|
-
});
|
304
|
-
observer.observe(element);
|
305
|
-
});
|
306
|
-
if (visibleRatio !== 1.0) {
|
307
|
-
element.scrollIntoView({
|
308
|
-
block: 'center',
|
309
|
-
inline: 'center',
|
310
|
-
// @ts-expect-error Chrome still supports behavior: instant but
|
311
|
-
// it's not in the spec so TS shouts We don't want to make this
|
312
|
-
// breaking change in Puppeteer yet so we'll ignore the line.
|
313
|
-
behavior: 'instant',
|
314
|
-
});
|
315
|
-
}
|
316
|
-
return false;
|
317
|
-
}, this._page.isJavaScriptEnabled());
|
318
|
-
if (error)
|
319
|
-
throw new Error(error);
|
320
|
-
}
|
321
|
-
/**
|
322
|
-
* Returns the middle point within an element unless a specific offset is provided.
|
323
|
-
*/
|
324
|
-
async clickablePoint(offset) {
|
325
|
-
const [result, layoutMetrics] = await Promise.all([
|
326
|
-
this._client
|
327
|
-
.send('DOM.getContentQuads', {
|
328
|
-
objectId: this._remoteObject.objectId,
|
329
|
-
})
|
330
|
-
.catch(helper_js_1.debugError),
|
331
|
-
this._client.send('Page.getLayoutMetrics'),
|
332
|
-
]);
|
333
|
-
if (!result || !result.quads.length)
|
334
|
-
throw new Error('Node is either not clickable or not an HTMLElement');
|
335
|
-
// Filter out quads that have too small area to click into.
|
336
|
-
// Fallback to `layoutViewport` in case of using Firefox.
|
337
|
-
const { clientWidth, clientHeight } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
|
338
|
-
const quads = result.quads
|
339
|
-
.map((quad) => this._fromProtocolQuad(quad))
|
340
|
-
.map((quad) => this._intersectQuadWithViewport(quad, clientWidth, clientHeight))
|
341
|
-
.filter((quad) => computeQuadArea(quad) > 1);
|
342
|
-
if (!quads.length)
|
343
|
-
throw new Error('Node is either not clickable or not an HTMLElement');
|
344
|
-
const quad = quads[0];
|
345
|
-
if (offset) {
|
346
|
-
// Return the point of the first quad identified by offset.
|
347
|
-
let minX = Number.MAX_SAFE_INTEGER;
|
348
|
-
let minY = Number.MAX_SAFE_INTEGER;
|
349
|
-
for (const point of quad) {
|
350
|
-
if (point.x < minX) {
|
351
|
-
minX = point.x;
|
352
|
-
}
|
353
|
-
if (point.y < minY) {
|
354
|
-
minY = point.y;
|
355
|
-
}
|
356
|
-
}
|
357
|
-
if (minX !== Number.MAX_SAFE_INTEGER &&
|
358
|
-
minY !== Number.MAX_SAFE_INTEGER) {
|
359
|
-
return {
|
360
|
-
x: minX + offset.x,
|
361
|
-
y: minY + offset.y,
|
362
|
-
};
|
363
|
-
}
|
364
|
-
}
|
365
|
-
// Return the middle point of the first quad.
|
366
|
-
let x = 0;
|
367
|
-
let y = 0;
|
368
|
-
for (const point of quad) {
|
369
|
-
x += point.x;
|
370
|
-
y += point.y;
|
371
|
-
}
|
372
|
-
return {
|
373
|
-
x: x / 4,
|
374
|
-
y: y / 4,
|
375
|
-
};
|
376
|
-
}
|
377
|
-
_getBoxModel() {
|
378
|
-
const params = {
|
379
|
-
objectId: this._remoteObject.objectId,
|
380
|
-
};
|
381
|
-
return this._client
|
382
|
-
.send('DOM.getBoxModel', params)
|
383
|
-
.catch((error) => (0, helper_js_1.debugError)(error));
|
384
|
-
}
|
385
|
-
_fromProtocolQuad(quad) {
|
386
|
-
return [
|
387
|
-
{ x: quad[0], y: quad[1] },
|
388
|
-
{ x: quad[2], y: quad[3] },
|
389
|
-
{ x: quad[4], y: quad[5] },
|
390
|
-
{ x: quad[6], y: quad[7] },
|
391
|
-
];
|
392
|
-
}
|
393
|
-
_intersectQuadWithViewport(quad, width, height) {
|
394
|
-
return quad.map((point) => ({
|
395
|
-
x: Math.min(Math.max(point.x, 0), width),
|
396
|
-
y: Math.min(Math.max(point.y, 0), height),
|
397
|
-
}));
|
398
|
-
}
|
399
|
-
/**
|
400
|
-
* This method scrolls element into view if needed, and then
|
401
|
-
* uses {@link Page.mouse} to hover over the center of the element.
|
402
|
-
* If the element is detached from DOM, the method throws an error.
|
403
|
-
*/
|
404
|
-
async hover() {
|
405
|
-
await this._scrollIntoViewIfNeeded();
|
406
|
-
const { x, y } = await this.clickablePoint();
|
407
|
-
await this._page.mouse.move(x, y);
|
408
|
-
}
|
409
|
-
/**
|
410
|
-
* This method scrolls element into view if needed, and then
|
411
|
-
* uses {@link Page.mouse} to click in the center of the element.
|
412
|
-
* If the element is detached from DOM, the method throws an error.
|
413
|
-
*/
|
414
|
-
async click(options = {}) {
|
415
|
-
await this._scrollIntoViewIfNeeded();
|
416
|
-
const { x, y } = await this.clickablePoint(options.offset);
|
417
|
-
await this._page.mouse.click(x, y, options);
|
418
|
-
}
|
419
|
-
/**
|
420
|
-
* This method creates and captures a dragevent from the element.
|
421
|
-
*/
|
422
|
-
async drag(target) {
|
423
|
-
(0, assert_js_1.assert)(this._page.isDragInterceptionEnabled(), 'Drag Interception is not enabled!');
|
424
|
-
await this._scrollIntoViewIfNeeded();
|
425
|
-
const start = await this.clickablePoint();
|
426
|
-
return await this._page.mouse.drag(start, target);
|
427
|
-
}
|
428
|
-
/**
|
429
|
-
* This method creates a `dragenter` event on the element.
|
430
|
-
*/
|
431
|
-
async dragEnter(data = { items: [], dragOperationsMask: 1 }) {
|
432
|
-
await this._scrollIntoViewIfNeeded();
|
433
|
-
const target = await this.clickablePoint();
|
434
|
-
await this._page.mouse.dragEnter(target, data);
|
435
|
-
}
|
436
|
-
/**
|
437
|
-
* This method creates a `dragover` event on the element.
|
438
|
-
*/
|
439
|
-
async dragOver(data = { items: [], dragOperationsMask: 1 }) {
|
440
|
-
await this._scrollIntoViewIfNeeded();
|
441
|
-
const target = await this.clickablePoint();
|
442
|
-
await this._page.mouse.dragOver(target, data);
|
443
|
-
}
|
444
|
-
/**
|
445
|
-
* This method triggers a drop on the element.
|
446
|
-
*/
|
447
|
-
async drop(data = { items: [], dragOperationsMask: 1 }) {
|
448
|
-
await this._scrollIntoViewIfNeeded();
|
449
|
-
const destination = await this.clickablePoint();
|
450
|
-
await this._page.mouse.drop(destination, data);
|
451
|
-
}
|
452
|
-
/**
|
453
|
-
* This method triggers a dragenter, dragover, and drop on the element.
|
454
|
-
*/
|
455
|
-
async dragAndDrop(target, options) {
|
456
|
-
await this._scrollIntoViewIfNeeded();
|
457
|
-
const startPoint = await this.clickablePoint();
|
458
|
-
const targetPoint = await target.clickablePoint();
|
459
|
-
await this._page.mouse.dragAndDrop(startPoint, targetPoint, options);
|
460
|
-
}
|
461
|
-
/**
|
462
|
-
* Triggers a `change` and `input` event once all the provided options have been
|
463
|
-
* selected. If there's no `<select>` element matching `selector`, the method
|
464
|
-
* throws an error.
|
465
|
-
*
|
466
|
-
* @example
|
467
|
-
* ```js
|
468
|
-
* handle.select('blue'); // single selection
|
469
|
-
* handle.select('red', 'green', 'blue'); // multiple selections
|
470
|
-
* ```
|
471
|
-
* @param values - Values of options to select. If the `<select>` has the
|
472
|
-
* `multiple` attribute, all values are considered, otherwise only the first
|
473
|
-
* one is taken into account.
|
474
|
-
*/
|
475
|
-
async select(...values) {
|
476
|
-
for (const value of values)
|
477
|
-
(0, assert_js_1.assert)(helper_js_1.helper.isString(value), 'Values must be strings. Found value "' +
|
478
|
-
value +
|
479
|
-
'" of type "' +
|
480
|
-
typeof value +
|
481
|
-
'"');
|
482
|
-
return this.evaluate((element, values) => {
|
483
|
-
if (!(element instanceof HTMLSelectElement))
|
484
|
-
throw new Error('Element is not a <select> element.');
|
485
|
-
const options = Array.from(element.options);
|
486
|
-
element.value = undefined;
|
487
|
-
for (const option of options) {
|
488
|
-
option.selected = values.includes(option.value);
|
489
|
-
if (option.selected && !element.multiple)
|
490
|
-
break;
|
491
|
-
}
|
492
|
-
element.dispatchEvent(new Event('input', { bubbles: true }));
|
493
|
-
element.dispatchEvent(new Event('change', { bubbles: true }));
|
494
|
-
return options
|
495
|
-
.filter((option) => option.selected)
|
496
|
-
.map((option) => option.value);
|
497
|
-
}, values);
|
498
|
-
}
|
499
|
-
/**
|
500
|
-
* This method expects `elementHandle` to point to an
|
501
|
-
* {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input | input element}.
|
502
|
-
* @param filePaths - Sets the value of the file input to these paths.
|
503
|
-
* If some of the `filePaths` are relative paths, then they are resolved
|
504
|
-
* relative to the {@link https://nodejs.org/api/process.html#process_process_cwd | current working directory}
|
505
|
-
*/
|
506
|
-
async uploadFile(...filePaths) {
|
507
|
-
const isMultiple = await this.evaluate((element) => {
|
508
|
-
if (!(element instanceof HTMLInputElement)) {
|
509
|
-
throw new Error('uploadFile can only be called on an input element.');
|
510
|
-
}
|
511
|
-
return element.multiple;
|
512
|
-
});
|
513
|
-
(0, assert_js_1.assert)(filePaths.length <= 1 || isMultiple, 'Multiple file uploads only work with <input type=file multiple>');
|
514
|
-
if (!environment_js_1.isNode) {
|
515
|
-
throw new Error(`JSHandle#uploadFile can only be used in Node environments.`);
|
516
|
-
}
|
517
|
-
/*
|
518
|
-
This import is only needed for `uploadFile`, so keep it scoped here to
|
519
|
-
avoid paying the cost unnecessarily.
|
520
|
-
*/
|
521
|
-
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
522
|
-
const fs = await helper_js_1.helper.importFSModule();
|
523
|
-
// Locate all files and confirm that they exist.
|
524
|
-
const files = await Promise.all(filePaths.map(async (filePath) => {
|
525
|
-
const resolvedPath = path.resolve(filePath);
|
526
|
-
try {
|
527
|
-
await fs.promises.access(resolvedPath, fs.constants.R_OK);
|
528
|
-
}
|
529
|
-
catch (error) {
|
530
|
-
if (error.code === 'ENOENT')
|
531
|
-
throw new Error(`${filePath} does not exist or is not readable`);
|
532
|
-
}
|
533
|
-
return resolvedPath;
|
534
|
-
}));
|
535
|
-
const { objectId } = this._remoteObject;
|
536
|
-
const { node } = await this._client.send('DOM.describeNode', { objectId });
|
537
|
-
const { backendNodeId } = node;
|
538
|
-
/* The zero-length array is a special case, it seems that
|
539
|
-
DOM.setFileInputFiles does not actually update the files in that case,
|
540
|
-
so the solution is to eval the element value to a new FileList directly.
|
541
|
-
*/
|
542
|
-
if (files.length === 0) {
|
543
|
-
await this.evaluate((element) => {
|
544
|
-
element.files = new DataTransfer().files;
|
545
|
-
// Dispatch events for this case because it should behave akin to a user action.
|
546
|
-
element.dispatchEvent(new Event('input', { bubbles: true }));
|
547
|
-
element.dispatchEvent(new Event('change', { bubbles: true }));
|
548
|
-
});
|
549
|
-
}
|
550
|
-
else {
|
551
|
-
await this._client.send('DOM.setFileInputFiles', {
|
552
|
-
objectId,
|
553
|
-
files,
|
554
|
-
backendNodeId,
|
555
|
-
});
|
556
|
-
}
|
557
|
-
}
|
558
|
-
/**
|
559
|
-
* This method scrolls element into view if needed, and then uses
|
560
|
-
* {@link Touchscreen.tap} to tap in the center of the element.
|
561
|
-
* If the element is detached from DOM, the method throws an error.
|
562
|
-
*/
|
563
|
-
async tap() {
|
564
|
-
await this._scrollIntoViewIfNeeded();
|
565
|
-
const { x, y } = await this.clickablePoint();
|
566
|
-
await this._page.touchscreen.tap(x, y);
|
567
|
-
}
|
568
|
-
/**
|
569
|
-
* Calls {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus | focus} on the element.
|
570
|
-
*/
|
571
|
-
async focus() {
|
572
|
-
await this.evaluate((element) => element.focus());
|
573
|
-
}
|
574
|
-
/**
|
575
|
-
* Focuses the element, and then sends a `keydown`, `keypress`/`input`, and
|
576
|
-
* `keyup` event for each character in the text.
|
577
|
-
*
|
578
|
-
* To press a special key, like `Control` or `ArrowDown`,
|
579
|
-
* use {@link ElementHandle.press}.
|
580
|
-
*
|
581
|
-
* @example
|
582
|
-
* ```js
|
583
|
-
* await elementHandle.type('Hello'); // Types instantly
|
584
|
-
* await elementHandle.type('World', {delay: 100}); // Types slower, like a user
|
585
|
-
* ```
|
586
|
-
*
|
587
|
-
* @example
|
588
|
-
* An example of typing into a text field and then submitting the form:
|
589
|
-
*
|
590
|
-
* ```js
|
591
|
-
* const elementHandle = await page.$('input');
|
592
|
-
* await elementHandle.type('some text');
|
593
|
-
* await elementHandle.press('Enter');
|
594
|
-
* ```
|
595
|
-
*/
|
596
|
-
async type(text, options) {
|
597
|
-
await this.focus();
|
598
|
-
await this._page.keyboard.type(text, options);
|
599
|
-
}
|
600
|
-
/**
|
601
|
-
* Focuses the element, and then uses {@link Keyboard.down} and {@link Keyboard.up}.
|
602
|
-
*
|
603
|
-
* @remarks
|
604
|
-
* If `key` is a single character and no modifier keys besides `Shift`
|
605
|
-
* are being held down, a `keypress`/`input` event will also be generated.
|
606
|
-
* The `text` option can be specified to force an input event to be generated.
|
607
|
-
*
|
608
|
-
* **NOTE** Modifier keys DO affect `elementHandle.press`. Holding down `Shift`
|
609
|
-
* will type the text in upper case.
|
610
|
-
*
|
611
|
-
* @param key - Name of key to press, such as `ArrowLeft`.
|
612
|
-
* See {@link KeyInput} for a list of all key names.
|
613
|
-
*/
|
614
|
-
async press(key, options) {
|
615
|
-
await this.focus();
|
616
|
-
await this._page.keyboard.press(key, options);
|
617
|
-
}
|
618
|
-
/**
|
619
|
-
* This method returns the bounding box of the element (relative to the main frame),
|
620
|
-
* or `null` if the element is not visible.
|
621
|
-
*/
|
622
|
-
async boundingBox() {
|
623
|
-
const result = await this._getBoxModel();
|
624
|
-
if (!result)
|
625
|
-
return null;
|
626
|
-
const quad = result.model.border;
|
627
|
-
const x = Math.min(quad[0], quad[2], quad[4], quad[6]);
|
628
|
-
const y = Math.min(quad[1], quad[3], quad[5], quad[7]);
|
629
|
-
const width = Math.max(quad[0], quad[2], quad[4], quad[6]) - x;
|
630
|
-
const height = Math.max(quad[1], quad[3], quad[5], quad[7]) - y;
|
631
|
-
return { x, y, width, height };
|
632
|
-
}
|
633
|
-
/**
|
634
|
-
* This method returns boxes of the element, or `null` if the element is not visible.
|
635
|
-
*
|
636
|
-
* @remarks
|
637
|
-
*
|
638
|
-
* Boxes are represented as an array of points;
|
639
|
-
* Each Point is an object `{x, y}`. Box points are sorted clock-wise.
|
640
|
-
*/
|
641
|
-
async boxModel() {
|
642
|
-
const result = await this._getBoxModel();
|
643
|
-
if (!result)
|
644
|
-
return null;
|
645
|
-
const { content, padding, border, margin, width, height } = result.model;
|
646
|
-
return {
|
647
|
-
content: this._fromProtocolQuad(content),
|
648
|
-
padding: this._fromProtocolQuad(padding),
|
649
|
-
border: this._fromProtocolQuad(border),
|
650
|
-
margin: this._fromProtocolQuad(margin),
|
651
|
-
width,
|
652
|
-
height,
|
653
|
-
};
|
654
|
-
}
|
655
|
-
/**
|
656
|
-
* This method scrolls element into view if needed, and then uses
|
657
|
-
* {@link Page.screenshot} to take a screenshot of the element.
|
658
|
-
* If the element is detached from DOM, the method throws an error.
|
659
|
-
*/
|
660
|
-
async screenshot(options = {}) {
|
661
|
-
let needsViewportReset = false;
|
662
|
-
let boundingBox = await this.boundingBox();
|
663
|
-
(0, assert_js_1.assert)(boundingBox, 'Node is either not visible or not an HTMLElement');
|
664
|
-
const viewport = this._page.viewport();
|
665
|
-
if (viewport &&
|
666
|
-
(boundingBox.width > viewport.width ||
|
667
|
-
boundingBox.height > viewport.height)) {
|
668
|
-
const newViewport = {
|
669
|
-
width: Math.max(viewport.width, Math.ceil(boundingBox.width)),
|
670
|
-
height: Math.max(viewport.height, Math.ceil(boundingBox.height)),
|
671
|
-
};
|
672
|
-
await this._page.setViewport(Object.assign({}, viewport, newViewport));
|
673
|
-
needsViewportReset = true;
|
674
|
-
}
|
675
|
-
await this._scrollIntoViewIfNeeded();
|
676
|
-
boundingBox = await this.boundingBox();
|
677
|
-
(0, assert_js_1.assert)(boundingBox, 'Node is either not visible or not an HTMLElement');
|
678
|
-
(0, assert_js_1.assert)(boundingBox.width !== 0, 'Node has 0 width.');
|
679
|
-
(0, assert_js_1.assert)(boundingBox.height !== 0, 'Node has 0 height.');
|
680
|
-
const layoutMetrics = await this._client.send('Page.getLayoutMetrics');
|
681
|
-
// Fallback to `layoutViewport` in case of using Firefox.
|
682
|
-
const { pageX, pageY } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
|
683
|
-
const clip = Object.assign({}, boundingBox);
|
684
|
-
clip.x += pageX;
|
685
|
-
clip.y += pageY;
|
686
|
-
const imageData = await this._page.screenshot(Object.assign({}, {
|
687
|
-
clip,
|
688
|
-
}, options));
|
689
|
-
if (needsViewportReset)
|
690
|
-
await this._page.setViewport(viewport);
|
691
|
-
return imageData;
|
692
|
-
}
|
693
|
-
/**
|
694
|
-
* Runs `element.querySelector` within the page. If no element matches the selector,
|
695
|
-
* the return value resolves to `null`.
|
696
|
-
*/
|
697
|
-
async $(selector) {
|
698
|
-
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
699
|
-
return queryHandler.queryOne(this, updatedSelector);
|
700
|
-
}
|
701
|
-
/**
|
702
|
-
* Runs `element.querySelectorAll` within the page. If no elements match the selector,
|
703
|
-
* the return value resolves to `[]`.
|
704
|
-
*/
|
705
|
-
async $$(selector) {
|
706
|
-
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
707
|
-
return queryHandler.queryAll(this, updatedSelector);
|
708
|
-
}
|
709
|
-
/**
|
710
|
-
* This method runs `document.querySelector` within the element and passes it as
|
711
|
-
* the first argument to `pageFunction`. If there's no element matching `selector`,
|
712
|
-
* the method throws an error.
|
713
|
-
*
|
714
|
-
* If `pageFunction` returns a Promise, then `frame.$eval` would wait for the promise
|
715
|
-
* to resolve and return its value.
|
716
|
-
*
|
717
|
-
* @example
|
718
|
-
* ```js
|
719
|
-
* const tweetHandle = await page.$('.tweet');
|
720
|
-
* expect(await tweetHandle.$eval('.like', node => node.innerText)).toBe('100');
|
721
|
-
* expect(await tweetHandle.$eval('.retweets', node => node.innerText)).toBe('10');
|
722
|
-
* ```
|
723
|
-
*/
|
724
|
-
async $eval(selector, pageFunction, ...args) {
|
725
|
-
const elementHandle = await this.$(selector);
|
726
|
-
if (!elementHandle)
|
727
|
-
throw new Error(`Error: failed to find element matching selector "${selector}"`);
|
728
|
-
const result = await elementHandle.evaluate(pageFunction, ...args);
|
729
|
-
await elementHandle.dispose();
|
730
|
-
/**
|
731
|
-
* This `as` is a little unfortunate but helps TS understand the behavior of
|
732
|
-
* `elementHandle.evaluate`. If evaluate returns an element it will return an
|
733
|
-
* ElementHandle instance, rather than the plain object. All the
|
734
|
-
* WrapElementHandle type does is wrap ReturnType into
|
735
|
-
* ElementHandle<ReturnType> if it is an ElementHandle, or leave it alone as
|
736
|
-
* ReturnType if it isn't.
|
737
|
-
*/
|
738
|
-
return result;
|
739
|
-
}
|
740
|
-
/**
|
741
|
-
* This method runs `document.querySelectorAll` within the element and passes it as
|
742
|
-
* the first argument to `pageFunction`. If there's no element matching `selector`,
|
743
|
-
* the method throws an error.
|
744
|
-
*
|
745
|
-
* If `pageFunction` returns a Promise, then `frame.$$eval` would wait for the
|
746
|
-
* promise to resolve and return its value.
|
747
|
-
*
|
748
|
-
* @example
|
749
|
-
* ```html
|
750
|
-
* <div class="feed">
|
751
|
-
* <div class="tweet">Hello!</div>
|
752
|
-
* <div class="tweet">Hi!</div>
|
753
|
-
* </div>
|
754
|
-
* ```
|
755
|
-
*
|
756
|
-
* @example
|
757
|
-
* ```js
|
758
|
-
* const feedHandle = await page.$('.feed');
|
759
|
-
* expect(await feedHandle.$$eval('.tweet', nodes => nodes.map(n => n.innerText)))
|
760
|
-
* .toEqual(['Hello!', 'Hi!']);
|
761
|
-
* ```
|
762
|
-
*/
|
763
|
-
async $$eval(selector, pageFunction, ...args) {
|
764
|
-
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
765
|
-
const arrayHandle = await queryHandler.queryAllArray(this, updatedSelector);
|
766
|
-
const result = await arrayHandle.evaluate(pageFunction, ...args);
|
767
|
-
await arrayHandle.dispose();
|
768
|
-
/* This `as` exists for the same reason as the `as` in $eval above.
|
769
|
-
* See the comment there for a full explanation.
|
770
|
-
*/
|
771
|
-
return result;
|
772
|
-
}
|
773
|
-
/**
|
774
|
-
* The method evaluates the XPath expression relative to the elementHandle.
|
775
|
-
* If there are no such elements, the method will resolve to an empty array.
|
776
|
-
* @param expression - Expression to {@link https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate | evaluate}
|
777
|
-
*/
|
778
|
-
async $x(expression) {
|
779
|
-
const arrayHandle = await this.evaluateHandle((element, expression) => {
|
780
|
-
const document = element.ownerDocument || element;
|
781
|
-
const iterator = document.evaluate(expression, element, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE);
|
782
|
-
const array = [];
|
783
|
-
let item;
|
784
|
-
while ((item = iterator.iterateNext()))
|
785
|
-
array.push(item);
|
786
|
-
return array;
|
787
|
-
}, expression);
|
788
|
-
const properties = await arrayHandle.getProperties();
|
789
|
-
await arrayHandle.dispose();
|
790
|
-
const result = [];
|
791
|
-
for (const property of properties.values()) {
|
792
|
-
const elementHandle = property.asElement();
|
793
|
-
if (elementHandle)
|
794
|
-
result.push(elementHandle);
|
795
|
-
}
|
796
|
-
return result;
|
797
|
-
}
|
798
|
-
/**
|
799
|
-
* Resolves to true if the element is visible in the current viewport.
|
800
|
-
*/
|
801
|
-
async isIntersectingViewport(options) {
|
802
|
-
const { threshold = 0 } = options || {};
|
803
|
-
return await this.evaluate(async (element, threshold) => {
|
804
|
-
const visibleRatio = await new Promise((resolve) => {
|
805
|
-
const observer = new IntersectionObserver((entries) => {
|
806
|
-
resolve(entries[0].intersectionRatio);
|
807
|
-
observer.disconnect();
|
808
|
-
});
|
809
|
-
observer.observe(element);
|
810
|
-
});
|
811
|
-
return threshold === 1 ? visibleRatio === 1 : visibleRatio > threshold;
|
812
|
-
}, threshold);
|
813
|
-
}
|
814
|
-
}
|
815
|
-
exports.ElementHandle = ElementHandle;
|
816
|
-
function computeQuadArea(quad) {
|
817
|
-
/* Compute sum of all directed areas of adjacent triangles
|
818
|
-
https://en.wikipedia.org/wiki/Polygon#Simple_polygons
|
819
|
-
*/
|
820
|
-
let area = 0;
|
821
|
-
for (let i = 0; i < quad.length; ++i) {
|
822
|
-
const p1 = quad[i];
|
823
|
-
const p2 = quad[(i + 1) % quad.length];
|
824
|
-
area += (p1.x * p2.y - p2.x * p1.y) / 2;
|
825
|
-
}
|
826
|
-
return Math.abs(area);
|
827
|
-
}
|
1
|
+
"use strict";
|
2
|
+
/**
|
3
|
+
* Copyright 2019 Google Inc. All rights reserved.
|
4
|
+
*
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
* you may not use this file except in compliance with the License.
|
7
|
+
* You may obtain a copy of the License at
|
8
|
+
*
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
*
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
* See the License for the specific language governing permissions and
|
15
|
+
* limitations under the License.
|
16
|
+
*/
|
17
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
18
|
+
if (k2 === undefined) k2 = k;
|
19
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
20
|
+
}) : (function(o, m, k, k2) {
|
21
|
+
if (k2 === undefined) k2 = k;
|
22
|
+
o[k2] = m[k];
|
23
|
+
}));
|
24
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
25
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
26
|
+
}) : function(o, v) {
|
27
|
+
o["default"] = v;
|
28
|
+
});
|
29
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
30
|
+
if (mod && mod.__esModule) return mod;
|
31
|
+
var result = {};
|
32
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
33
|
+
__setModuleDefault(result, mod);
|
34
|
+
return result;
|
35
|
+
};
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
37
|
+
exports.ElementHandle = exports.JSHandle = exports.createJSHandle = void 0;
|
38
|
+
const assert_js_1 = require("./assert.js");
|
39
|
+
const helper_js_1 = require("./helper.js");
|
40
|
+
const QueryHandler_js_1 = require("./QueryHandler.js");
|
41
|
+
const environment_js_1 = require("../environment.js");
|
42
|
+
/**
|
43
|
+
* @internal
|
44
|
+
*/
|
45
|
+
function createJSHandle(context, remoteObject) {
|
46
|
+
const frame = context.frame();
|
47
|
+
if (remoteObject.subtype === 'node' && frame) {
|
48
|
+
const frameManager = frame._frameManager;
|
49
|
+
return new ElementHandle(context, context._client, remoteObject, frameManager.page(), frameManager);
|
50
|
+
}
|
51
|
+
return new JSHandle(context, context._client, remoteObject);
|
52
|
+
}
|
53
|
+
exports.createJSHandle = createJSHandle;
|
54
|
+
/**
|
55
|
+
* Represents an in-page JavaScript object. JSHandles can be created with the
|
56
|
+
* {@link Page.evaluateHandle | page.evaluateHandle} method.
|
57
|
+
*
|
58
|
+
* @example
|
59
|
+
* ```js
|
60
|
+
* const windowHandle = await page.evaluateHandle(() => window);
|
61
|
+
* ```
|
62
|
+
*
|
63
|
+
* JSHandle prevents the referenced JavaScript object from being garbage-collected
|
64
|
+
* unless the handle is {@link JSHandle.dispose | disposed}. JSHandles are auto-
|
65
|
+
* disposed when their origin frame gets navigated or the parent context gets destroyed.
|
66
|
+
*
|
67
|
+
* JSHandle instances can be used as arguments for {@link Page.$eval},
|
68
|
+
* {@link Page.evaluate}, and {@link Page.evaluateHandle}.
|
69
|
+
*
|
70
|
+
* @public
|
71
|
+
*/
|
72
|
+
class JSHandle {
|
73
|
+
/**
|
74
|
+
* @internal
|
75
|
+
*/
|
76
|
+
constructor(context, client, remoteObject) {
|
77
|
+
/**
|
78
|
+
* @internal
|
79
|
+
*/
|
80
|
+
this._disposed = false;
|
81
|
+
this._context = context;
|
82
|
+
this._client = client;
|
83
|
+
this._remoteObject = remoteObject;
|
84
|
+
}
|
85
|
+
/** Returns the execution context the handle belongs to.
|
86
|
+
*/
|
87
|
+
executionContext() {
|
88
|
+
return this._context;
|
89
|
+
}
|
90
|
+
/**
|
91
|
+
* This method passes this handle as the first argument to `pageFunction`.
|
92
|
+
* If `pageFunction` returns a Promise, then `handle.evaluate` would wait
|
93
|
+
* for the promise to resolve and return its value.
|
94
|
+
*
|
95
|
+
* @example
|
96
|
+
* ```js
|
97
|
+
* const tweetHandle = await page.$('.tweet .retweets');
|
98
|
+
* expect(await tweetHandle.evaluate(node => node.innerText)).toBe('10');
|
99
|
+
* ```
|
100
|
+
*/
|
101
|
+
async evaluate(pageFunction, ...args) {
|
102
|
+
return await this.executionContext().evaluate(pageFunction, this, ...args);
|
103
|
+
}
|
104
|
+
/**
|
105
|
+
* This method passes this handle as the first argument to `pageFunction`.
|
106
|
+
*
|
107
|
+
* @remarks
|
108
|
+
*
|
109
|
+
* The only difference between `jsHandle.evaluate` and
|
110
|
+
* `jsHandle.evaluateHandle` is that `jsHandle.evaluateHandle`
|
111
|
+
* returns an in-page object (JSHandle).
|
112
|
+
*
|
113
|
+
* If the function passed to `jsHandle.evaluateHandle` returns a Promise,
|
114
|
+
* then `evaluateHandle.evaluateHandle` waits for the promise to resolve and
|
115
|
+
* returns its value.
|
116
|
+
*
|
117
|
+
* See {@link Page.evaluateHandle} for more details.
|
118
|
+
*/
|
119
|
+
async evaluateHandle(pageFunction, ...args) {
|
120
|
+
return await this.executionContext().evaluateHandle(pageFunction, this, ...args);
|
121
|
+
}
|
122
|
+
/** Fetches a single property from the referenced object.
|
123
|
+
*/
|
124
|
+
async getProperty(propertyName) {
|
125
|
+
const objectHandle = await this.evaluateHandle((object, propertyName) => {
|
126
|
+
const result = { __proto__: null };
|
127
|
+
result[propertyName] = object[propertyName];
|
128
|
+
return result;
|
129
|
+
}, propertyName);
|
130
|
+
const properties = await objectHandle.getProperties();
|
131
|
+
const result = properties.get(propertyName);
|
132
|
+
(0, assert_js_1.assert)(result instanceof JSHandle);
|
133
|
+
await objectHandle.dispose();
|
134
|
+
return result;
|
135
|
+
}
|
136
|
+
/**
|
137
|
+
* The method returns a map with property names as keys and JSHandle
|
138
|
+
* instances for the property values.
|
139
|
+
*
|
140
|
+
* @example
|
141
|
+
* ```js
|
142
|
+
* const listHandle = await page.evaluateHandle(() => document.body.children);
|
143
|
+
* const properties = await listHandle.getProperties();
|
144
|
+
* const children = [];
|
145
|
+
* for (const property of properties.values()) {
|
146
|
+
* const element = property.asElement();
|
147
|
+
* if (element)
|
148
|
+
* children.push(element);
|
149
|
+
* }
|
150
|
+
* children; // holds elementHandles to all children of document.body
|
151
|
+
* ```
|
152
|
+
*/
|
153
|
+
async getProperties() {
|
154
|
+
const response = await this._client.send('Runtime.getProperties', {
|
155
|
+
objectId: this._remoteObject.objectId,
|
156
|
+
ownProperties: true,
|
157
|
+
});
|
158
|
+
const result = new Map();
|
159
|
+
for (const property of response.result) {
|
160
|
+
if (!property.enumerable)
|
161
|
+
continue;
|
162
|
+
result.set(property.name, createJSHandle(this._context, property.value));
|
163
|
+
}
|
164
|
+
return result;
|
165
|
+
}
|
166
|
+
/**
|
167
|
+
* @returns Returns a JSON representation of the object.If the object has a
|
168
|
+
* `toJSON` function, it will not be called.
|
169
|
+
* @remarks
|
170
|
+
*
|
171
|
+
* The JSON is generated by running {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify | JSON.stringify}
|
172
|
+
* on the object in page and consequent {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse} in puppeteer.
|
173
|
+
* **NOTE** The method throws if the referenced object is not stringifiable.
|
174
|
+
*/
|
175
|
+
async jsonValue() {
|
176
|
+
if (this._remoteObject.objectId) {
|
177
|
+
const response = await this._client.send('Runtime.callFunctionOn', {
|
178
|
+
functionDeclaration: 'function() { return this; }',
|
179
|
+
objectId: this._remoteObject.objectId,
|
180
|
+
returnByValue: true,
|
181
|
+
awaitPromise: true,
|
182
|
+
});
|
183
|
+
return helper_js_1.helper.valueFromRemoteObject(response.result);
|
184
|
+
}
|
185
|
+
return helper_js_1.helper.valueFromRemoteObject(this._remoteObject);
|
186
|
+
}
|
187
|
+
/**
|
188
|
+
* @returns Either `null` or the object handle itself, if the object
|
189
|
+
* handle is an instance of {@link ElementHandle}.
|
190
|
+
*/
|
191
|
+
asElement() {
|
192
|
+
/* This always returns null, but subclasses can override this and return an
|
193
|
+
ElementHandle.
|
194
|
+
*/
|
195
|
+
return null;
|
196
|
+
}
|
197
|
+
/**
|
198
|
+
* Stops referencing the element handle, and resolves when the object handle is
|
199
|
+
* successfully disposed of.
|
200
|
+
*/
|
201
|
+
async dispose() {
|
202
|
+
if (this._disposed)
|
203
|
+
return;
|
204
|
+
this._disposed = true;
|
205
|
+
await helper_js_1.helper.releaseObject(this._client, this._remoteObject);
|
206
|
+
}
|
207
|
+
/**
|
208
|
+
* Returns a string representation of the JSHandle.
|
209
|
+
*
|
210
|
+
* @remarks Useful during debugging.
|
211
|
+
*/
|
212
|
+
toString() {
|
213
|
+
if (this._remoteObject.objectId) {
|
214
|
+
const type = this._remoteObject.subtype || this._remoteObject.type;
|
215
|
+
return 'JSHandle@' + type;
|
216
|
+
}
|
217
|
+
return 'JSHandle:' + helper_js_1.helper.valueFromRemoteObject(this._remoteObject);
|
218
|
+
}
|
219
|
+
}
|
220
|
+
exports.JSHandle = JSHandle;
|
221
|
+
/**
|
222
|
+
* ElementHandle represents an in-page DOM element.
|
223
|
+
*
|
224
|
+
* @remarks
|
225
|
+
*
|
226
|
+
* ElementHandles can be created with the {@link Page.$} method.
|
227
|
+
*
|
228
|
+
* ```js
|
229
|
+
* const puppeteer = require('puppeteer');
|
230
|
+
*
|
231
|
+
* (async () => {
|
232
|
+
* const browser = await puppeteer.launch();
|
233
|
+
* const page = await browser.newPage();
|
234
|
+
* await page.goto('https://example.com');
|
235
|
+
* const hrefElement = await page.$('a');
|
236
|
+
* await hrefElement.click();
|
237
|
+
* // ...
|
238
|
+
* })();
|
239
|
+
* ```
|
240
|
+
*
|
241
|
+
* ElementHandle prevents the DOM element from being garbage-collected unless the
|
242
|
+
* handle is {@link JSHandle.dispose | disposed}. ElementHandles are auto-disposed
|
243
|
+
* when their origin frame gets navigated.
|
244
|
+
*
|
245
|
+
* ElementHandle instances can be used as arguments in {@link Page.$eval} and
|
246
|
+
* {@link Page.evaluate} methods.
|
247
|
+
*
|
248
|
+
* If you're using TypeScript, ElementHandle takes a generic argument that
|
249
|
+
* denotes the type of element the handle is holding within. For example, if you
|
250
|
+
* have a handle to a `<select>` element, you can type it as
|
251
|
+
* `ElementHandle<HTMLSelectElement>` and you get some nicer type checks.
|
252
|
+
*
|
253
|
+
* @public
|
254
|
+
*/
|
255
|
+
class ElementHandle extends JSHandle {
|
256
|
+
/**
|
257
|
+
* @internal
|
258
|
+
*/
|
259
|
+
constructor(context, client, remoteObject, page, frameManager) {
|
260
|
+
super(context, client, remoteObject);
|
261
|
+
this._client = client;
|
262
|
+
this._remoteObject = remoteObject;
|
263
|
+
this._page = page;
|
264
|
+
this._frameManager = frameManager;
|
265
|
+
}
|
266
|
+
asElement() {
|
267
|
+
return this;
|
268
|
+
}
|
269
|
+
/**
|
270
|
+
* Resolves to the content frame for element handles referencing
|
271
|
+
* iframe nodes, or null otherwise
|
272
|
+
*/
|
273
|
+
async contentFrame() {
|
274
|
+
const nodeInfo = await this._client.send('DOM.describeNode', {
|
275
|
+
objectId: this._remoteObject.objectId,
|
276
|
+
});
|
277
|
+
if (typeof nodeInfo.node.frameId !== 'string')
|
278
|
+
return null;
|
279
|
+
return this._frameManager.frame(nodeInfo.node.frameId);
|
280
|
+
}
|
281
|
+
async _scrollIntoViewIfNeeded() {
|
282
|
+
const error = await this.evaluate(async (element, pageJavascriptEnabled) => {
|
283
|
+
if (!element.isConnected)
|
284
|
+
return 'Node is detached from document';
|
285
|
+
if (element.nodeType !== Node.ELEMENT_NODE)
|
286
|
+
return 'Node is not of type HTMLElement';
|
287
|
+
// force-scroll if page's javascript is disabled.
|
288
|
+
if (!pageJavascriptEnabled) {
|
289
|
+
element.scrollIntoView({
|
290
|
+
block: 'center',
|
291
|
+
inline: 'center',
|
292
|
+
// @ts-expect-error Chrome still supports behavior: instant but
|
293
|
+
// it's not in the spec so TS shouts We don't want to make this
|
294
|
+
// breaking change in Puppeteer yet so we'll ignore the line.
|
295
|
+
behavior: 'instant',
|
296
|
+
});
|
297
|
+
return false;
|
298
|
+
}
|
299
|
+
const visibleRatio = await new Promise((resolve) => {
|
300
|
+
const observer = new IntersectionObserver((entries) => {
|
301
|
+
resolve(entries[0].intersectionRatio);
|
302
|
+
observer.disconnect();
|
303
|
+
});
|
304
|
+
observer.observe(element);
|
305
|
+
});
|
306
|
+
if (visibleRatio !== 1.0) {
|
307
|
+
element.scrollIntoView({
|
308
|
+
block: 'center',
|
309
|
+
inline: 'center',
|
310
|
+
// @ts-expect-error Chrome still supports behavior: instant but
|
311
|
+
// it's not in the spec so TS shouts We don't want to make this
|
312
|
+
// breaking change in Puppeteer yet so we'll ignore the line.
|
313
|
+
behavior: 'instant',
|
314
|
+
});
|
315
|
+
}
|
316
|
+
return false;
|
317
|
+
}, this._page.isJavaScriptEnabled());
|
318
|
+
if (error)
|
319
|
+
throw new Error(error);
|
320
|
+
}
|
321
|
+
/**
|
322
|
+
* Returns the middle point within an element unless a specific offset is provided.
|
323
|
+
*/
|
324
|
+
async clickablePoint(offset) {
|
325
|
+
const [result, layoutMetrics] = await Promise.all([
|
326
|
+
this._client
|
327
|
+
.send('DOM.getContentQuads', {
|
328
|
+
objectId: this._remoteObject.objectId,
|
329
|
+
})
|
330
|
+
.catch(helper_js_1.debugError),
|
331
|
+
this._client.send('Page.getLayoutMetrics'),
|
332
|
+
]);
|
333
|
+
if (!result || !result.quads.length)
|
334
|
+
throw new Error('Node is either not clickable or not an HTMLElement');
|
335
|
+
// Filter out quads that have too small area to click into.
|
336
|
+
// Fallback to `layoutViewport` in case of using Firefox.
|
337
|
+
const { clientWidth, clientHeight } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
|
338
|
+
const quads = result.quads
|
339
|
+
.map((quad) => this._fromProtocolQuad(quad))
|
340
|
+
.map((quad) => this._intersectQuadWithViewport(quad, clientWidth, clientHeight))
|
341
|
+
.filter((quad) => computeQuadArea(quad) > 1);
|
342
|
+
if (!quads.length)
|
343
|
+
throw new Error('Node is either not clickable or not an HTMLElement');
|
344
|
+
const quad = quads[0];
|
345
|
+
if (offset) {
|
346
|
+
// Return the point of the first quad identified by offset.
|
347
|
+
let minX = Number.MAX_SAFE_INTEGER;
|
348
|
+
let minY = Number.MAX_SAFE_INTEGER;
|
349
|
+
for (const point of quad) {
|
350
|
+
if (point.x < minX) {
|
351
|
+
minX = point.x;
|
352
|
+
}
|
353
|
+
if (point.y < minY) {
|
354
|
+
minY = point.y;
|
355
|
+
}
|
356
|
+
}
|
357
|
+
if (minX !== Number.MAX_SAFE_INTEGER &&
|
358
|
+
minY !== Number.MAX_SAFE_INTEGER) {
|
359
|
+
return {
|
360
|
+
x: minX + offset.x,
|
361
|
+
y: minY + offset.y,
|
362
|
+
};
|
363
|
+
}
|
364
|
+
}
|
365
|
+
// Return the middle point of the first quad.
|
366
|
+
let x = 0;
|
367
|
+
let y = 0;
|
368
|
+
for (const point of quad) {
|
369
|
+
x += point.x;
|
370
|
+
y += point.y;
|
371
|
+
}
|
372
|
+
return {
|
373
|
+
x: x / 4,
|
374
|
+
y: y / 4,
|
375
|
+
};
|
376
|
+
}
|
377
|
+
_getBoxModel() {
|
378
|
+
const params = {
|
379
|
+
objectId: this._remoteObject.objectId,
|
380
|
+
};
|
381
|
+
return this._client
|
382
|
+
.send('DOM.getBoxModel', params)
|
383
|
+
.catch((error) => (0, helper_js_1.debugError)(error));
|
384
|
+
}
|
385
|
+
_fromProtocolQuad(quad) {
|
386
|
+
return [
|
387
|
+
{ x: quad[0], y: quad[1] },
|
388
|
+
{ x: quad[2], y: quad[3] },
|
389
|
+
{ x: quad[4], y: quad[5] },
|
390
|
+
{ x: quad[6], y: quad[7] },
|
391
|
+
];
|
392
|
+
}
|
393
|
+
_intersectQuadWithViewport(quad, width, height) {
|
394
|
+
return quad.map((point) => ({
|
395
|
+
x: Math.min(Math.max(point.x, 0), width),
|
396
|
+
y: Math.min(Math.max(point.y, 0), height),
|
397
|
+
}));
|
398
|
+
}
|
399
|
+
/**
|
400
|
+
* This method scrolls element into view if needed, and then
|
401
|
+
* uses {@link Page.mouse} to hover over the center of the element.
|
402
|
+
* If the element is detached from DOM, the method throws an error.
|
403
|
+
*/
|
404
|
+
async hover() {
|
405
|
+
await this._scrollIntoViewIfNeeded();
|
406
|
+
const { x, y } = await this.clickablePoint();
|
407
|
+
await this._page.mouse.move(x, y);
|
408
|
+
}
|
409
|
+
/**
|
410
|
+
* This method scrolls element into view if needed, and then
|
411
|
+
* uses {@link Page.mouse} to click in the center of the element.
|
412
|
+
* If the element is detached from DOM, the method throws an error.
|
413
|
+
*/
|
414
|
+
async click(options = {}) {
|
415
|
+
await this._scrollIntoViewIfNeeded();
|
416
|
+
const { x, y } = await this.clickablePoint(options.offset);
|
417
|
+
await this._page.mouse.click(x, y, options);
|
418
|
+
}
|
419
|
+
/**
|
420
|
+
* This method creates and captures a dragevent from the element.
|
421
|
+
*/
|
422
|
+
async drag(target) {
|
423
|
+
(0, assert_js_1.assert)(this._page.isDragInterceptionEnabled(), 'Drag Interception is not enabled!');
|
424
|
+
await this._scrollIntoViewIfNeeded();
|
425
|
+
const start = await this.clickablePoint();
|
426
|
+
return await this._page.mouse.drag(start, target);
|
427
|
+
}
|
428
|
+
/**
|
429
|
+
* This method creates a `dragenter` event on the element.
|
430
|
+
*/
|
431
|
+
async dragEnter(data = { items: [], dragOperationsMask: 1 }) {
|
432
|
+
await this._scrollIntoViewIfNeeded();
|
433
|
+
const target = await this.clickablePoint();
|
434
|
+
await this._page.mouse.dragEnter(target, data);
|
435
|
+
}
|
436
|
+
/**
|
437
|
+
* This method creates a `dragover` event on the element.
|
438
|
+
*/
|
439
|
+
async dragOver(data = { items: [], dragOperationsMask: 1 }) {
|
440
|
+
await this._scrollIntoViewIfNeeded();
|
441
|
+
const target = await this.clickablePoint();
|
442
|
+
await this._page.mouse.dragOver(target, data);
|
443
|
+
}
|
444
|
+
/**
|
445
|
+
* This method triggers a drop on the element.
|
446
|
+
*/
|
447
|
+
async drop(data = { items: [], dragOperationsMask: 1 }) {
|
448
|
+
await this._scrollIntoViewIfNeeded();
|
449
|
+
const destination = await this.clickablePoint();
|
450
|
+
await this._page.mouse.drop(destination, data);
|
451
|
+
}
|
452
|
+
/**
|
453
|
+
* This method triggers a dragenter, dragover, and drop on the element.
|
454
|
+
*/
|
455
|
+
async dragAndDrop(target, options) {
|
456
|
+
await this._scrollIntoViewIfNeeded();
|
457
|
+
const startPoint = await this.clickablePoint();
|
458
|
+
const targetPoint = await target.clickablePoint();
|
459
|
+
await this._page.mouse.dragAndDrop(startPoint, targetPoint, options);
|
460
|
+
}
|
461
|
+
/**
|
462
|
+
* Triggers a `change` and `input` event once all the provided options have been
|
463
|
+
* selected. If there's no `<select>` element matching `selector`, the method
|
464
|
+
* throws an error.
|
465
|
+
*
|
466
|
+
* @example
|
467
|
+
* ```js
|
468
|
+
* handle.select('blue'); // single selection
|
469
|
+
* handle.select('red', 'green', 'blue'); // multiple selections
|
470
|
+
* ```
|
471
|
+
* @param values - Values of options to select. If the `<select>` has the
|
472
|
+
* `multiple` attribute, all values are considered, otherwise only the first
|
473
|
+
* one is taken into account.
|
474
|
+
*/
|
475
|
+
async select(...values) {
|
476
|
+
for (const value of values)
|
477
|
+
(0, assert_js_1.assert)(helper_js_1.helper.isString(value), 'Values must be strings. Found value "' +
|
478
|
+
value +
|
479
|
+
'" of type "' +
|
480
|
+
typeof value +
|
481
|
+
'"');
|
482
|
+
return this.evaluate((element, values) => {
|
483
|
+
if (!(element instanceof HTMLSelectElement))
|
484
|
+
throw new Error('Element is not a <select> element.');
|
485
|
+
const options = Array.from(element.options);
|
486
|
+
element.value = undefined;
|
487
|
+
for (const option of options) {
|
488
|
+
option.selected = values.includes(option.value);
|
489
|
+
if (option.selected && !element.multiple)
|
490
|
+
break;
|
491
|
+
}
|
492
|
+
element.dispatchEvent(new Event('input', { bubbles: true }));
|
493
|
+
element.dispatchEvent(new Event('change', { bubbles: true }));
|
494
|
+
return options
|
495
|
+
.filter((option) => option.selected)
|
496
|
+
.map((option) => option.value);
|
497
|
+
}, values);
|
498
|
+
}
|
499
|
+
/**
|
500
|
+
* This method expects `elementHandle` to point to an
|
501
|
+
* {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input | input element}.
|
502
|
+
* @param filePaths - Sets the value of the file input to these paths.
|
503
|
+
* If some of the `filePaths` are relative paths, then they are resolved
|
504
|
+
* relative to the {@link https://nodejs.org/api/process.html#process_process_cwd | current working directory}
|
505
|
+
*/
|
506
|
+
async uploadFile(...filePaths) {
|
507
|
+
const isMultiple = await this.evaluate((element) => {
|
508
|
+
if (!(element instanceof HTMLInputElement)) {
|
509
|
+
throw new Error('uploadFile can only be called on an input element.');
|
510
|
+
}
|
511
|
+
return element.multiple;
|
512
|
+
});
|
513
|
+
(0, assert_js_1.assert)(filePaths.length <= 1 || isMultiple, 'Multiple file uploads only work with <input type=file multiple>');
|
514
|
+
if (!environment_js_1.isNode) {
|
515
|
+
throw new Error(`JSHandle#uploadFile can only be used in Node environments.`);
|
516
|
+
}
|
517
|
+
/*
|
518
|
+
This import is only needed for `uploadFile`, so keep it scoped here to
|
519
|
+
avoid paying the cost unnecessarily.
|
520
|
+
*/
|
521
|
+
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
522
|
+
const fs = await helper_js_1.helper.importFSModule();
|
523
|
+
// Locate all files and confirm that they exist.
|
524
|
+
const files = await Promise.all(filePaths.map(async (filePath) => {
|
525
|
+
const resolvedPath = path.resolve(filePath);
|
526
|
+
try {
|
527
|
+
await fs.promises.access(resolvedPath, fs.constants.R_OK);
|
528
|
+
}
|
529
|
+
catch (error) {
|
530
|
+
if (error.code === 'ENOENT')
|
531
|
+
throw new Error(`${filePath} does not exist or is not readable`);
|
532
|
+
}
|
533
|
+
return resolvedPath;
|
534
|
+
}));
|
535
|
+
const { objectId } = this._remoteObject;
|
536
|
+
const { node } = await this._client.send('DOM.describeNode', { objectId });
|
537
|
+
const { backendNodeId } = node;
|
538
|
+
/* The zero-length array is a special case, it seems that
|
539
|
+
DOM.setFileInputFiles does not actually update the files in that case,
|
540
|
+
so the solution is to eval the element value to a new FileList directly.
|
541
|
+
*/
|
542
|
+
if (files.length === 0) {
|
543
|
+
await this.evaluate((element) => {
|
544
|
+
element.files = new DataTransfer().files;
|
545
|
+
// Dispatch events for this case because it should behave akin to a user action.
|
546
|
+
element.dispatchEvent(new Event('input', { bubbles: true }));
|
547
|
+
element.dispatchEvent(new Event('change', { bubbles: true }));
|
548
|
+
});
|
549
|
+
}
|
550
|
+
else {
|
551
|
+
await this._client.send('DOM.setFileInputFiles', {
|
552
|
+
objectId,
|
553
|
+
files,
|
554
|
+
backendNodeId,
|
555
|
+
});
|
556
|
+
}
|
557
|
+
}
|
558
|
+
/**
|
559
|
+
* This method scrolls element into view if needed, and then uses
|
560
|
+
* {@link Touchscreen.tap} to tap in the center of the element.
|
561
|
+
* If the element is detached from DOM, the method throws an error.
|
562
|
+
*/
|
563
|
+
async tap() {
|
564
|
+
await this._scrollIntoViewIfNeeded();
|
565
|
+
const { x, y } = await this.clickablePoint();
|
566
|
+
await this._page.touchscreen.tap(x, y);
|
567
|
+
}
|
568
|
+
/**
|
569
|
+
* Calls {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus | focus} on the element.
|
570
|
+
*/
|
571
|
+
async focus() {
|
572
|
+
await this.evaluate((element) => element.focus());
|
573
|
+
}
|
574
|
+
/**
|
575
|
+
* Focuses the element, and then sends a `keydown`, `keypress`/`input`, and
|
576
|
+
* `keyup` event for each character in the text.
|
577
|
+
*
|
578
|
+
* To press a special key, like `Control` or `ArrowDown`,
|
579
|
+
* use {@link ElementHandle.press}.
|
580
|
+
*
|
581
|
+
* @example
|
582
|
+
* ```js
|
583
|
+
* await elementHandle.type('Hello'); // Types instantly
|
584
|
+
* await elementHandle.type('World', {delay: 100}); // Types slower, like a user
|
585
|
+
* ```
|
586
|
+
*
|
587
|
+
* @example
|
588
|
+
* An example of typing into a text field and then submitting the form:
|
589
|
+
*
|
590
|
+
* ```js
|
591
|
+
* const elementHandle = await page.$('input');
|
592
|
+
* await elementHandle.type('some text');
|
593
|
+
* await elementHandle.press('Enter');
|
594
|
+
* ```
|
595
|
+
*/
|
596
|
+
async type(text, options) {
|
597
|
+
await this.focus();
|
598
|
+
await this._page.keyboard.type(text, options);
|
599
|
+
}
|
600
|
+
/**
|
601
|
+
* Focuses the element, and then uses {@link Keyboard.down} and {@link Keyboard.up}.
|
602
|
+
*
|
603
|
+
* @remarks
|
604
|
+
* If `key` is a single character and no modifier keys besides `Shift`
|
605
|
+
* are being held down, a `keypress`/`input` event will also be generated.
|
606
|
+
* The `text` option can be specified to force an input event to be generated.
|
607
|
+
*
|
608
|
+
* **NOTE** Modifier keys DO affect `elementHandle.press`. Holding down `Shift`
|
609
|
+
* will type the text in upper case.
|
610
|
+
*
|
611
|
+
* @param key - Name of key to press, such as `ArrowLeft`.
|
612
|
+
* See {@link KeyInput} for a list of all key names.
|
613
|
+
*/
|
614
|
+
async press(key, options) {
|
615
|
+
await this.focus();
|
616
|
+
await this._page.keyboard.press(key, options);
|
617
|
+
}
|
618
|
+
/**
|
619
|
+
* This method returns the bounding box of the element (relative to the main frame),
|
620
|
+
* or `null` if the element is not visible.
|
621
|
+
*/
|
622
|
+
async boundingBox() {
|
623
|
+
const result = await this._getBoxModel();
|
624
|
+
if (!result)
|
625
|
+
return null;
|
626
|
+
const quad = result.model.border;
|
627
|
+
const x = Math.min(quad[0], quad[2], quad[4], quad[6]);
|
628
|
+
const y = Math.min(quad[1], quad[3], quad[5], quad[7]);
|
629
|
+
const width = Math.max(quad[0], quad[2], quad[4], quad[6]) - x;
|
630
|
+
const height = Math.max(quad[1], quad[3], quad[5], quad[7]) - y;
|
631
|
+
return { x, y, width, height };
|
632
|
+
}
|
633
|
+
/**
|
634
|
+
* This method returns boxes of the element, or `null` if the element is not visible.
|
635
|
+
*
|
636
|
+
* @remarks
|
637
|
+
*
|
638
|
+
* Boxes are represented as an array of points;
|
639
|
+
* Each Point is an object `{x, y}`. Box points are sorted clock-wise.
|
640
|
+
*/
|
641
|
+
async boxModel() {
|
642
|
+
const result = await this._getBoxModel();
|
643
|
+
if (!result)
|
644
|
+
return null;
|
645
|
+
const { content, padding, border, margin, width, height } = result.model;
|
646
|
+
return {
|
647
|
+
content: this._fromProtocolQuad(content),
|
648
|
+
padding: this._fromProtocolQuad(padding),
|
649
|
+
border: this._fromProtocolQuad(border),
|
650
|
+
margin: this._fromProtocolQuad(margin),
|
651
|
+
width,
|
652
|
+
height,
|
653
|
+
};
|
654
|
+
}
|
655
|
+
/**
|
656
|
+
* This method scrolls element into view if needed, and then uses
|
657
|
+
* {@link Page.screenshot} to take a screenshot of the element.
|
658
|
+
* If the element is detached from DOM, the method throws an error.
|
659
|
+
*/
|
660
|
+
async screenshot(options = {}) {
|
661
|
+
let needsViewportReset = false;
|
662
|
+
let boundingBox = await this.boundingBox();
|
663
|
+
(0, assert_js_1.assert)(boundingBox, 'Node is either not visible or not an HTMLElement');
|
664
|
+
const viewport = this._page.viewport();
|
665
|
+
if (viewport &&
|
666
|
+
(boundingBox.width > viewport.width ||
|
667
|
+
boundingBox.height > viewport.height)) {
|
668
|
+
const newViewport = {
|
669
|
+
width: Math.max(viewport.width, Math.ceil(boundingBox.width)),
|
670
|
+
height: Math.max(viewport.height, Math.ceil(boundingBox.height)),
|
671
|
+
};
|
672
|
+
await this._page.setViewport(Object.assign({}, viewport, newViewport));
|
673
|
+
needsViewportReset = true;
|
674
|
+
}
|
675
|
+
await this._scrollIntoViewIfNeeded();
|
676
|
+
boundingBox = await this.boundingBox();
|
677
|
+
(0, assert_js_1.assert)(boundingBox, 'Node is either not visible or not an HTMLElement');
|
678
|
+
(0, assert_js_1.assert)(boundingBox.width !== 0, 'Node has 0 width.');
|
679
|
+
(0, assert_js_1.assert)(boundingBox.height !== 0, 'Node has 0 height.');
|
680
|
+
const layoutMetrics = await this._client.send('Page.getLayoutMetrics');
|
681
|
+
// Fallback to `layoutViewport` in case of using Firefox.
|
682
|
+
const { pageX, pageY } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
|
683
|
+
const clip = Object.assign({}, boundingBox);
|
684
|
+
clip.x += pageX;
|
685
|
+
clip.y += pageY;
|
686
|
+
const imageData = await this._page.screenshot(Object.assign({}, {
|
687
|
+
clip,
|
688
|
+
}, options));
|
689
|
+
if (needsViewportReset)
|
690
|
+
await this._page.setViewport(viewport);
|
691
|
+
return imageData;
|
692
|
+
}
|
693
|
+
/**
|
694
|
+
* Runs `element.querySelector` within the page. If no element matches the selector,
|
695
|
+
* the return value resolves to `null`.
|
696
|
+
*/
|
697
|
+
async $(selector) {
|
698
|
+
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
699
|
+
return queryHandler.queryOne(this, updatedSelector);
|
700
|
+
}
|
701
|
+
/**
|
702
|
+
* Runs `element.querySelectorAll` within the page. If no elements match the selector,
|
703
|
+
* the return value resolves to `[]`.
|
704
|
+
*/
|
705
|
+
async $$(selector) {
|
706
|
+
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
707
|
+
return queryHandler.queryAll(this, updatedSelector);
|
708
|
+
}
|
709
|
+
/**
|
710
|
+
* This method runs `document.querySelector` within the element and passes it as
|
711
|
+
* the first argument to `pageFunction`. If there's no element matching `selector`,
|
712
|
+
* the method throws an error.
|
713
|
+
*
|
714
|
+
* If `pageFunction` returns a Promise, then `frame.$eval` would wait for the promise
|
715
|
+
* to resolve and return its value.
|
716
|
+
*
|
717
|
+
* @example
|
718
|
+
* ```js
|
719
|
+
* const tweetHandle = await page.$('.tweet');
|
720
|
+
* expect(await tweetHandle.$eval('.like', node => node.innerText)).toBe('100');
|
721
|
+
* expect(await tweetHandle.$eval('.retweets', node => node.innerText)).toBe('10');
|
722
|
+
* ```
|
723
|
+
*/
|
724
|
+
async $eval(selector, pageFunction, ...args) {
|
725
|
+
const elementHandle = await this.$(selector);
|
726
|
+
if (!elementHandle)
|
727
|
+
throw new Error(`Error: failed to find element matching selector "${selector}"`);
|
728
|
+
const result = await elementHandle.evaluate(pageFunction, ...args);
|
729
|
+
await elementHandle.dispose();
|
730
|
+
/**
|
731
|
+
* This `as` is a little unfortunate but helps TS understand the behavior of
|
732
|
+
* `elementHandle.evaluate`. If evaluate returns an element it will return an
|
733
|
+
* ElementHandle instance, rather than the plain object. All the
|
734
|
+
* WrapElementHandle type does is wrap ReturnType into
|
735
|
+
* ElementHandle<ReturnType> if it is an ElementHandle, or leave it alone as
|
736
|
+
* ReturnType if it isn't.
|
737
|
+
*/
|
738
|
+
return result;
|
739
|
+
}
|
740
|
+
/**
|
741
|
+
* This method runs `document.querySelectorAll` within the element and passes it as
|
742
|
+
* the first argument to `pageFunction`. If there's no element matching `selector`,
|
743
|
+
* the method throws an error.
|
744
|
+
*
|
745
|
+
* If `pageFunction` returns a Promise, then `frame.$$eval` would wait for the
|
746
|
+
* promise to resolve and return its value.
|
747
|
+
*
|
748
|
+
* @example
|
749
|
+
* ```html
|
750
|
+
* <div class="feed">
|
751
|
+
* <div class="tweet">Hello!</div>
|
752
|
+
* <div class="tweet">Hi!</div>
|
753
|
+
* </div>
|
754
|
+
* ```
|
755
|
+
*
|
756
|
+
* @example
|
757
|
+
* ```js
|
758
|
+
* const feedHandle = await page.$('.feed');
|
759
|
+
* expect(await feedHandle.$$eval('.tweet', nodes => nodes.map(n => n.innerText)))
|
760
|
+
* .toEqual(['Hello!', 'Hi!']);
|
761
|
+
* ```
|
762
|
+
*/
|
763
|
+
async $$eval(selector, pageFunction, ...args) {
|
764
|
+
const { updatedSelector, queryHandler } = (0, QueryHandler_js_1.getQueryHandlerAndSelector)(selector);
|
765
|
+
const arrayHandle = await queryHandler.queryAllArray(this, updatedSelector);
|
766
|
+
const result = await arrayHandle.evaluate(pageFunction, ...args);
|
767
|
+
await arrayHandle.dispose();
|
768
|
+
/* This `as` exists for the same reason as the `as` in $eval above.
|
769
|
+
* See the comment there for a full explanation.
|
770
|
+
*/
|
771
|
+
return result;
|
772
|
+
}
|
773
|
+
/**
|
774
|
+
* The method evaluates the XPath expression relative to the elementHandle.
|
775
|
+
* If there are no such elements, the method will resolve to an empty array.
|
776
|
+
* @param expression - Expression to {@link https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate | evaluate}
|
777
|
+
*/
|
778
|
+
async $x(expression) {
|
779
|
+
const arrayHandle = await this.evaluateHandle((element, expression) => {
|
780
|
+
const document = element.ownerDocument || element;
|
781
|
+
const iterator = document.evaluate(expression, element, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE);
|
782
|
+
const array = [];
|
783
|
+
let item;
|
784
|
+
while ((item = iterator.iterateNext()))
|
785
|
+
array.push(item);
|
786
|
+
return array;
|
787
|
+
}, expression);
|
788
|
+
const properties = await arrayHandle.getProperties();
|
789
|
+
await arrayHandle.dispose();
|
790
|
+
const result = [];
|
791
|
+
for (const property of properties.values()) {
|
792
|
+
const elementHandle = property.asElement();
|
793
|
+
if (elementHandle)
|
794
|
+
result.push(elementHandle);
|
795
|
+
}
|
796
|
+
return result;
|
797
|
+
}
|
798
|
+
/**
|
799
|
+
* Resolves to true if the element is visible in the current viewport.
|
800
|
+
*/
|
801
|
+
async isIntersectingViewport(options) {
|
802
|
+
const { threshold = 0 } = options || {};
|
803
|
+
return await this.evaluate(async (element, threshold) => {
|
804
|
+
const visibleRatio = await new Promise((resolve) => {
|
805
|
+
const observer = new IntersectionObserver((entries) => {
|
806
|
+
resolve(entries[0].intersectionRatio);
|
807
|
+
observer.disconnect();
|
808
|
+
});
|
809
|
+
observer.observe(element);
|
810
|
+
});
|
811
|
+
return threshold === 1 ? visibleRatio === 1 : visibleRatio > threshold;
|
812
|
+
}, threshold);
|
813
|
+
}
|
814
|
+
}
|
815
|
+
exports.ElementHandle = ElementHandle;
|
816
|
+
function computeQuadArea(quad) {
|
817
|
+
/* Compute sum of all directed areas of adjacent triangles
|
818
|
+
https://en.wikipedia.org/wiki/Polygon#Simple_polygons
|
819
|
+
*/
|
820
|
+
let area = 0;
|
821
|
+
for (let i = 0; i < quad.length; ++i) {
|
822
|
+
const p1 = quad[i];
|
823
|
+
const p2 = quad[(i + 1) % quad.length];
|
824
|
+
area += (p1.x * p2.y - p2.x * p1.y) / 2;
|
825
|
+
}
|
826
|
+
return Math.abs(area);
|
827
|
+
}
|
828
828
|
//# sourceMappingURL=JSHandle.js.map
|