@checkly/playwright-core 1.42.17 → 1.47.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ThirdPartyNotices.txt +144 -109
- package/browsers.json +15 -25
- package/lib/androidServerImpl.js +1 -1
- package/lib/browserServerImpl.js +1 -1
- package/lib/cli/driver.js +1 -3
- package/lib/cli/program.js +5 -10
- package/lib/client/android.js +1 -1
- package/lib/client/api.js +7 -0
- package/lib/client/browserContext.js +37 -5
- package/lib/client/browserType.js +19 -11
- package/lib/client/channelOwner.js +19 -16
- package/lib/client/clientInstrumentation.js +17 -7
- package/lib/client/clock.js +68 -0
- package/lib/client/connection.js +9 -6
- package/lib/client/electron.js +7 -5
- package/lib/client/elementHandle.js +44 -14
- package/lib/client/eventEmitter.js +314 -0
- package/lib/client/fetch.js +81 -28
- package/lib/client/frame.js +2 -4
- package/lib/client/jsHandle.js +7 -1
- package/lib/client/locator.js +9 -0
- package/lib/client/network.js +12 -9
- package/lib/client/page.js +45 -23
- package/lib/client/playwright.js +3 -0
- package/lib/client/tracing.js +7 -4
- package/lib/common/socksProxy.js +2 -2
- package/lib/generated/clockSource.js +7 -0
- package/lib/generated/injectedScriptSource.js +1 -1
- package/lib/generated/recorderSource.js +1 -1
- package/lib/generated/utilityScriptSource.js +1 -1
- package/lib/protocol/serializers.js +12 -11
- package/lib/protocol/validator.js +137 -55
- package/lib/server/bidi/bidiBrowser.js +296 -0
- package/lib/server/bidi/bidiConnection.js +206 -0
- package/lib/server/bidi/bidiExecutionContext.js +162 -0
- package/lib/server/bidi/bidiFirefox.js +110 -0
- package/lib/server/bidi/bidiInput.js +174 -0
- package/lib/server/bidi/bidiNetworkManager.js +304 -0
- package/lib/server/bidi/bidiPage.js +456 -0
- package/lib/server/bidi/third_party/bidiDeserializer.js +93 -0
- package/lib/server/bidi/third_party/bidiKeyboard.js +238 -0
- package/lib/server/bidi/third_party/bidiProtocol.js +139 -0
- package/lib/server/bidi/third_party/bidiSerializer.js +144 -0
- package/lib/server/browser.js +9 -1
- package/lib/server/browserContext.js +97 -22
- package/lib/server/browserType.js +27 -20
- package/lib/server/chromium/chromium.js +30 -15
- package/lib/server/chromium/chromiumSwitches.js +6 -3
- package/lib/server/chromium/crBrowser.js +11 -17
- package/lib/server/chromium/crConnection.js +2 -2
- package/lib/server/chromium/crDragDrop.js +28 -29
- package/lib/server/chromium/crNetworkManager.js +130 -84
- package/lib/server/chromium/crPage.js +34 -79
- package/lib/server/chromium/crProtocolHelper.js +3 -1
- package/lib/server/chromium/crServiceWorker.js +20 -23
- package/lib/server/chromium/videoRecorder.js +1 -1
- package/lib/server/clock.js +125 -0
- package/lib/server/codegen/csharp.js +299 -0
- package/lib/server/codegen/java.js +235 -0
- package/lib/server/codegen/javascript.js +223 -0
- package/lib/server/codegen/jsonl.js +47 -0
- package/lib/server/codegen/language.js +76 -0
- package/lib/server/codegen/languages.js +30 -0
- package/lib/server/codegen/python.js +265 -0
- package/lib/server/codegen/types.js +5 -0
- package/lib/server/debugController.js +3 -5
- package/lib/server/deviceDescriptors.js +9 -4
- package/lib/server/deviceDescriptorsSource.json +239 -119
- package/lib/server/dispatchers/androidDispatcher.js +1 -1
- package/lib/server/dispatchers/browserContextDispatcher.js +51 -7
- package/lib/server/dispatchers/dispatcher.js +36 -40
- package/lib/server/dispatchers/frameDispatcher.js +1 -2
- package/lib/server/dispatchers/jsHandleDispatcher.js +1 -1
- package/lib/server/dispatchers/jsonPipeDispatcher.js +4 -6
- package/lib/server/dispatchers/localUtilsDispatcher.js +19 -5
- package/lib/server/dispatchers/networkDispatchers.js +2 -2
- package/lib/server/dispatchers/pageDispatcher.js +5 -2
- package/lib/server/dispatchers/playwrightDispatcher.js +1 -0
- package/lib/server/dispatchers/writableStreamDispatcher.js +8 -5
- package/lib/server/dom.js +90 -53
- package/lib/server/electron/electron.js +21 -4
- package/lib/server/fetch.js +74 -25
- package/lib/server/fileUploadUtils.js +7 -3
- package/lib/server/firefox/ffBrowser.js +36 -25
- package/lib/server/firefox/ffConnection.js +2 -2
- package/lib/server/firefox/ffNetworkManager.js +6 -4
- package/lib/server/firefox/ffPage.js +22 -24
- package/lib/server/firefox/firefox.js +25 -6
- package/lib/server/frameSelectors.js +2 -2
- package/lib/server/frames.js +205 -159
- package/lib/server/har/harTracer.js +4 -12
- package/lib/server/helper.js +3 -3
- package/lib/server/index.js +18 -0
- package/lib/server/input.js +18 -8
- package/lib/server/instrumentation.js +0 -4
- package/lib/server/isomorphic/utilityScriptSerializers.js +19 -5
- package/lib/server/javascript.js +3 -2
- package/lib/server/launchApp.js +3 -2
- package/lib/server/network.js +14 -4
- package/lib/server/page.js +75 -46
- package/lib/server/playwright.js +5 -2
- package/lib/server/recorder/codeGenerator.js +2 -1
- package/lib/server/recorder/contextRecorder.js +316 -0
- package/lib/server/recorder/csharp.js +2 -1
- package/lib/server/recorder/java.js +2 -1
- package/lib/server/recorder/javascript.js +2 -1
- package/lib/server/recorder/jsonl.js +2 -1
- package/lib/server/recorder/language.js +2 -1
- package/lib/server/recorder/python.js +2 -1
- package/lib/server/recorder/recorderApp.js +14 -5
- package/lib/server/recorder/recorderCollection.js +127 -0
- package/lib/server/recorder/recorderRunner.js +177 -0
- package/lib/server/recorder/recorderUtils.js +23 -0
- package/lib/server/recorder/throttledFile.js +46 -0
- package/lib/server/recorder/utils.js +2 -1
- package/lib/server/recorder.js +42 -418
- package/lib/server/registry/index.js +99 -100
- package/lib/server/registry/nativeDeps.js +107 -0
- package/lib/server/screenshotter.js +6 -12
- package/lib/server/socksClientCertificatesInterceptor.js +328 -0
- package/lib/server/trace/recorder/snapshotter.js +4 -1
- package/lib/server/trace/recorder/tracing.js +27 -96
- package/lib/server/trace/viewer/traceViewer.js +54 -67
- package/lib/server/transport.js +1 -1
- package/lib/server/webkit/webkit.js +5 -5
- package/lib/server/webkit/wkBrowser.js +14 -14
- package/lib/server/webkit/wkConnection.js +3 -3
- package/lib/server/webkit/wkInterceptableRequest.js +8 -4
- package/lib/server/webkit/wkPage.js +52 -34
- package/lib/server/webkit/wkProvisionalPage.js +36 -1
- package/lib/utils/crypto.js +141 -0
- package/lib/utils/debugLogger.js +2 -0
- package/lib/utils/env.js +4 -2
- package/lib/utils/expectUtils.js +33 -0
- package/lib/utils/fileUtils.js +140 -1
- package/lib/utils/glob.js +2 -1
- package/lib/utils/happy-eyeballs.js +29 -2
- package/lib/utils/hostPlatform.js +13 -4
- package/lib/utils/httpServer.js +54 -13
- package/lib/utils/index.js +53 -31
- package/lib/utils/isomorphic/cssTokenizer.js +1 -1
- package/lib/utils/isomorphic/locatorParser.js +1 -1
- package/lib/utils/isomorphic/mimeType.js +29 -0
- package/lib/utils/isomorphic/stringUtils.js +28 -1
- package/lib/utils/isomorphic/urlMatch.js +120 -0
- package/lib/utils/mimeType.js +2 -1
- package/lib/utils/network.js +7 -35
- package/lib/utils/stackTrace.js +2 -4
- package/lib/utils/timeoutRunner.js +11 -76
- package/lib/utils/zones.js +23 -60
- package/lib/utilsBundle.js +2 -1
- package/lib/utilsBundleImpl/index.js +33 -31
- package/lib/vite/htmlReport/index.html +12 -12
- package/lib/vite/recorder/assets/codeMirrorModule-BN0yUF4I.js +24 -0
- package/lib/vite/recorder/assets/{codicon-zGuYmc9o.ttf → codicon-DCmgc-ay.ttf} +0 -0
- package/lib/vite/recorder/assets/index-B-MT5gKo.css +1 -0
- package/lib/vite/recorder/assets/index-DVt3E1Ef.js +47 -0
- package/lib/vite/recorder/index.html +2 -2
- package/lib/vite/traceViewer/assets/codeMirrorModule-5yiV-3wl.js +16831 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-B7Z3vq11.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-C6p3E9Zg.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-CcviAl53.js +16831 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-CqYUz5ms.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-DS3v0XrQ.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-Dx6AXgMV.js +16838 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-T_sdMrbM.js +24 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-V7N6ppkd.js +15585 -0
- package/lib/vite/traceViewer/assets/testServerConnection-D-tXL3sj.js +224 -0
- package/lib/vite/traceViewer/assets/testServerConnection-DeE2kSzz.js +1 -0
- package/lib/vite/traceViewer/assets/workbench-Bjkiwcr1.js +19119 -0
- package/lib/vite/traceViewer/assets/workbench-C43LWZEX.js +72 -0
- package/lib/vite/traceViewer/assets/workbench-C5OQh9VX.js +19119 -0
- package/lib/vite/traceViewer/assets/workbench-Crj6jzdv.js +19119 -0
- package/lib/vite/traceViewer/assets/workbench-DrQjKdyE.js +72 -0
- package/lib/vite/traceViewer/assets/workbench-Pa1v1Ojh.js +72 -0
- package/lib/vite/traceViewer/assets/workbench-caTaZnzx.js +72 -0
- package/lib/vite/traceViewer/assets/workbench-u2lRPMOT.js +72 -0
- package/lib/vite/traceViewer/assets/wsPort-EUvw-dwH.js +18540 -0
- package/lib/vite/traceViewer/assets/xtermModule-CZ7sDYXB.js +6529 -0
- package/lib/vite/traceViewer/assets/xtermModule-_6TC5FYT.js +6529 -0
- package/lib/vite/traceViewer/codeMirrorModule.Cy8X9Wtw.css +344 -0
- package/lib/vite/traceViewer/codeMirrorModule.svF_VrcJ.css +344 -0
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/embedded.BBZ9gQEw.js +104 -0
- package/lib/vite/traceViewer/embedded.BQq6Psnz.js +104 -0
- package/lib/vite/traceViewer/embedded.BVDVQOzc.js +2 -0
- package/lib/vite/traceViewer/embedded.Bn8Ptzv6.js +2 -0
- package/lib/vite/traceViewer/embedded.CvhnUgIi.js +2 -0
- package/lib/vite/traceViewer/embedded.D27cnKiB.js +104 -0
- package/lib/vite/traceViewer/embedded.DPqrDeET.js +2 -0
- package/lib/vite/traceViewer/embedded.DbzY7Q8w.js +2 -0
- package/lib/vite/traceViewer/embedded.DjZq4InJ.css +68 -0
- package/lib/vite/traceViewer/embedded.html +16 -0
- package/lib/vite/traceViewer/embedded.w7WN2u1R.css +1 -0
- package/lib/vite/traceViewer/index.5mge2rY_.css +124 -0
- package/lib/vite/traceViewer/index.6KJ-JQ0L.js +180 -0
- package/lib/vite/traceViewer/index.B8dgQwuN.js +2 -0
- package/lib/vite/traceViewer/index.BGj8jY3H.js +2 -0
- package/lib/vite/traceViewer/index.BSak5QT9.js +2 -0
- package/lib/vite/traceViewer/index.C0EgJ4oW.js +195 -0
- package/lib/vite/traceViewer/index.CUpI-BFe.js +195 -0
- package/lib/vite/traceViewer/{index.-g_5lMbJ.css → index.CrbWWHbf.css} +1 -1
- package/lib/vite/traceViewer/index.DkRbtWVo.js +195 -0
- package/lib/vite/traceViewer/index.QanXxRUb.css +131 -0
- package/lib/vite/traceViewer/index._cX8k4co.js +2 -0
- package/lib/vite/traceViewer/index.html +5 -4
- package/lib/vite/traceViewer/index.pMAN88y-.js +2 -0
- package/lib/vite/traceViewer/snapshot.html +1 -1
- package/lib/vite/traceViewer/sw.bundle.js +3 -4
- package/lib/vite/traceViewer/uiMode.D-tg1Oci.js +1730 -0
- package/lib/vite/traceViewer/uiMode.D3cNFP6u.css +1 -0
- package/lib/vite/traceViewer/uiMode.DKjMBMlc.js +1730 -0
- package/lib/vite/traceViewer/uiMode.DVWUEIHq.css +1424 -0
- package/lib/vite/traceViewer/uiMode.DVrL7a1K.js +10 -0
- package/lib/vite/traceViewer/uiMode.Dg9oJCQU.js +10 -0
- package/lib/vite/traceViewer/uiMode.DwZAzstF.js +10 -0
- package/lib/vite/traceViewer/uiMode.O07awP3T.js +10 -0
- package/lib/vite/traceViewer/uiMode.gGHHTsyL.js +1730 -0
- package/lib/vite/traceViewer/uiMode.html +5 -4
- package/lib/vite/traceViewer/uiMode.iq7CyYy7.js +1490 -0
- package/lib/vite/traceViewer/uiMode.jY2s-9ps.js +10 -0
- package/lib/vite/traceViewer/uiMode.xvJHbkzl.css +1324 -0
- package/lib/vite/traceViewer/workbench.B3X2QtYa.css +3702 -0
- package/lib/vite/traceViewer/workbench.DjbIuxix.css +1 -0
- package/lib/vite/traceViewer/workbench.DyTpxWVb.css +1 -0
- package/lib/vite/traceViewer/workbench.wuxQoE2z.css +3703 -0
- package/lib/vite/traceViewer/wsPort.p5jUwABW.css +3450 -0
- package/lib/vite/traceViewer/xtermModule.4oRVGWQ-.css +209 -0
- package/lib/vite/traceViewer/xtermModule.OKEVRlkP.css +209 -0
- package/package.json +2 -2
- package/types/protocol.d.ts +960 -78
- package/types/structs.d.ts +1 -1
- package/types/types.d.ts +3083 -2448
- package/lib/vite/recorder/assets/codeMirrorModule-I9ks4y7D.js +0 -24
- package/lib/vite/recorder/assets/index-ljsTwXtJ.css +0 -1
- package/lib/vite/recorder/assets/index-yg8ypzl6.js +0 -47
- package/lib/vite/traceViewer/assets/codeMirrorModule-0bpaqixv.js +0 -24
- package/lib/vite/traceViewer/assets/wsPort-_JBDEilC.js +0 -69
- package/lib/vite/traceViewer/index.u51inEcm.js +0 -2
- package/lib/vite/traceViewer/uiMode.Fb0bNA4H.js +0 -10
- package/lib/vite/traceViewer/uiMode.pWy0Re7G.css +0 -1
- package/lib/vite/traceViewer/wsPort.zR1WIy9-.css +0 -1
- /package/lib/vite/recorder/assets/{codeMirrorModule-Hs9-1ZG4.css → codeMirrorModule-ez37Vkbh.css} +0 -0
- /package/lib/vite/traceViewer/assets/{xtermModule-Yt6xwiJ_.js → xtermModule-BeNbaIVa.js} +0 -0
- /package/lib/vite/traceViewer/{codeMirrorModule.Hs9-1ZG4.css → codeMirrorModule.ez37Vkbh.css} +0 -0
- /package/lib/vite/traceViewer/{xtermModule.0lwXJFHT.css → xtermModule.DSXBckUd.css} +0 -0
|
@@ -0,0 +1,314 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.EventEmitter = void 0;
|
|
7
|
+
var _events = require("events");
|
|
8
|
+
var _utils = require("../utils");
|
|
9
|
+
/**
|
|
10
|
+
* Copyright Joyent, Inc. and other Node contributors.
|
|
11
|
+
* Modifications copyright (c) Microsoft Corporation.
|
|
12
|
+
*
|
|
13
|
+
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
14
|
+
* copy of this software and associated documentation files (the
|
|
15
|
+
* "Software"), to deal in the Software without restriction, including
|
|
16
|
+
* without limitation the rights to use, copy, modify, merge, publish,
|
|
17
|
+
* distribute, sublicense, and/or sell copies of the Software, and to permit
|
|
18
|
+
* persons to whom the Software is furnished to do so, subject to the
|
|
19
|
+
* following conditions:
|
|
20
|
+
*
|
|
21
|
+
* The above copyright notice and this permission notice shall be included
|
|
22
|
+
* in all copies or substantial portions of the Software.
|
|
23
|
+
*
|
|
24
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
25
|
+
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
26
|
+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
|
27
|
+
* NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
28
|
+
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
|
29
|
+
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
|
30
|
+
* USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
31
|
+
*/
|
|
32
|
+
|
|
33
|
+
class EventEmitter {
|
|
34
|
+
constructor() {
|
|
35
|
+
this._events = undefined;
|
|
36
|
+
this._eventsCount = 0;
|
|
37
|
+
this._maxListeners = undefined;
|
|
38
|
+
this._pendingHandlers = new Map();
|
|
39
|
+
this._rejectionHandler = void 0;
|
|
40
|
+
if (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) {
|
|
41
|
+
this._events = Object.create(null);
|
|
42
|
+
this._eventsCount = 0;
|
|
43
|
+
}
|
|
44
|
+
this._maxListeners = this._maxListeners || undefined;
|
|
45
|
+
this.on = this.addListener;
|
|
46
|
+
this.off = this.removeListener;
|
|
47
|
+
}
|
|
48
|
+
setMaxListeners(n) {
|
|
49
|
+
if (typeof n !== 'number' || n < 0 || Number.isNaN(n)) throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + '.');
|
|
50
|
+
this._maxListeners = n;
|
|
51
|
+
return this;
|
|
52
|
+
}
|
|
53
|
+
getMaxListeners() {
|
|
54
|
+
return this._maxListeners === undefined ? _events.EventEmitter.defaultMaxListeners : this._maxListeners;
|
|
55
|
+
}
|
|
56
|
+
emit(type, ...args) {
|
|
57
|
+
const events = this._events;
|
|
58
|
+
if (events === undefined) return false;
|
|
59
|
+
const handler = events === null || events === void 0 ? void 0 : events[type];
|
|
60
|
+
if (handler === undefined) return false;
|
|
61
|
+
if (typeof handler === 'function') {
|
|
62
|
+
this._callHandler(type, handler, args);
|
|
63
|
+
} else {
|
|
64
|
+
const len = handler.length;
|
|
65
|
+
const listeners = handler.slice();
|
|
66
|
+
for (let i = 0; i < len; ++i) this._callHandler(type, listeners[i], args);
|
|
67
|
+
}
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
_callHandler(type, handler, args) {
|
|
71
|
+
const promise = Reflect.apply(handler, this, args);
|
|
72
|
+
if (!(promise instanceof Promise)) return;
|
|
73
|
+
let set = this._pendingHandlers.get(type);
|
|
74
|
+
if (!set) {
|
|
75
|
+
set = new Set();
|
|
76
|
+
this._pendingHandlers.set(type, set);
|
|
77
|
+
}
|
|
78
|
+
set.add(promise);
|
|
79
|
+
promise.catch(e => {
|
|
80
|
+
if (this._rejectionHandler) this._rejectionHandler(e);else throw e;
|
|
81
|
+
}).finally(() => set.delete(promise));
|
|
82
|
+
}
|
|
83
|
+
addListener(type, listener) {
|
|
84
|
+
return this._addListener(type, listener, false);
|
|
85
|
+
}
|
|
86
|
+
on(type, listener) {
|
|
87
|
+
return this._addListener(type, listener, false);
|
|
88
|
+
}
|
|
89
|
+
_addListener(type, listener, prepend) {
|
|
90
|
+
checkListener(listener);
|
|
91
|
+
let events = this._events;
|
|
92
|
+
let existing;
|
|
93
|
+
if (events === undefined) {
|
|
94
|
+
events = this._events = Object.create(null);
|
|
95
|
+
this._eventsCount = 0;
|
|
96
|
+
} else {
|
|
97
|
+
// To avoid recursion in the case that type === "newListener"! Before
|
|
98
|
+
// adding it to the listeners, first emit "newListener".
|
|
99
|
+
if (events.newListener !== undefined) {
|
|
100
|
+
this.emit('newListener', type, unwrapListener(listener));
|
|
101
|
+
|
|
102
|
+
// Re-assign `events` because a newListener handler could have caused the
|
|
103
|
+
// this._events to be assigned to a new object
|
|
104
|
+
events = this._events;
|
|
105
|
+
}
|
|
106
|
+
existing = events[type];
|
|
107
|
+
}
|
|
108
|
+
if (existing === undefined) {
|
|
109
|
+
// Optimize the case of one listener. Don't need the extra array object.
|
|
110
|
+
existing = events[type] = listener;
|
|
111
|
+
++this._eventsCount;
|
|
112
|
+
} else {
|
|
113
|
+
if (typeof existing === 'function') {
|
|
114
|
+
// Adding the second element, need to change to array.
|
|
115
|
+
existing = events[type] = prepend ? [listener, existing] : [existing, listener];
|
|
116
|
+
// If we've already got an array, just append.
|
|
117
|
+
} else if (prepend) {
|
|
118
|
+
existing.unshift(listener);
|
|
119
|
+
} else {
|
|
120
|
+
existing.push(listener);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// Check for listener leak
|
|
124
|
+
const m = this.getMaxListeners();
|
|
125
|
+
if (m > 0 && existing.length > m && !existing.warned) {
|
|
126
|
+
existing.warned = true;
|
|
127
|
+
// No error code for this since it is a Warning
|
|
128
|
+
const w = new Error('Possible EventEmitter memory leak detected. ' + existing.length + ' ' + String(type) + ' listeners ' + 'added. Use emitter.setMaxListeners() to ' + 'increase limit');
|
|
129
|
+
w.name = 'MaxListenersExceededWarning';
|
|
130
|
+
w.emitter = this;
|
|
131
|
+
w.type = type;
|
|
132
|
+
w.count = existing.length;
|
|
133
|
+
if (!(0, _utils.isUnderTest)()) {
|
|
134
|
+
// eslint-disable-next-line no-console
|
|
135
|
+
console.warn(w);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return this;
|
|
140
|
+
}
|
|
141
|
+
prependListener(type, listener) {
|
|
142
|
+
return this._addListener(type, listener, true);
|
|
143
|
+
}
|
|
144
|
+
once(type, listener) {
|
|
145
|
+
checkListener(listener);
|
|
146
|
+
this.on(type, new OnceWrapper(this, type, listener).wrapperFunction);
|
|
147
|
+
return this;
|
|
148
|
+
}
|
|
149
|
+
prependOnceListener(type, listener) {
|
|
150
|
+
checkListener(listener);
|
|
151
|
+
this.prependListener(type, new OnceWrapper(this, type, listener).wrapperFunction);
|
|
152
|
+
return this;
|
|
153
|
+
}
|
|
154
|
+
removeListener(type, listener) {
|
|
155
|
+
checkListener(listener);
|
|
156
|
+
const events = this._events;
|
|
157
|
+
if (events === undefined) return this;
|
|
158
|
+
const list = events[type];
|
|
159
|
+
if (list === undefined) return this;
|
|
160
|
+
if (list === listener || list.listener === listener) {
|
|
161
|
+
if (--this._eventsCount === 0) {
|
|
162
|
+
this._events = Object.create(null);
|
|
163
|
+
} else {
|
|
164
|
+
var _listener;
|
|
165
|
+
delete events[type];
|
|
166
|
+
if (events.removeListener) this.emit('removeListener', type, (_listener = list.listener) !== null && _listener !== void 0 ? _listener : listener);
|
|
167
|
+
}
|
|
168
|
+
} else if (typeof list !== 'function') {
|
|
169
|
+
let position = -1;
|
|
170
|
+
let originalListener;
|
|
171
|
+
for (let i = list.length - 1; i >= 0; i--) {
|
|
172
|
+
if (list[i] === listener || wrappedListener(list[i]) === listener) {
|
|
173
|
+
originalListener = wrappedListener(list[i]);
|
|
174
|
+
position = i;
|
|
175
|
+
break;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
if (position < 0) return this;
|
|
179
|
+
if (position === 0) list.shift();else list.splice(position, 1);
|
|
180
|
+
if (list.length === 1) events[type] = list[0];
|
|
181
|
+
if (events.removeListener !== undefined) this.emit('removeListener', type, originalListener || listener);
|
|
182
|
+
}
|
|
183
|
+
return this;
|
|
184
|
+
}
|
|
185
|
+
off(type, listener) {
|
|
186
|
+
return this.removeListener(type, listener);
|
|
187
|
+
}
|
|
188
|
+
removeAllListeners(type, options) {
|
|
189
|
+
this._removeAllListeners(type);
|
|
190
|
+
if (!options) return this;
|
|
191
|
+
if (options.behavior === 'wait') {
|
|
192
|
+
const errors = [];
|
|
193
|
+
this._rejectionHandler = error => errors.push(error);
|
|
194
|
+
// eslint-disable-next-line internal-playwright/await-promise-in-class-returns
|
|
195
|
+
return this._waitFor(type).then(() => {
|
|
196
|
+
if (errors.length) throw errors[0];
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
if (options.behavior === 'ignoreErrors') this._rejectionHandler = () => {};
|
|
200
|
+
|
|
201
|
+
// eslint-disable-next-line internal-playwright/await-promise-in-class-returns
|
|
202
|
+
return Promise.resolve();
|
|
203
|
+
}
|
|
204
|
+
_removeAllListeners(type) {
|
|
205
|
+
const events = this._events;
|
|
206
|
+
if (!events) return;
|
|
207
|
+
|
|
208
|
+
// not listening for removeListener, no need to emit
|
|
209
|
+
if (!events.removeListener) {
|
|
210
|
+
if (type === undefined) {
|
|
211
|
+
this._events = Object.create(null);
|
|
212
|
+
this._eventsCount = 0;
|
|
213
|
+
} else if (events[type] !== undefined) {
|
|
214
|
+
if (--this._eventsCount === 0) this._events = Object.create(null);else delete events[type];
|
|
215
|
+
}
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
// emit removeListener for all listeners on all events
|
|
220
|
+
if (type === undefined) {
|
|
221
|
+
const keys = Object.keys(events);
|
|
222
|
+
let key;
|
|
223
|
+
for (let i = 0; i < keys.length; ++i) {
|
|
224
|
+
key = keys[i];
|
|
225
|
+
if (key === 'removeListener') continue;
|
|
226
|
+
this._removeAllListeners(key);
|
|
227
|
+
}
|
|
228
|
+
this._removeAllListeners('removeListener');
|
|
229
|
+
this._events = Object.create(null);
|
|
230
|
+
this._eventsCount = 0;
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
const listeners = events[type];
|
|
234
|
+
if (typeof listeners === 'function') {
|
|
235
|
+
this.removeListener(type, listeners);
|
|
236
|
+
} else if (listeners !== undefined) {
|
|
237
|
+
// LIFO order
|
|
238
|
+
for (let i = listeners.length - 1; i >= 0; i--) this.removeListener(type, listeners[i]);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
listeners(type) {
|
|
242
|
+
return this._listeners(this, type, true);
|
|
243
|
+
}
|
|
244
|
+
rawListeners(type) {
|
|
245
|
+
return this._listeners(this, type, false);
|
|
246
|
+
}
|
|
247
|
+
listenerCount(type) {
|
|
248
|
+
const events = this._events;
|
|
249
|
+
if (events !== undefined) {
|
|
250
|
+
const listener = events[type];
|
|
251
|
+
if (typeof listener === 'function') return 1;
|
|
252
|
+
if (listener !== undefined) return listener.length;
|
|
253
|
+
}
|
|
254
|
+
return 0;
|
|
255
|
+
}
|
|
256
|
+
eventNames() {
|
|
257
|
+
return this._eventsCount > 0 && this._events ? Reflect.ownKeys(this._events) : [];
|
|
258
|
+
}
|
|
259
|
+
async _waitFor(type) {
|
|
260
|
+
let promises = [];
|
|
261
|
+
if (type) {
|
|
262
|
+
promises = [...(this._pendingHandlers.get(type) || [])];
|
|
263
|
+
} else {
|
|
264
|
+
promises = [];
|
|
265
|
+
for (const [, pending] of this._pendingHandlers) promises.push(...pending);
|
|
266
|
+
}
|
|
267
|
+
await Promise.all(promises);
|
|
268
|
+
}
|
|
269
|
+
_listeners(target, type, unwrap) {
|
|
270
|
+
const events = target._events;
|
|
271
|
+
if (events === undefined) return [];
|
|
272
|
+
const listener = events[type];
|
|
273
|
+
if (listener === undefined) return [];
|
|
274
|
+
if (typeof listener === 'function') return unwrap ? [unwrapListener(listener)] : [listener];
|
|
275
|
+
return unwrap ? unwrapListeners(listener) : listener.slice();
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
exports.EventEmitter = EventEmitter;
|
|
279
|
+
function checkListener(listener) {
|
|
280
|
+
if (typeof listener !== 'function') throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener);
|
|
281
|
+
}
|
|
282
|
+
class OnceWrapper {
|
|
283
|
+
constructor(eventEmitter, eventType, listener) {
|
|
284
|
+
this._fired = false;
|
|
285
|
+
this.wrapperFunction = void 0;
|
|
286
|
+
this._listener = void 0;
|
|
287
|
+
this._eventEmitter = void 0;
|
|
288
|
+
this._eventType = void 0;
|
|
289
|
+
this._eventEmitter = eventEmitter;
|
|
290
|
+
this._eventType = eventType;
|
|
291
|
+
this._listener = listener;
|
|
292
|
+
this.wrapperFunction = this._handle.bind(this);
|
|
293
|
+
this.wrapperFunction.listener = listener;
|
|
294
|
+
}
|
|
295
|
+
_handle(...args) {
|
|
296
|
+
if (this._fired) return;
|
|
297
|
+
this._fired = true;
|
|
298
|
+
this._eventEmitter.removeListener(this._eventType, this.wrapperFunction);
|
|
299
|
+
return this._listener.apply(this._eventEmitter, args);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
function unwrapListener(l) {
|
|
303
|
+
var _wrappedListener;
|
|
304
|
+
return (_wrappedListener = wrappedListener(l)) !== null && _wrappedListener !== void 0 ? _wrappedListener : l;
|
|
305
|
+
}
|
|
306
|
+
function unwrapListeners(arr) {
|
|
307
|
+
return arr.map(l => {
|
|
308
|
+
var _wrappedListener2;
|
|
309
|
+
return (_wrappedListener2 = wrappedListener(l)) !== null && _wrappedListener2 !== void 0 ? _wrappedListener2 : l;
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
function wrappedListener(l) {
|
|
313
|
+
return l.listener;
|
|
314
|
+
}
|
package/lib/client/fetch.js
CHANGED
|
@@ -13,6 +13,7 @@ var _channelOwner = require("./channelOwner");
|
|
|
13
13
|
var _network = require("./network");
|
|
14
14
|
var _tracing = require("./tracing");
|
|
15
15
|
var _errors = require("./errors");
|
|
16
|
+
var _browserContext = require("./browserContext");
|
|
16
17
|
var _fetch = require("../checkly/fetch");
|
|
17
18
|
let _Symbol$asyncDispose, _Symbol$asyncDispose2, _util$inspect$custom;
|
|
18
19
|
/**
|
|
@@ -54,12 +55,13 @@ class APIRequest {
|
|
|
54
55
|
...options,
|
|
55
56
|
extraHTTPHeaders: options.extraHTTPHeaders ? (0, _utils.headersObjectToArray)(options.extraHTTPHeaders) : undefined,
|
|
56
57
|
storageState,
|
|
57
|
-
tracesDir
|
|
58
|
+
tracesDir,
|
|
59
|
+
clientCertificates: await (0, _browserContext.toClientCertificatesProtocol)(options.clientCertificates)
|
|
58
60
|
})).request);
|
|
59
61
|
this._contexts.add(context);
|
|
60
62
|
context._request = this;
|
|
61
63
|
context._tracing._tracesDir = tracesDir;
|
|
62
|
-
await context._instrumentation.
|
|
64
|
+
await context._instrumentation.runAfterCreateRequestContext(context);
|
|
63
65
|
return context;
|
|
64
66
|
}
|
|
65
67
|
}
|
|
@@ -73,15 +75,23 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
|
|
|
73
75
|
super(parent, type, guid, initializer);
|
|
74
76
|
this._request = void 0;
|
|
75
77
|
this._tracing = void 0;
|
|
78
|
+
this._closeReason = void 0;
|
|
76
79
|
this._tracing = _tracing.Tracing.from(initializer.tracing);
|
|
77
80
|
}
|
|
78
81
|
async [_Symbol$asyncDispose]() {
|
|
79
82
|
await this.dispose();
|
|
80
83
|
}
|
|
81
|
-
async dispose() {
|
|
84
|
+
async dispose(options = {}) {
|
|
82
85
|
var _this$_request;
|
|
83
|
-
|
|
84
|
-
await this.
|
|
86
|
+
this._closeReason = options.reason;
|
|
87
|
+
await this._instrumentation.runBeforeCloseRequestContext(this);
|
|
88
|
+
try {
|
|
89
|
+
await this._channel.dispose(options);
|
|
90
|
+
} catch (e) {
|
|
91
|
+
if ((0, _errors.isTargetClosedError)(e)) return;
|
|
92
|
+
throw e;
|
|
93
|
+
}
|
|
94
|
+
this._tracing._resetStackCounter();
|
|
85
95
|
(_this$_request = this._request) === null || _this$_request === void 0 || _this$_request._contexts.delete(this);
|
|
86
96
|
}
|
|
87
97
|
async delete(url, options) {
|
|
@@ -138,13 +148,14 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
|
|
|
138
148
|
this.writeApiCallToDisk(options);
|
|
139
149
|
return await this._wrapApiCall(async () => {
|
|
140
150
|
var _options$request, _options$request2, _options$request3;
|
|
151
|
+
if (this._closeReason) throw new _errors.TargetClosedError(this._closeReason);
|
|
141
152
|
(0, _utils.assert)(options.request || typeof options.url === 'string', 'First argument must be either URL string or Request');
|
|
142
153
|
(0, _utils.assert)((options.data === undefined ? 0 : 1) + (options.form === undefined ? 0 : 1) + (options.multipart === undefined ? 0 : 1) <= 1, `Only one of 'data', 'form' or 'multipart' can be specified`);
|
|
143
|
-
(0, _utils.assert)(options.maxRedirects === undefined || options.maxRedirects >= 0, `'maxRedirects'
|
|
154
|
+
(0, _utils.assert)(options.maxRedirects === undefined || options.maxRedirects >= 0, `'maxRedirects' must be greater than or equal to '0'`);
|
|
155
|
+
(0, _utils.assert)(options.maxRetries === undefined || options.maxRetries >= 0, `'maxRetries' must be greater than or equal to '0'`);
|
|
144
156
|
const url = options.url !== undefined ? options.url : options.request.url();
|
|
145
|
-
const params =
|
|
157
|
+
const params = mapParamsToArray(options.params);
|
|
146
158
|
const method = options.method || ((_options$request = options.request) === null || _options$request === void 0 ? void 0 : _options$request.method());
|
|
147
|
-
const maxRedirects = options.maxRedirects;
|
|
148
159
|
// Cannot call allHeaders() here as the request may be paused inside route handler.
|
|
149
160
|
const headersObj = options.headers || ((_options$request2 = options.request) === null || _options$request2 === void 0 ? void 0 : _options$request2.headers());
|
|
150
161
|
const headers = headersObj ? (0, _utils.headersObjectToArray)(headersObj) : undefined;
|
|
@@ -166,26 +177,29 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
|
|
|
166
177
|
formData = objectToArray(options.form);
|
|
167
178
|
} else if (options.multipart) {
|
|
168
179
|
multipartData = [];
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
}
|
|
180
|
+
if (globalThis.FormData && options.multipart instanceof FormData) {
|
|
181
|
+
const form = options.multipart;
|
|
182
|
+
for (const [name, value] of form.entries()) {
|
|
183
|
+
if ((0, _utils.isString)(value)) {
|
|
184
|
+
multipartData.push({
|
|
185
|
+
name,
|
|
186
|
+
value
|
|
187
|
+
});
|
|
188
|
+
} else {
|
|
189
|
+
const file = {
|
|
190
|
+
name: value.name,
|
|
191
|
+
mimeType: value.type,
|
|
192
|
+
buffer: Buffer.from(await value.arrayBuffer())
|
|
193
|
+
};
|
|
194
|
+
multipartData.push({
|
|
195
|
+
name,
|
|
196
|
+
file
|
|
197
|
+
});
|
|
198
|
+
}
|
|
188
199
|
}
|
|
200
|
+
} else {
|
|
201
|
+
// Convert file-like values to ServerFilePayload structs.
|
|
202
|
+
for (const [name, value] of Object.entries(options.multipart)) multipartData.push(await toFormField(name, value));
|
|
189
203
|
}
|
|
190
204
|
}
|
|
191
205
|
if (postDataBuffer === undefined && jsonData === undefined && formData === undefined && multipartData === undefined) postDataBuffer = ((_options$request3 = options.request) === null || _options$request3 === void 0 ? void 0 : _options$request3.postDataBuffer()) || undefined;
|
|
@@ -204,7 +218,8 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
|
|
|
204
218
|
timeout: options.timeout,
|
|
205
219
|
failOnStatusCode: options.failOnStatusCode,
|
|
206
220
|
ignoreHTTPSErrors: options.ignoreHTTPSErrors,
|
|
207
|
-
maxRedirects: maxRedirects,
|
|
221
|
+
maxRedirects: options.maxRedirects,
|
|
222
|
+
maxRetries: options.maxRetries,
|
|
208
223
|
tokenizedURL: options.tokenizedURL,
|
|
209
224
|
...fixtures,
|
|
210
225
|
...(0, _fetch.getClientCertificates)(options)
|
|
@@ -222,6 +237,26 @@ class APIRequestContext extends _channelOwner.ChannelOwner {
|
|
|
222
237
|
}
|
|
223
238
|
}
|
|
224
239
|
exports.APIRequestContext = APIRequestContext;
|
|
240
|
+
async function toFormField(name, value) {
|
|
241
|
+
if (isFilePayload(value)) {
|
|
242
|
+
const payload = value;
|
|
243
|
+
if (!Buffer.isBuffer(payload.buffer)) throw new Error(`Unexpected buffer type of 'data.${name}'`);
|
|
244
|
+
return {
|
|
245
|
+
name,
|
|
246
|
+
file: filePayloadToJson(payload)
|
|
247
|
+
};
|
|
248
|
+
} else if (value instanceof _fs.default.ReadStream) {
|
|
249
|
+
return {
|
|
250
|
+
name,
|
|
251
|
+
file: await readStreamToJson(value)
|
|
252
|
+
};
|
|
253
|
+
} else {
|
|
254
|
+
return {
|
|
255
|
+
name,
|
|
256
|
+
value: String(value)
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
}
|
|
225
260
|
function isJsonParsable(value) {
|
|
226
261
|
if (typeof value !== 'string') return false;
|
|
227
262
|
try {
|
|
@@ -353,6 +388,24 @@ function objectToArray(map) {
|
|
|
353
388
|
});
|
|
354
389
|
return result;
|
|
355
390
|
}
|
|
391
|
+
function queryStringToArray(queryString) {
|
|
392
|
+
const searchParams = new URLSearchParams(queryString);
|
|
393
|
+
return searchParamsToArray(searchParams);
|
|
394
|
+
}
|
|
395
|
+
function searchParamsToArray(searchParams) {
|
|
396
|
+
if (searchParams.size === 0) return undefined;
|
|
397
|
+
const result = [];
|
|
398
|
+
for (const [name, value] of searchParams.entries()) result.push({
|
|
399
|
+
name,
|
|
400
|
+
value
|
|
401
|
+
});
|
|
402
|
+
return result;
|
|
403
|
+
}
|
|
404
|
+
function mapParamsToArray(params) {
|
|
405
|
+
if (params instanceof URLSearchParams) return searchParamsToArray(params);
|
|
406
|
+
if (typeof params === 'string') return queryStringToArray(params);
|
|
407
|
+
return objectToArray(params);
|
|
408
|
+
}
|
|
356
409
|
function isFilePayload(value) {
|
|
357
410
|
return typeof value === 'object' && value['name'] && value['mimeType'] && value['buffer'];
|
|
358
411
|
}
|
package/lib/client/frame.js
CHANGED
|
@@ -17,7 +17,6 @@ var _events = require("events");
|
|
|
17
17
|
var _waiter = require("./waiter");
|
|
18
18
|
var _events2 = require("./events");
|
|
19
19
|
var _types = require("./types");
|
|
20
|
-
var _network2 = require("../utils/network");
|
|
21
20
|
var _clientHelper = require("./clientHelper");
|
|
22
21
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
23
22
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
@@ -111,7 +110,7 @@ class Frame extends _channelOwner.ChannelOwner {
|
|
|
111
110
|
// Any failed navigation results in a rejection.
|
|
112
111
|
if (event.error) return true;
|
|
113
112
|
waiter.log(` navigated to "${event.url}"`);
|
|
114
|
-
return (0,
|
|
113
|
+
return (0, _utils.urlMatches)((_this$_page = this._page) === null || _this$_page === void 0 ? void 0 : _this$_page.context()._options.baseURL, event.url, options.url);
|
|
115
114
|
});
|
|
116
115
|
if (navigatedEvent.error) {
|
|
117
116
|
const e = new Error(navigatedEvent.error);
|
|
@@ -147,7 +146,7 @@ class Frame extends _channelOwner.ChannelOwner {
|
|
|
147
146
|
}
|
|
148
147
|
async waitForURL(url, options = {}) {
|
|
149
148
|
var _this$_page2;
|
|
150
|
-
if ((0,
|
|
149
|
+
if ((0, _utils.urlMatches)((_this$_page2 = this._page) === null || _this$_page2 === void 0 ? void 0 : _this$_page2.context()._options.baseURL, this.url(), url)) return await this.waitForLoadState(options.waitUntil, options);
|
|
151
150
|
await this.waitForNavigation({
|
|
152
151
|
url,
|
|
153
152
|
...options
|
|
@@ -179,7 +178,6 @@ class Frame extends _channelOwner.ChannelOwner {
|
|
|
179
178
|
const result = await this._channel.evaluateExpression({
|
|
180
179
|
expression: String(pageFunction),
|
|
181
180
|
isFunction: typeof pageFunction === 'function',
|
|
182
|
-
exposeUtilityScript: true,
|
|
183
181
|
arg: (0, _jsHandle.serializeArgument)(arg)
|
|
184
182
|
});
|
|
185
183
|
return (0, _jsHandle.parseResult)(result.value);
|
package/lib/client/jsHandle.js
CHANGED
|
@@ -9,6 +9,7 @@ exports.parseResult = parseResult;
|
|
|
9
9
|
exports.serializeArgument = serializeArgument;
|
|
10
10
|
var _channelOwner = require("./channelOwner");
|
|
11
11
|
var _serializers = require("../protocol/serializers");
|
|
12
|
+
var _errors = require("./errors");
|
|
12
13
|
let _Symbol$asyncDispose;
|
|
13
14
|
/**
|
|
14
15
|
* Copyright (c) Microsoft Corporation.
|
|
@@ -78,7 +79,12 @@ class JSHandle extends _channelOwner.ChannelOwner {
|
|
|
78
79
|
await this.dispose();
|
|
79
80
|
}
|
|
80
81
|
async dispose() {
|
|
81
|
-
|
|
82
|
+
try {
|
|
83
|
+
await this._channel.dispose();
|
|
84
|
+
} catch (e) {
|
|
85
|
+
if ((0, _errors.isTargetClosedError)(e)) return;
|
|
86
|
+
throw e;
|
|
87
|
+
}
|
|
82
88
|
}
|
|
83
89
|
async _objectCount() {
|
|
84
90
|
return await this._wrapApiCall(async () => {
|
package/lib/client/locator.js
CHANGED
|
@@ -71,6 +71,9 @@ class Locator {
|
|
|
71
71
|
}
|
|
72
72
|
});
|
|
73
73
|
}
|
|
74
|
+
_equals(locator) {
|
|
75
|
+
return this._frame === locator._frame && this._selector === locator._selector;
|
|
76
|
+
}
|
|
74
77
|
page() {
|
|
75
78
|
return this._frame.page();
|
|
76
79
|
}
|
|
@@ -174,6 +177,9 @@ class Locator {
|
|
|
174
177
|
async elementHandles() {
|
|
175
178
|
return await this._frame.$$(this._selector);
|
|
176
179
|
}
|
|
180
|
+
contentFrame() {
|
|
181
|
+
return new FrameLocator(this._frame, this._selector);
|
|
182
|
+
}
|
|
177
183
|
first() {
|
|
178
184
|
return new Locator(this._frame, this._selector + ' >> nth=0');
|
|
179
185
|
}
|
|
@@ -409,6 +415,9 @@ class FrameLocator {
|
|
|
409
415
|
getByRole(role, options = {}) {
|
|
410
416
|
return this.locator((0, _locatorUtils.getByRoleSelector)(role, options));
|
|
411
417
|
}
|
|
418
|
+
owner() {
|
|
419
|
+
return new Locator(this._frame, this._frameSelector);
|
|
420
|
+
}
|
|
412
421
|
frameLocator(selector) {
|
|
413
422
|
return new FrameLocator(this._frame, this._frameSelector + ' >> internal:control=enter-frame >> ' + selector);
|
|
414
423
|
}
|
package/lib/client/network.js
CHANGED
|
@@ -15,9 +15,8 @@ var _utils = require("../utils");
|
|
|
15
15
|
var _manualPromise = require("../utils/manualPromise");
|
|
16
16
|
var _events = require("./events");
|
|
17
17
|
var _waiter = require("./waiter");
|
|
18
|
-
var _network = require("../utils/network");
|
|
19
|
-
var _multimap = require("../utils/multimap");
|
|
20
18
|
var _fetch = require("./fetch");
|
|
19
|
+
var _errors = require("./errors");
|
|
21
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
22
21
|
/**
|
|
23
22
|
* Copyright (c) Microsoft Corporation.
|
|
@@ -54,7 +53,6 @@ class Request extends _channelOwner.ChannelOwner {
|
|
|
54
53
|
this._redirectedFrom = Request.fromNullable(initializer.redirectedFrom);
|
|
55
54
|
if (this._redirectedFrom) this._redirectedFrom._redirectedTo = this;
|
|
56
55
|
this._provisionalHeaders = new RawHeaders(initializer.headers);
|
|
57
|
-
this._fallbackOverrides.postDataBuffer = initializer.postData;
|
|
58
56
|
this._timing = {
|
|
59
57
|
startTime: 0,
|
|
60
58
|
domainLookupStart: -1,
|
|
@@ -77,17 +75,17 @@ class Request extends _channelOwner.ChannelOwner {
|
|
|
77
75
|
return this._fallbackOverrides.method || this._initializer.method;
|
|
78
76
|
}
|
|
79
77
|
postData() {
|
|
80
|
-
var
|
|
81
|
-
return ((
|
|
78
|
+
var _ref;
|
|
79
|
+
return ((_ref = this._fallbackOverrides.postDataBuffer || this._initializer.postData) === null || _ref === void 0 ? void 0 : _ref.toString('utf-8')) || null;
|
|
82
80
|
}
|
|
83
81
|
postDataBuffer() {
|
|
84
|
-
return this._fallbackOverrides.postDataBuffer || null;
|
|
82
|
+
return this._fallbackOverrides.postDataBuffer || this._initializer.postData || null;
|
|
85
83
|
}
|
|
86
84
|
postDataJSON() {
|
|
87
85
|
const postData = this.postData();
|
|
88
86
|
if (!postData) return null;
|
|
89
87
|
const contentType = this.headers()['content-type'];
|
|
90
|
-
if (contentType
|
|
88
|
+
if (contentType !== null && contentType !== void 0 && contentType.includes('application/x-www-form-urlencoded')) {
|
|
91
89
|
const entries = {};
|
|
92
90
|
const parsed = new _url.URLSearchParams(postData);
|
|
93
91
|
for (const [k, v] of parsed.entries()) entries[k] = v;
|
|
@@ -520,7 +518,7 @@ class RouteHandler {
|
|
|
520
518
|
return patterns;
|
|
521
519
|
}
|
|
522
520
|
matches(requestURL) {
|
|
523
|
-
return (0,
|
|
521
|
+
return (0, _utils.urlMatches)(this._baseURL, requestURL, this.url);
|
|
524
522
|
}
|
|
525
523
|
async handle(route) {
|
|
526
524
|
const handlerInvocation = {
|
|
@@ -533,6 +531,11 @@ class RouteHandler {
|
|
|
533
531
|
} catch (e) {
|
|
534
532
|
// If the handler was stopped (without waiting for completion), we ignore all exceptions.
|
|
535
533
|
if (this._ignoreException) return false;
|
|
534
|
+
if ((0, _errors.isTargetClosedError)(e)) {
|
|
535
|
+
// We are failing in the handler because the target close closed.
|
|
536
|
+
// Give user a hint!
|
|
537
|
+
(0, _utils.rewriteErrorMessage)(e, `"${e.message}" while running route callback.\nConsider awaiting \`await page.unrouteAll({ behavior: 'ignoreErrors' })\`\nbefore the end of the test to ignore remaining routes in flight.`);
|
|
538
|
+
}
|
|
536
539
|
throw e;
|
|
537
540
|
} finally {
|
|
538
541
|
handlerInvocation.complete.resolve();
|
|
@@ -577,7 +580,7 @@ class RawHeaders {
|
|
|
577
580
|
}
|
|
578
581
|
constructor(headers) {
|
|
579
582
|
this._headersArray = void 0;
|
|
580
|
-
this._headersMap = new
|
|
583
|
+
this._headersMap = new _utils.MultiMap();
|
|
581
584
|
this._headersArray = headers;
|
|
582
585
|
for (const header of headers) this._headersMap.set(header.name.toLowerCase(), header.value);
|
|
583
586
|
}
|