@checkly/playwright-core 1.41.2-beta.0 → 1.41.2-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (124) hide show
  1. package/lib/browserServerImpl.js +1 -1
  2. package/lib/cli/cli.js +61 -0
  3. package/lib/cli/driver.js +3 -11
  4. package/lib/cli/program.js +5 -13
  5. package/lib/client/android.js +1 -1
  6. package/lib/client/artifact.js +2 -2
  7. package/lib/client/browserContext.js +5 -5
  8. package/lib/client/browserType.js +1 -1
  9. package/lib/client/channelOwner.js +3 -3
  10. package/lib/client/clientHelper.js +1 -5
  11. package/lib/client/connection.js +2 -2
  12. package/lib/client/consoleMessage.js +2 -2
  13. package/lib/client/fetch.js +3 -3
  14. package/lib/client/frame.js +3 -4
  15. package/lib/client/harRouter.js +1 -1
  16. package/lib/client/locator.js +2 -2
  17. package/lib/client/page.js +1 -24
  18. package/lib/common/debugLogger.js +90 -0
  19. package/lib/common/socksProxy.js +17 -12
  20. package/lib/generated/consoleApiSource.js +1 -1
  21. package/lib/generated/injectedScriptSource.js +1 -1
  22. package/lib/generated/recorderSource.js +1 -1
  23. package/lib/outofprocess.js +3 -3
  24. package/lib/protocol/validator.js +7 -13
  25. package/lib/remote/playwrightConnection.js +2 -2
  26. package/lib/remote/playwrightServer.js +166 -72
  27. package/lib/server/android/android.js +2 -2
  28. package/lib/server/android/backendAdb.js +2 -2
  29. package/lib/server/browser.js +2 -2
  30. package/lib/server/browserContext.js +9 -8
  31. package/lib/server/browserType.js +5 -5
  32. package/lib/server/chromium/chromium.js +1 -1
  33. package/lib/server/chromium/crBrowser.js +3 -2
  34. package/lib/server/chromium/crConnection.js +2 -2
  35. package/lib/server/chromium/crExecutionContext.js +2 -2
  36. package/lib/server/chromium/crInput.js +2 -2
  37. package/lib/server/chromium/crNetworkManager.js +23 -37
  38. package/lib/server/chromium/crPage.js +7 -48
  39. package/lib/server/chromium/crServiceWorker.js +3 -2
  40. package/lib/server/debugController.js +3 -0
  41. package/lib/server/deviceDescriptorsSource.json +50 -50
  42. package/lib/server/dispatchers/browserContextDispatcher.js +4 -4
  43. package/lib/server/dispatchers/dispatcher.js +10 -10
  44. package/lib/server/dispatchers/localUtilsDispatcher.js +4 -4
  45. package/lib/server/dispatchers/pageDispatcher.js +0 -12
  46. package/lib/server/dispatchers/playwrightDispatcher.js +5 -5
  47. package/lib/server/dispatchers/writableStreamDispatcher.js +2 -2
  48. package/lib/server/dom.js +170 -133
  49. package/lib/server/electron/electron.js +4 -5
  50. package/lib/server/electron/loader.js +2 -4
  51. package/lib/server/fetch.js +4 -4
  52. package/lib/server/firefox/ffBrowser.js +3 -3
  53. package/lib/server/firefox/ffConnection.js +1 -1
  54. package/lib/server/firefox/ffExecutionContext.js +2 -2
  55. package/lib/server/firefox/ffNetworkManager.js +7 -7
  56. package/lib/server/firefox/ffPage.js +5 -3
  57. package/lib/server/firefox/firefox.js +2 -2
  58. package/lib/server/frames.js +23 -31
  59. package/lib/server/har/harTracer.js +6 -6
  60. package/lib/server/helper.js +1 -1
  61. package/lib/server/input.js +2 -2
  62. package/lib/server/isomorphic/utilityScriptSerializers.js +1 -0
  63. package/lib/server/javascript.js +2 -2
  64. package/lib/server/network.js +23 -5
  65. package/lib/server/page.js +3 -44
  66. package/lib/server/pipeTransport.js +1 -1
  67. package/lib/server/playwright.js +1 -1
  68. package/lib/server/progress.js +14 -5
  69. package/lib/server/recorder/csharp.js +1 -1
  70. package/lib/server/recorder/recorderUtils.js +2 -2
  71. package/lib/server/recorder.js +14 -14
  72. package/lib/server/registry/browserFetcher.js +2 -1
  73. package/lib/server/registry/dependencies.js +6 -7
  74. package/lib/server/registry/index.js +33 -50
  75. package/lib/server/registry/nativeDeps.js +94 -0
  76. package/lib/server/registry/oopDownloadBrowserMain.js +2 -2
  77. package/lib/server/screenshotter.js +1 -0
  78. package/lib/server/socksInterceptor.js +2 -2
  79. package/lib/server/trace/recorder/snapshotter.js +2 -2
  80. package/lib/server/trace/recorder/tracing.js +9 -7
  81. package/lib/server/trace/test/inMemorySnapshotter.js +1 -1
  82. package/lib/server/trace/viewer/traceViewer.js +2 -2
  83. package/lib/server/transport.js +13 -15
  84. package/lib/server/webkit/wkBrowser.js +3 -3
  85. package/lib/server/webkit/wkConnection.js +1 -1
  86. package/lib/server/webkit/wkExecutionContext.js +2 -2
  87. package/lib/server/webkit/wkInput.js +2 -2
  88. package/lib/server/webkit/wkInterceptableRequest.js +2 -2
  89. package/lib/server/webkit/wkPage.js +12 -10
  90. package/lib/utils/fileUtils.js +0 -4
  91. package/lib/utils/happy-eyeballs.js +4 -5
  92. package/lib/utils/hostPlatform.js +1 -1
  93. package/lib/utils/index.js +0 -11
  94. package/lib/utils/isomorphic/cssParser.js +2 -2
  95. package/lib/utils/isomorphic/locatorParser.js +4 -6
  96. package/lib/utils/isomorphic/selectorParser.js +1 -0
  97. package/lib/utils/network.js +0 -33
  98. package/lib/utils/processLauncher.js +2 -9
  99. package/lib/utils/profiler.js +2 -2
  100. package/lib/utils/zipFile.js +1 -1
  101. package/lib/vite/htmlReport/index.html +13 -12
  102. package/lib/vite/recorder/assets/codeMirrorModule-2a26f817.js +24 -0
  103. package/lib/vite/recorder/assets/codeMirrorModule-5d0f417c.css +1 -0
  104. package/lib/vite/recorder/assets/{index-ljsTwXtJ.css → index-64ce22d5.css} +1 -1
  105. package/lib/vite/recorder/assets/index-bbf80321.js +41 -0
  106. package/lib/vite/recorder/index.html +3 -2
  107. package/lib/vite/{recorder/assets/codeMirrorModule-I9ks4y7D.js → traceViewer/assets/codeMirrorModule-56536a77.js} +13 -13
  108. package/lib/vite/traceViewer/assets/wsPort-722747dc.js +64 -0
  109. package/lib/vite/traceViewer/assets/xtermModule-443332e6.js +9 -0
  110. package/lib/vite/traceViewer/codeMirrorModule.5d0f417c.css +1 -0
  111. package/lib/vite/traceViewer/codicon.79f233d0.ttf +0 -0
  112. package/lib/vite/traceViewer/index.1a1fe659.css +1 -0
  113. package/lib/vite/traceViewer/index.d05939c9.js +2 -0
  114. package/lib/vite/traceViewer/index.html +5 -4
  115. package/lib/vite/traceViewer/sw.bundle.js +1 -1
  116. package/lib/vite/traceViewer/uiMode.8b41a49d.css +1 -0
  117. package/lib/vite/traceViewer/uiMode.8e0454c4.js +4 -0
  118. package/lib/vite/traceViewer/uiMode.html +5 -4
  119. package/lib/vite/traceViewer/wsPort.9c9a6767.css +1 -0
  120. package/lib/vite/traceViewer/xtermModule.6428296b.css +32 -0
  121. package/package.json +1 -1
  122. package/lib/vite/recorder/assets/codeMirrorModule-Hs9-1ZG4.css +0 -1
  123. package/lib/vite/recorder/assets/index-yg8ypzl6.js +0 -47
  124. /package/lib/vite/recorder/assets/{codicon-zGuYmc9o.ttf → codicon-79f233d0.ttf} +0 -0
