webdriverio 9.9.2 → 9.9.3

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.
@@ -8,7 +8,38 @@ type WaitState = 'none' | 'interactive' | 'networkIdle' | 'complete';
8
8
  * has to [refresh](/docs/api/webdriver#refresh) the page to trigger one.
9
9
  *
10
10
  * The command returns an `WebdriverIO.Request` object that contains information about the
11
- * request and response data of the page load.
11
+ * request and response data of the page load:
12
+ *
13
+ * ```ts
14
+ * interface WebdriverIO.Request {
15
+ * id?: string
16
+ * url: string
17
+ * timestamp: number
18
+ * navigation?: string
19
+ * redirectChain?: string[],
20
+ * headers: Record<string, string>
21
+ * cookies?: NetworkCookie[]
22
+ * \/**
23
+ * * Error message if request failed
24
+ * *\/
25
+ * error?: string
26
+ * response?: {
27
+ * fromCache: boolean
28
+ * headers: Record<string, string>
29
+ * mimeType: string
30
+ * status: number
31
+ * },
32
+ * /**
33
+ * * List of all requests that were made due to the main request.
34
+ * * Note: the list may be incomplete and does not contain request that were
35
+ * * made after the command has finished.
36
+ * *
37
+ * * The property will be undefined if the request is not a document request
38
+ * * that was initiated by the browser.
39
+ * *\/
40
+ * children?: Request[]
41
+ * }
42
+ * ```
12
43
  *
13
44
  * The command supports the following options:
14
45
  *
@@ -47,6 +78,8 @@ type WaitState = 'none' | 'interactive' | 'networkIdle' | 'complete';
47
78
  const request = await browser.url('https://webdriver.io');
48
79
  // log url
49
80
  console.log(request.url); // outputs: "https://webdriver.io"
81
+ console.log(request.response?.status); // outputs: 200
82
+ console.log(request.response?.headers); // outputs: { 'content-type': 'text/html; charset=UTF-8' }
50
83
 
51
84
  :baseUrlResolutions.js
52
85
  // With a base URL of http://example.com/site, the following url parameters resolve as such:
@@ -1 +1 @@
1
- {"version":3,"file":"url.d.ts","sourceRoot":"","sources":["../../../src/commands/browser/url.ts"],"names":[],"mappings":"AAKA,KAAK,SAAS,GAAG,MAAM,GAAG,aAAa,GAAG,aAAa,GAAG,UAAU,CAAA;AAKpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqGG;AACH,wBAAsB,GAAG,CACrB,IAAI,EAAE,WAAW,CAAC,OAAO,EACzB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,iBAAsB,GAChC,OAAO,CAAC,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC,CA6HrC;AAED,UAAU,iBAAiB;IACvB;;;;;;;;;;OAUG;IACH,IAAI,CAAC,EAAE,SAAS,CAAA;IAChB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAChC;;;OAGG;IACH,IAAI,CAAC,EAAE;QACH,IAAI,EAAE,MAAM,CAAA;QACZ,IAAI,EAAE,MAAM,CAAA;KACf,CAAA;IACD;;;;;;;OAOG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB;;;;;;;OAOG;IACH,YAAY,CAAC,EAAE,MAAM,OAAO,CAAA;CAC/B"}
1
+ {"version":3,"file":"url.d.ts","sourceRoot":"","sources":["../../../src/commands/browser/url.ts"],"names":[],"mappings":"AAKA,KAAK,SAAS,GAAG,MAAM,GAAG,aAAa,GAAG,aAAa,GAAG,UAAU,CAAA;AAKpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsIG;AACH,wBAAsB,GAAG,CACrB,IAAI,EAAE,WAAW,CAAC,OAAO,EACzB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,iBAAsB,GAChC,OAAO,CAAC,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC,CA6HrC;AAED,UAAU,iBAAiB;IACvB;;;;;;;;;;OAUG;IACH,IAAI,CAAC,EAAE,SAAS,CAAA;IAChB;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAChC;;;OAGG;IACH,IAAI,CAAC,EAAE;QACH,IAAI,EAAE,MAAM,CAAA;QACZ,IAAI,EAAE,MAAM,CAAA;KACf,CAAA;IACD;;;;;;;OAOG;IACH,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB;;;;;;;OAOG;IACH,YAAY,CAAC,EAAE,MAAM,OAAO,CAAA;CAC/B"}
package/build/index.js CHANGED
@@ -4664,12 +4664,14 @@ var _NetworkManager = class _NetworkManager extends SessionManager {
4664
4664
  __privateSet(this, _initialize3, __privateGet(this, _browser7).sessionSubscribe({
4665
4665
  events: [
4666
4666
  "browsingContext.navigationStarted",
4667
+ "browsingContext.fragmentNavigated",
4667
4668
  "network.responseCompleted",
4668
4669
  "network.beforeRequestSent",
4669
4670
  "network.fetchError"
4670
4671
  ]
4671
4672
  }).then(() => true, () => false));
4672
4673
  __privateGet(this, _browser7).on("browsingContext.navigationStarted", __privateMethod(this, _NetworkManager_instances, navigationStarted_fn).bind(this));
4674
+ __privateGet(this, _browser7).on("browsingContext.fragmentNavigated", __privateMethod(this, _NetworkManager_instances, navigationStarted_fn).bind(this));
4673
4675
  __privateGet(this, _browser7).on("network.responseCompleted", __privateMethod(this, _NetworkManager_instances, responseCompleted_fn).bind(this));
4674
4676
  __privateGet(this, _browser7).on("network.beforeRequestSent", __privateMethod(this, _NetworkManager_instances, beforeRequestSent_fn).bind(this));
4675
4677
  __privateGet(this, _browser7).on("network.fetchError", __privateMethod(this, _NetworkManager_instances, fetchError_fn).bind(this));
@@ -4677,6 +4679,7 @@ var _NetworkManager = class _NetworkManager extends SessionManager {
4677
4679
  removeListeners() {
4678
4680
  super.removeListeners();
4679
4681
  __privateGet(this, _browser7).off("browsingContext.navigationStarted", __privateMethod(this, _NetworkManager_instances, navigationStarted_fn).bind(this));
4682
+ __privateGet(this, _browser7).off("browsingContext.fragmentNavigated", __privateMethod(this, _NetworkManager_instances, navigationStarted_fn).bind(this));
4680
4683
  __privateGet(this, _browser7).off("network.responseCompleted", __privateMethod(this, _NetworkManager_instances, responseCompleted_fn).bind(this));
4681
4684
  __privateGet(this, _browser7).off("network.beforeRequestSent", __privateMethod(this, _NetworkManager_instances, beforeRequestSent_fn).bind(this));
4682
4685
  __privateGet(this, _browser7).off("network.fetchError", __privateMethod(this, _NetworkManager_instances, fetchError_fn).bind(this));
@@ -4685,16 +4688,6 @@ var _NetworkManager = class _NetworkManager extends SessionManager {
4685
4688
  return __privateGet(this, _initialize3);
4686
4689
  }
4687
4690
  getRequestResponseData(navigationId) {
4688
- if (!__privateGet(this, _requests).has(navigationId)) {
4689
- const lastRequest = Array.from(__privateGet(this, _requests).values()).pop();
4690
- if (!lastRequest) {
4691
- return void 0;
4692
- }
4693
- const lastRequestUrl = new URL(lastRequest.url);
4694
- if (lastRequestUrl.hash !== "") {
4695
- return lastRequest;
4696
- }
4697
- }
4698
4691
  return __privateGet(this, _requests).get(navigationId);
4699
4692
  }
4700
4693
  /**
package/build/node.js CHANGED
@@ -4701,12 +4701,14 @@ var NetworkManager = class _NetworkManager extends SessionManager {
4701
4701
  this.#initialize = this.#browser.sessionSubscribe({
4702
4702
  events: [
4703
4703
  "browsingContext.navigationStarted",
4704
+ "browsingContext.fragmentNavigated",
4704
4705
  "network.responseCompleted",
4705
4706
  "network.beforeRequestSent",
4706
4707
  "network.fetchError"
4707
4708
  ]
4708
4709
  }).then(() => true, () => false);
4709
4710
  this.#browser.on("browsingContext.navigationStarted", this.#navigationStarted.bind(this));
4711
+ this.#browser.on("browsingContext.fragmentNavigated", this.#navigationStarted.bind(this));
4710
4712
  this.#browser.on("network.responseCompleted", this.#responseCompleted.bind(this));
4711
4713
  this.#browser.on("network.beforeRequestSent", this.#beforeRequestSent.bind(this));
4712
4714
  this.#browser.on("network.fetchError", this.#fetchError.bind(this));
@@ -4714,6 +4716,7 @@ var NetworkManager = class _NetworkManager extends SessionManager {
4714
4716
  removeListeners() {
4715
4717
  super.removeListeners();
4716
4718
  this.#browser.off("browsingContext.navigationStarted", this.#navigationStarted.bind(this));
4719
+ this.#browser.off("browsingContext.fragmentNavigated", this.#navigationStarted.bind(this));
4717
4720
  this.#browser.off("network.responseCompleted", this.#responseCompleted.bind(this));
4718
4721
  this.#browser.off("network.beforeRequestSent", this.#beforeRequestSent.bind(this));
4719
4722
  this.#browser.off("network.fetchError", this.#fetchError.bind(this));
@@ -4836,16 +4839,6 @@ var NetworkManager = class _NetworkManager extends SessionManager {
4836
4839
  response.children?.push(request);
4837
4840
  }
4838
4841
  getRequestResponseData(navigationId) {
4839
- if (!this.#requests.has(navigationId)) {
4840
- const lastRequest = Array.from(this.#requests.values()).pop();
4841
- if (!lastRequest) {
4842
- return void 0;
4843
- }
4844
- const lastRequestUrl = new URL(lastRequest.url);
4845
- if (lastRequestUrl.hash !== "") {
4846
- return lastRequest;
4847
- }
4848
- }
4849
4842
  return this.#requests.get(navigationId);
4850
4843
  }
4851
4844
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"networkManager.d.ts","sourceRoot":"","sources":["../../src/session/networkManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAE7C,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,WAAW,CAAC,OAAO,kBAE7D;AAMD;;;;GAIG;AACH,qBAAa,cAAe,SAAQ,cAAc;;gBAMlC,OAAO,EAAE,WAAW,CAAC,OAAO;IA6BxC,eAAe,IAAI,IAAI;IAQjB,UAAU;IA+JhB,sBAAsB,CAAC,YAAY,EAAE,MAAM;IAkB3C;;;;OAIG;IACH,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,WAAW,CAAC,OAAO,EAAE;CAqBlE"}
1
+ {"version":3,"file":"networkManager.d.ts","sourceRoot":"","sources":["../../src/session/networkManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAE7C,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,WAAW,CAAC,OAAO,kBAE7D;AAMD;;;;GAIG;AACH,qBAAa,cAAe,SAAQ,cAAc;;gBAMlC,OAAO,EAAE,WAAW,CAAC,OAAO;IA+BxC,eAAe,IAAI,IAAI;IASjB,UAAU;IA+JhB,sBAAsB,CAAC,YAAY,EAAE,MAAM;IAI3C;;;;OAIG;IACH,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,WAAW,CAAC,OAAO,EAAE;CAqBlE"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "webdriverio",
3
3
  "description": "Next-gen browser and mobile automation test framework for Node.js",
4
- "version": "9.9.2",
4
+ "version": "9.9.3",
5
5
  "homepage": "https://webdriver.io",
6
6
  "author": "Christian Bromann <mail@bromann.dev>",
7
7
  "license": "MIT",
@@ -109,5 +109,5 @@
109
109
  "optional": true
110
110
  }
111
111
  },
112
- "gitHead": "05d66ef279e7d2c8abf97bb9029016f0eafcfafd"
112
+ "gitHead": "8908cc4e3cd75e85bf47692477fc5c0ab58f9168"
113
113
  }