From ecffd2088ce35efebc4e19c1a6f74ed91da15a43 Mon Sep 17 00:00:00 2001 From: "reportportal.io" Date: Tue, 23 Jan 2024 15:38:22 +0000 Subject: [PATCH 1/6] 5.1.1 -> 5.1.2-SNAPSHOT --- VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/VERSION b/VERSION index ac14c3d..e634f3c 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -5.1.1 +5.1.2-SNAPSHOT From 88e512591babd1051c0ebef383ccb3f366c7231e Mon Sep 17 00:00:00 2001 From: Ilya Date: Thu, 15 Feb 2024 16:40:17 +0100 Subject: [PATCH 2/6] Update README.md --- README.md | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index e95c8a1..8aec4e0 100644 --- a/README.md +++ b/README.md @@ -6,17 +6,18 @@ Library is used only for implementors of custom listeners for ReportPortal. ## Already implemented listeners: -* [Jest integration](https://github.com/reportportal/agent-js-jest) +* [Playwright integration](https://github.com/reportportal/agent-js-playwright) * [Cypress integration](https://github.com/reportportal/agent-js-cypress) +* [Jest integration](https://github.com/reportportal/agent-js-jest) * [Mocha integration](https://github.com/reportportal/agent-js-mocha) -* [Jasmine integration](https://github.com/reportportal/agent-js-jasmine) -* [Nightwatch integration](https://github.com/reportportal/agent-js-nightwatch) -* [Cucumber integration](https://github.com/reportportal/agent-js-cucumber) -* [Codecept integration](https://github.com/reportportal/agent-js-codecept) +* [Webdriverio integration](https://github.com/reportportal/agent-js-webdriverio) * [Postman integration](https://github.com/reportportal/agent-js-postman) +* [Cucumber integration](https://github.com/reportportal/agent-js-cucumber) +* [Vitest integration](https://github.com/reportportal/agent-js-vitest) +* [Jasmine integration](https://github.com/reportportal/agent-js-jasmine) * [TestCafe integration](https://github.com/reportportal/agent-js-testcafe) -* [Webdriverio integration](https://github.com/reportportal/agent-js-webdriverio) -* [Playwright integration](https://github.com/reportportal/agent-js-playwright) +* [Codecept integration](https://github.com/reportportal/agent-js-codecept) +* [Nightwatch integration](https://github.com/reportportal/agent-js-nightwatch) Examples for test framework integrations from the list above described in [examples](https://github.com/reportportal/examples-js) repository. From 5c841ca234e1979c8ea5a76963597b501a135a56 Mon Sep 17 00:00:00 2001 From: Ilya Date: Mon, 19 Feb 2024 20:13:50 +0100 Subject: [PATCH 3/6] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 8aec4e0..435c883 100644 --- a/README.md +++ b/README.md @@ -62,7 +62,7 @@ When creating a client instance, you need to specify the following options: | headers | Optional | {} | The object with custom headers for internal http client. | | debug | Optional | false | This flag allows seeing the logs of the client. Useful for debugging. | | isLaunchMergeRequired | Optional | false | Allows client to merge launches into one at the end of the run via saving their UUIDs to the temp files at filesystem . At the end of the run launches can be merged using `mergeLaunches` method. Temp file format: `rplaunch-${launch_uuid}.tmp`. | -| restClientConfig | Optional | Not set | The object with `agent` property for configure [http(s)](https://nodejs.org/api/https.html#https_https_request_url_options_callback) client, may contain other client options eg. `timeout`. For debugging and displaying logs you can set `debug: true` | +| restClientConfig | Optional | Not set | `axios` like http client [config](https://github.com/axios/axios#request-config). May contain `agent` property for configure [http(s)](https://nodejs.org/api/https.html#https_https_request_url_options_callback) client, and other client options eg. `timeout`. For debugging and displaying logs you can set `debug: true`. | | launchUuidPrint | Optional | false | Whether to print the current launch UUID. | | launchUuidPrintOutput | Optional | 'STDOUT' | Launch UUID printing output. Possible values: 'STDOUT', 'STDERR'. Works only if `launchUuidPrint` set to `true`. | | token | Deprecated | Not set | Use `apiKey` instead. | From 7ae3a6f4deb1ecd9cc946ccb9af46535b38ae65c Mon Sep 17 00:00:00 2001 From: AliakseiLiasnitski <40150869+AliakseiLiasnitski@users.noreply.github.com> Date: Tue, 20 Feb 2024 17:13:00 +0300 Subject: [PATCH 4/6] EPMRPP-82648 || Fix execution sequence for retry tests (#192) * EPMRPP-82648 || Fix execution sequence for retry tests * EPMRPP-82648 || update tests * EPMRPP-82648 || Remove duplicates in executableItemKeys * EPMRPP-82648 || rename map name --- lib/report-portal-client.js | 40 ++++++++++++++++++++----------- spec/report-portal-client.spec.js | 23 ++++++++---------- 2 files changed, 36 insertions(+), 27 deletions(-) diff --git a/lib/report-portal-client.js b/lib/report-portal-client.js index 888165c..659294b 100644 --- a/lib/report-portal-client.js +++ b/lib/report-portal-client.js @@ -53,7 +53,8 @@ class RPClient { }); this.statistics = new Statistics(EVENT_NAME, agentParams); this.launchUuid = ''; - this.nonRetriedItemMap = new Map(); + this.itemRetriesChainMap = new Map(); + this.itemRetriesChainKeyMapByTempId = new Map(); } // eslint-disable-next-line valid-jsdoc @@ -67,10 +68,27 @@ class RPClient { } } - calculateNonRetriedItemMapKey(launchId, parentId, name, itemId = '') { + calculateItemRetriesChainMapKey(launchId, parentId, name, itemId = '') { return `${launchId}__${parentId}__${name}__${itemId}`; } + // eslint-disable-next-line valid-jsdoc + /** + * + * @Private + */ + cleanItemRetriesChain(tempIds) { + tempIds.forEach((id) => { + const key = this.itemRetriesChainKeyMapByTempId.get(id); + + if (key) { + this.itemRetriesChainMap.delete(key); + } + + this.itemRetriesChainKeyMapByTempId.delete(id); + }); + } + getUniqId() { return UniqId(); } @@ -488,20 +506,17 @@ class RPClient { parentPromise = parentObj.promiseStart; } - const itemKey = this.calculateNonRetriedItemMapKey( + const itemKey = this.calculateItemRetriesChainMapKey( launchTempId, parentTempId, testItemDataRQ.name, testItemDataRQ.uniqueId, ); - const firstNonRetriedItemPromise = testItemDataRQ.retry && this.nonRetriedItemMap.get(itemKey); - if (firstNonRetriedItemPromise) { - parentPromise = Promise.all([parentPromise, firstNonRetriedItemPromise]); - } + const executionItemPromise = testItemDataRQ.retry && this.itemRetriesChainMap.get(itemKey); const tempId = this.getUniqId(); this.map[tempId] = this.getNewItemObj((resolve, reject) => { - parentPromise.then( + (executionItemPromise || parentPromise).then( () => { const realLaunchId = this.map[launchTempId].realId; let url = 'item/'; @@ -515,7 +530,6 @@ class RPClient { (response) => { this.logDebug(`Success start item with tempId ${tempId}`, response); this.map[tempId].realId = response.id; - this.nonRetriedItemMap.delete(itemKey); resolve(response); }, (error) => { @@ -531,10 +545,8 @@ class RPClient { ); }); this.map[parentMapId].children.push(tempId); - - if (!testItemDataRQ.retry) { - this.nonRetriedItemMap.set(itemKey, this.map[tempId].promiseStart); - } + this.itemRetriesChainKeyMapByTempId.set(tempId, itemKey); + this.itemRetriesChainMap.set(itemKey, this.map[tempId].promiseStart); return { tempId, @@ -602,7 +614,7 @@ class RPClient { } }); } - + this.cleanItemRetriesChain(itemObj.children); this.cleanMap(itemObj.children); this.logDebug(`Finish test item with tempId ${itemTempId}`, finishTestItemRQ); diff --git a/spec/report-portal-client.spec.js b/spec/report-portal-client.spec.js index 54db15f..787d1a1 100644 --- a/spec/report-portal-client.spec.js +++ b/spec/report-portal-client.spec.js @@ -63,7 +63,7 @@ describe('ReportPortal javascript client', () => { }); }); - describe('calculateNonRetriedItemMapKey', () => { + describe('calculateItemRetriesChainMapKey', () => { it("should return correct parameter's string", () => { const client = new RPClient({ apiKey: 'test', @@ -71,7 +71,7 @@ describe('ReportPortal javascript client', () => { endpoint: 'https://abc.com', }); - const str = client.calculateNonRetriedItemMapKey('lId', 'pId', 'name', 'itemId'); + const str = client.calculateItemRetriesChainMapKey('lId', 'pId', 'name', 'itemId'); expect(str).toEqual('lId__pId__name__itemId'); }); @@ -83,7 +83,7 @@ describe('ReportPortal javascript client', () => { endpoint: 'https://abc.com', }); - const str = client.calculateNonRetriedItemMapKey('lId', 'pId', 'name'); + const str = client.calculateItemRetriesChainMapKey('lId', 'pId', 'name'); expect(str).toEqual('lId__pId__name__'); }); @@ -725,17 +725,17 @@ describe('ReportPortal javascript client', () => { promiseStart: Promise.resolve(), }, }; - spyOn(client.nonRetriedItemMap, 'get').and.resolveTo(); + spyOn(client.itemRetriesChainMap, 'get').and.resolveTo(); spyOn(client.restClient, 'create').and.resolveTo({}); spyOn(client, 'getUniqId').and.returnValue('4n5pxq24kpiob12og9'); - const result = client.startTestItem({ retry: true }, 'id1', 'id'); + const result = client.startTestItem({ retry: false }, 'id1', 'id'); expect(result.tempId).toEqual('4n5pxq24kpiob12og9'); return expectAsync(result.promise).toBeResolved(); }); - it('should call nonRetriedItemMap if retry is false', () => { + it('should get previous try promise from itemRetriesChainMap if retry is true', () => { const client = new RPClient({ apiKey: 'startLaunchTest', endpoint: 'https://rp.us/api/v1', @@ -754,17 +754,14 @@ describe('ReportPortal javascript client', () => { promiseStart: Promise.resolve(), }, }; - spyOn(client, 'calculateNonRetriedItemMapKey').and.returnValue('id1__name__'); + spyOn(client, 'calculateItemRetriesChainMapKey').and.returnValue('id1__name__'); spyOn(client, 'getUniqId').and.returnValue('4n5pxq24kpiob12og9'); spyOn(client.map['4n5pxq24kpiob12og9'], 'promiseStart').and.resolveTo(); - spyOn(client.nonRetriedItemMap, 'set'); + spyOn(client.itemRetriesChainMap, 'get'); - client.startTestItem({ retry: false }, 'id1'); + client.startTestItem({ retry: true }, 'id1'); - expect(client.nonRetriedItemMap.set).toHaveBeenCalledWith( - 'id1__name__', - client.map['4n5pxq24kpiob12og9'].promiseStart, - ); + expect(client.itemRetriesChainMap.get).toHaveBeenCalledWith('id1__name__'); }); }); From f13f81669cdfa37c94c2d201d89a8aa1dc4e9180 Mon Sep 17 00:00:00 2001 From: AliakseiLiasnitski Date: Tue, 20 Feb 2024 17:29:18 +0300 Subject: [PATCH 5/6] EPMRPP-82648 || update changelog --- CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1068aa4..4129b80 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,5 @@ +### Fixed +- Execution sequence for retry tests [#134](https://github.com/reportportal/agent-js-playwright/issues/134). ## [5.1.1] - 2024-01-23 ### Added From 050834271d05fbefaac22ecaa93c7f53e9da115e Mon Sep 17 00:00:00 2001 From: AliakseiLiasnitski <40150869+AliakseiLiasnitski@users.noreply.github.com> Date: Tue, 20 Feb 2024 17:34:35 +0300 Subject: [PATCH 6/6] EPMRPP-82648 || Update CHANGELOG.md --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 4129b80..92ea218 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,5 @@ ### Fixed -- Execution sequence for retry tests [#134](https://github.com/reportportal/agent-js-playwright/issues/134). +- Execution sequence for retried tests [#134](https://github.com/reportportal/agent-js-playwright/issues/134). ## [5.1.1] - 2024-01-23 ### Added