@@ -8,9 +8,8 @@ var _helper = require("../helper");
8
8
  var _eventsHelper = require("../../utils/eventsHelper");
9
9
  var network = _interopRequireWildcard(require("../network"));
10
10
  var _utils = require("../../utils");
11
- var _protocolError = require("../protocolError");
12
- 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); }
13
- 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; }
11
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
14
13
  /**
15
14
  * Copyright 2017 Google Inc. All rights reserved.
16
15
  * Modifications copyright (c) Microsoft Corporation.
@@ -179,7 +178,7 @@ class CRNetworkManager {
179
178
  } else {
180
179
  var _existingRequest$_rou;
181
180
  const existingRequest = this._requestIdToRequest.get(requestId);
182
- const alreadyContinuedParams = existingRequest === null || existingRequest === void 0 || (_existingRequest$_rou = existingRequest._route) === null || _existingRequest$_rou === void 0 ? void 0 : _existingRequest$_rou._alreadyContinuedParams;
181
+ const alreadyContinuedParams = existingRequest === null || existingRequest === void 0 ? void 0 : (_existingRequest$_rou = existingRequest._route) === null || _existingRequest$_rou === void 0 ? void 0 : _existingRequest$_rou._alreadyContinuedParams;
183
182
  if (alreadyContinuedParams && !event.redirectedRequestId) {
184
183
  // Sometimes Chromium network stack restarts the request internally.
185
184
  // For example, when no-cors request hits a "less public address space", it should be resent with cors.
@@ -267,9 +266,9 @@ class CRNetworkManager {
267
266
  if (requestPausedEvent) {
268
267
  // We do not support intercepting redirects.
269
268
  if (redirectedFrom || !this._userRequestInterceptionEnabled && this._protocolRequestInterceptionEnabled) {
270
- var _redirectedFrom;
269
+ var _redirectedFrom, _redirectedFrom$_orig, _redirectedFrom$_orig2;
271
270
  let headers = undefined;
272
- const previousHeaderOverrides = (_redirectedFrom = redirectedFrom) === null || _redirectedFrom === void 0 || (_redirectedFrom = _redirectedFrom._originalRequestRoute) === null || _redirectedFrom === void 0 || (_redirectedFrom = _redirectedFrom._alreadyContinuedParams) === null || _redirectedFrom === void 0 ? void 0 : _redirectedFrom.headers;
271
+ const previousHeaderOverrides = (_redirectedFrom = redirectedFrom) === null || _redirectedFrom === void 0 ? void 0 : (_redirectedFrom$_orig = _redirectedFrom._originalRequestRoute) === null || _redirectedFrom$_orig === void 0 ? void 0 : (_redirectedFrom$_orig2 = _redirectedFrom$_orig._alreadyContinuedParams) === null || _redirectedFrom$_orig2 === void 0 ? void 0 : _redirectedFrom$_orig2.headers;
273
272
  // Chromium does not preserve header overrides between redirects, so we have to do it ourselves.
274
273
  if (previousHeaderOverrides) headers = network.mergeHeaders([(0, _utils.headersObjectToArray)(requestPausedEvent.request.headers, '\n'), previousHeaderOverrides]);
275
274
  this._session._sendMayFail('Fetch.continueRequest', {
@@ -372,11 +371,11 @@ class CRNetworkManager {
372
371
  response._serverAddrFinished();
373
372
  }
374
373
  response._securityDetailsFinished({
375
- protocol: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu = responsePayload.securityDetails) === null || _responsePayload$secu === void 0 ? void 0 : _responsePayload$secu.protocol,
376
- subjectName: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu2 = responsePayload.securityDetails) === null || _responsePayload$secu2 === void 0 ? void 0 : _responsePayload$secu2.subjectName,
377
- issuer: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu3 = responsePayload.securityDetails) === null || _responsePayload$secu3 === void 0 ? void 0 : _responsePayload$secu3.issuer,
378
- validFrom: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu4 = responsePayload.securityDetails) === null || _responsePayload$secu4 === void 0 ? void 0 : _responsePayload$secu4.validFrom,
379
- validTo: responsePayload === null || responsePayload === void 0 || (_responsePayload$secu5 = responsePayload.securityDetails) === null || _responsePayload$secu5 === void 0 ? void 0 : _responsePayload$secu5.validTo
374
+ protocol: responsePayload === null || responsePayload === void 0 ? void 0 : (_responsePayload$secu = responsePayload.securityDetails) === null || _responsePayload$secu === void 0 ? void 0 : _responsePayload$secu.protocol,
375
+ subjectName: responsePayload === null || responsePayload === void 0 ? void 0 : (_responsePayload$secu2 = responsePayload.securityDetails) === null || _responsePayload$secu2 === void 0 ? void 0 : _responsePayload$secu2.subjectName,
376
+ issuer: responsePayload === null || responsePayload === void 0 ? void 0 : (_responsePayload$secu3 = responsePayload.securityDetails) === null || _responsePayload$secu3 === void 0 ? void 0 : _responsePayload$secu3.issuer,
377
+ validFrom: responsePayload === null || responsePayload === void 0 ? void 0 : (_responsePayload$secu4 = responsePayload.securityDetails) === null || _responsePayload$secu4 === void 0 ? void 0 : _responsePayload$secu4.validFrom,
378
+ validTo: responsePayload === null || responsePayload === void 0 ? void 0 : (_responsePayload$secu5 = responsePayload.securityDetails) === null || _responsePayload$secu5 === void 0 ? void 0 : _responsePayload$secu5.validTo
380
379
  });
381
380
  this._responseExtraInfoTracker.processResponse(request._requestId, response, hasExtraInfo);
382
381
  return response;
@@ -544,44 +543,30 @@ class RouteImpl {
544
543
  method: overrides.method,
545
544
  postData: overrides.postData ? overrides.postData.toString('base64') : undefined
546
545
  };
547
- await catchDisallowedErrors(async () => {
548
- await this._session.send('Fetch.continueRequest', this._alreadyContinuedParams);
549
- });
546
+ await this._session.send('Fetch.continueRequest', this._alreadyContinuedParams);
550
547
  }
551
548
  async fulfill(response) {
552
549
  const body = response.isBase64 ? response.body : Buffer.from(response.body).toString('base64');
553
550
  const responseHeaders = splitSetCookieHeader(response.headers);
554
- await catchDisallowedErrors(async () => {
555
- await this._session.send('Fetch.fulfillRequest', {
556
- requestId: this._interceptionId,
557
- responseCode: response.status,
558
- responsePhrase: network.STATUS_TEXTS[String(response.status)],
559
- responseHeaders,
560
- body
561
- });
551
+ await this._session.send('Fetch.fulfillRequest', {
552
+ requestId: this._interceptionId,
553
+ responseCode: response.status,
554
+ responsePhrase: network.STATUS_TEXTS[String(response.status)],
555
+ responseHeaders,
556
+ body
562
557
  });
563
558
  }
564
559
  async abort(errorCode = 'failed') {
565
560
  const errorReason = errorReasons[errorCode];
566
561
  (0, _utils.assert)(errorReason, 'Unknown error code: ' + errorCode);
567
- await catchDisallowedErrors(async () => {
568
- await this._session.send('Fetch.failRequest', {
569
- requestId: this._interceptionId,
570
- errorReason
571
- });
562
+ // In certain cases, protocol will return error if the request was already canceled
563
+ // or the page was closed. We should tolerate these errors.
564
+ await this._session._sendMayFail('Fetch.failRequest', {
565
+ requestId: this._interceptionId,
566
+ errorReason
572
567
  });
573
568
  }
574
569
  }
575
-
576
- // In certain cases, protocol will return error if the request was already canceled
577
- // or the page was closed. We should tolerate these errors but propagate other.
578
- async function catchDisallowedErrors(callback) {
579
- try {
580
- return await callback();
581
- } catch (e) {
582
- if ((0, _protocolError.isProtocolError)(e) && e.message.includes('Invalid http status code or phrase')) throw e;
583
- }
584
- }
585
570
  function splitSetCookieHeader(headers) {
586
571
  const index = headers.findIndex(({
587
572
  name
@@ -717,6 +702,7 @@ class ResponseExtraInfoTracker {
717
702
 
718
703
  // We are not done yet.
719
704
  }
705
+
720
706
  _stopTracking(requestId) {
721
707
  this._requests.delete(requestId);
722
708
  }
@@ -29,8 +29,8 @@ var _videoRecorder = require("./videoRecorder");
29
29
  var _browserContext = require("../browserContext");
30
30
  var _errors = require("../errors");
31
31
  var _protocolError = require("../protocolError");
32
- 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); }
33
- 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; }
32
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
33
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
34
34
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
35
  /**
36
36
  * Copyright 2017 Google Inc. All rights reserved.
@@ -836,7 +836,7 @@ class FrameSession {
836
836
  // Keep the video artifact in the map until encoding is fully finished, if the context
837
837
  // starts closing before the video is fully written to disk it will wait for it.
838
838
  const video = this._crPage._browserContext._browser._takeVideo(screencastId);
839
- video === null || video === void 0 || video.reportFinished();
839
+ video === null || video === void 0 ? void 0 : video.reportFinished();
840
840
  }
841
841
  async _startScreencast(client, options = {}) {
842
842
  this._screencastClients.add(client);
@@ -852,6 +852,7 @@ class FrameSession {
852
852
  headers: (0, _utils.headersArrayToObject)(headers, false /* lowerCase */)
853
853
  });
854
854
  }
855
+
855
856
  async _updateGeolocation(initial) {
856
857
  const geolocation = this._crPage._browserContext._options.geolocation;
857
858
  if (!initial || geolocation) await this._client.send('Emulation.setGeolocationOverride', geolocation || {});
@@ -970,8 +971,7 @@ class FrameSession {
970
971
  const options = this._crPage._browserContext._options;
971
972
  await this._client.send('Emulation.setUserAgentOverride', {
972
973
  userAgent: options.userAgent || '',
973
- acceptLanguage: options.locale,
974
- userAgentMetadata: calculateUserAgentMetadata(options)
974
+ acceptLanguage: options.locale
975
975
  });
976
976
  }
977
977
  async _setDefaultFontFamilies(session) {
@@ -988,6 +988,7 @@ class FrameSession {
988
988
  enabled
989
989
  }).catch(() => {}); // target can be closed.
990
990
  }
991
+
991
992
  async _evaluateOnNewDocument(source, world) {
992
993
  const worldName = world === 'utility' ? UTILITY_WORLD_NAME : undefined;
993
994
  const {
@@ -1128,46 +1129,4 @@ async function emulateTimezone(session, timezoneId) {
1128
1129
  throw exception;
1129
1130
  }
1130
1131
  }
1131
- const contextDelegateSymbol = Symbol('delegate');
1132
-
1133
- // Chromium reference: https://source.chromium.org/chromium/chromium/src/+/main:components/embedder_support/user_agent_utils.cc;l=434;drc=70a6711e08e9f9e0d8e4c48e9ba5cab62eb010c2
1134
- function calculateUserAgentMetadata(options) {
1135
- const ua = options.userAgent;
1136
- if (!ua) return undefined;
1137
- const metadata = {
1138
- mobile: !!options.isMobile,
1139
- model: '',
1140
- architecture: 'x64',
1141
- platform: 'Windows',
1142
- platformVersion: ''
1143
- };
1144
- const androidMatch = ua.match(/Android (\d+(\.\d+)?(\.\d+)?)/);
1145
- const iPhoneMatch = ua.match(/iPhone OS (\d+(_\d+)?)/);
1146
- const iPadMatch = ua.match(/iPad; CPU OS (\d+(_\d+)?)/);
1147
- const macOSMatch = ua.match(/Mac OS X (\d+(_\d+)?(_\d+)?)/);
1148
- const windowsMatch = ua.match(/Windows\D+(\d+(\.\d+)?(\.\d+)?)/);
1149
- if (androidMatch) {
1150
- metadata.platform = 'Android';
1151
- metadata.platformVersion = androidMatch[1];
1152
- metadata.architecture = 'arm';
1153
- } else if (iPhoneMatch) {
1154
- metadata.platform = 'iOS';
1155
- metadata.platformVersion = iPhoneMatch[1];
1156
- metadata.architecture = 'arm';
1157
- } else if (iPadMatch) {
1158
- metadata.platform = 'iOS';
1159
- metadata.platformVersion = iPadMatch[1];
1160
- metadata.architecture = 'arm';
1161
- } else if (macOSMatch) {
1162
- metadata.platform = 'macOS';
1163
- metadata.platformVersion = macOSMatch[1];
1164
- if (!ua.includes('Intel')) metadata.architecture = 'arm';
1165
- } else if (windowsMatch) {
1166
- metadata.platform = 'Windows';
1167
- metadata.platformVersion = windowsMatch[1];
1168
- } else if (ua.toLowerCase().includes('linux')) {
1169
- metadata.platform = 'Linux';
1170
- }
1171
- if (ua.includes('ARM')) metadata.architecture = 'arm';
1172
- return metadata;
1173
- }
1132
+ const contextDelegateSymbol = Symbol('delegate');
@@ -10,8 +10,8 @@ var _crNetworkManager = require("./crNetworkManager");
10
10
  var network = _interopRequireWildcard(require("../network"));
11
11
  var _browserContext = require("../browserContext");
12
12
  var _utils = require("../../utils");
13
- 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); }
14
- 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; }
13
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
14
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
15
15
  /**
16
16
  * Copyright (c) Microsoft Corporation.
17
17
  *
@@ -78,6 +78,7 @@ class CRServiceWorker extends _page.Worker {
78
78
  headers: (0, _utils.headersArrayToObject)(headers, false /* lowerCase */)
79
79
  });
80
80
  }
81
+
81
82
  updateRequestInterception() {
82
83
  if (!this._networkManager || !this._isNetworkInspectionEnabled()) return Promise.resolve();
83
84
  return this._networkManager.setRequestInterception(this.needsRequestInterception()).catch(e => {});
@@ -160,6 +160,8 @@ class DebugController extends _instrumentation.SdkObject {
160
160
  pageCount += context.pages().length;
161
161
  }
162
162
  }
163
+ // TODO: browsers is deprecated, remove it.
164
+ this.emit(DebugController.Events.BrowsersChanged, browsers);
163
165
  this.emit(DebugController.Events.StateChanged, {
164
166
  pageCount
165
167
  });
@@ -187,6 +189,7 @@ class DebugController extends _instrumentation.SdkObject {
187
189
  }
188
190
  exports.DebugController = DebugController;
189
191
  DebugController.Events = {
192
+ BrowsersChanged: 'browsersChanged',
190
193
  StateChanged: 'stateChanged',
191
194
  InspectRequested: 'inspectRequested',
192
195
  SourceChanged: 'sourceChanged',