topkat-utils 1.2.99 → 1.2.101
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/coverage/clover.xml +1756 -0
- package/coverage/coverage-final.json +16 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/clean-stack-trace.ts.html +205 -0
- package/coverage/lcov-report/config.ts.html +340 -0
- package/coverage/lcov-report/error-utils.ts.html +700 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +326 -0
- package/coverage/lcov-report/is-empty.ts.html +103 -0
- package/coverage/lcov-report/is-nodejs.ts.html +109 -0
- package/coverage/lcov-report/is-object.ts.html +91 -0
- package/coverage/lcov-report/isset.ts.html +91 -0
- package/coverage/lcov-report/logger-utils.ts.html +1156 -0
- package/coverage/lcov-report/loop-utils.ts.html +382 -0
- package/coverage/lcov-report/object-utils.ts.html +1393 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/regexp-utils.ts.html +205 -0
- package/coverage/lcov-report/remove-circular-json-stringify.ts.html +139 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov-report/string-utils.ts.html +922 -0
- package/coverage/lcov-report/timer-utils.ts.html +256 -0
- package/coverage/lcov-report/transaction-utils.ts.html +268 -0
- package/coverage/lcov.info +2138 -0
- package/dist/jest.config.d.ts +7 -0
- package/dist/jest.config.js +21 -0
- package/dist/jest.config.js.map +1 -0
- package/dist/src/error-utils.js +2 -2
- package/dist/src/error-utils.js.map +1 -1
- package/dist/src/transaction-utils.js +3 -2
- package/dist/src/transaction-utils.js.map +1 -1
- package/dist/src/transaction-utils.spec.d.ts +1 -0
- package/dist/src/transaction-utils.spec.js +49 -0
- package/dist/src/transaction-utils.spec.js.map +1 -0
- package/jest.config.ts +22 -0
- package/package.json +13 -7
- package/src/error-utils.ts +2 -2
- package/src/transaction-utils.spec.ts +74 -0
- package/src/transaction-utils.ts +3 -2
- package/tsconfig.json +2 -1
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* For a detailed explanation regarding each configuration property, visit:
|
|
4
|
+
* https://jestjs.io/docs/configuration
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
const config = {
|
|
8
|
+
clearMocks: true,
|
|
9
|
+
collectCoverage: true,
|
|
10
|
+
coverageDirectory: 'coverage',
|
|
11
|
+
coverageProvider: 'v8',
|
|
12
|
+
// testPathIgnorePatterns: ['dist/**/*'],
|
|
13
|
+
testTimeout: 9999,
|
|
14
|
+
transform: {
|
|
15
|
+
'^.+\\.tsx?$': 'ts-jest',
|
|
16
|
+
// '^.+\\.js$': '../../node_modules/babel-jest',
|
|
17
|
+
},
|
|
18
|
+
testRegex: ['.*\\.spec\\.[jt]sx?$'],
|
|
19
|
+
};
|
|
20
|
+
exports.default = config;
|
|
21
|
+
//# sourceMappingURL=jest.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jest.config.js","sourceRoot":"","sources":["../jest.config.ts"],"names":[],"mappings":";AAAA;;;GAGG;;AAIH,MAAM,MAAM,GAAW;IACnB,UAAU,EAAE,IAAI;IAChB,eAAe,EAAE,IAAI;IACrB,iBAAiB,EAAE,UAAU;IAC7B,gBAAgB,EAAE,IAAI;IACtB,yCAAyC;IACzC,WAAW,EAAE,IAAI;IACjB,SAAS,EAAE;QACP,aAAa,EAAE,SAAS;QACxB,gDAAgD;KACnD;IACD,SAAS,EAAE,CAAC,sBAAsB,CAAC;CACtC,CAAA;AAED,kBAAe,MAAM,CAAA"}
|
package/dist/src/error-utils.js
CHANGED
|
@@ -120,10 +120,10 @@ class DescriptiveError extends Error {
|
|
|
120
120
|
extraInfos.value = 'undefined';
|
|
121
121
|
if (!(0, isset_1.isset)(extraInfos.gotValue) && this.options.hasOwnProperty('gotValue'))
|
|
122
122
|
extraInfos.gotValue = 'undefined';
|
|
123
|
-
this.isAxiosError = (extraInfos?.err?.stack || extraInfos.stack || this.stack)?.startsWith('Axios') || false;
|
|
123
|
+
this.isAxiosError = this.isAxiosError || (extraInfos?.err?.stack || extraInfos.stack || this.stack)?.startsWith('Axios') || false;
|
|
124
124
|
if (this.isAxiosError) {
|
|
125
125
|
// trying to extract response
|
|
126
|
-
extraInfos.responseData =
|
|
126
|
+
extraInfos.responseData = err?.response?.data || extraInfos.response?.data;
|
|
127
127
|
}
|
|
128
128
|
if ((0, isset_1.isset)(ressource)) {
|
|
129
129
|
code = 404;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error-utils.js","sourceRoot":"","sources":["../../src/error-utils.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"error-utils.js","sourceRoot":"","sources":["../../src/error-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -31,11 +31,12 @@ async function transaction(name, asyncCallback, timeout = 120000, doNotThrow = f
|
|
|
31
31
|
reject = logger_utils_1.C.error;
|
|
32
32
|
queue[name].push(async () => {
|
|
33
33
|
try {
|
|
34
|
-
setTimeout(() => {
|
|
35
|
-
logger_utils_1.C.warning('Transaction
|
|
34
|
+
const to = setTimeout(() => {
|
|
35
|
+
logger_utils_1.C.warning('Transaction Timeout'); // in case not catched
|
|
36
36
|
reject(new Error('transactionTimeout'));
|
|
37
37
|
}, timeout);
|
|
38
38
|
const res = await asyncCallback();
|
|
39
|
+
clearTimeout(to);
|
|
39
40
|
resolve(res);
|
|
40
41
|
}
|
|
41
42
|
catch (err) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction-utils.js","sourceRoot":"","sources":["../../src/transaction-utils.ts"],"names":[],"mappings":";;;AAAA,0CAA0C;AAC1C,cAAc;AACd,0CAA0C;AAC1C,mCAA+B;AAC/B,iDAAkC;AAClC,+CAAuC;AAEvC,MAAM,kBAAkB,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE,CAAA;AAC/C,MAAM,KAAK,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,CAAA;AAE/B;;;;;;;GAOG;AACI,KAAK,UAAU,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,GAAG,MAAM,EAAE,UAAU,GAAG,KAAK;IACvF,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE;QAC5B,aAAa,GAAG,IAAI,CAAA;QACpB,IAAI,GAAG,WAAW,CAAA;KACrB;IACD,IAAI,CAAC,IAAA,aAAK,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAAE,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;IACzC,IAAI,CAAC,IAAA,aAAK,EAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAAE,kBAAkB,CAAC,IAAI,CAAC,GAAG,KAAK,CAAA;IAEtE,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACzC,IAAI,UAAU;YAAE,MAAM,GAAG,gBAAC,CAAC,KAAK,CAAA;QAChC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACxB,IAAI;gBACA,UAAU,CAAC,GAAG,EAAE;
|
|
1
|
+
{"version":3,"file":"transaction-utils.js","sourceRoot":"","sources":["../../src/transaction-utils.ts"],"names":[],"mappings":";;;AAAA,0CAA0C;AAC1C,cAAc;AACd,0CAA0C;AAC1C,mCAA+B;AAC/B,iDAAkC;AAClC,+CAAuC;AAEvC,MAAM,kBAAkB,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE,CAAA;AAC/C,MAAM,KAAK,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,CAAA;AAE/B;;;;;;;GAOG;AACI,KAAK,UAAU,WAAW,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,GAAG,MAAM,EAAE,UAAU,GAAG,KAAK;IACvF,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE;QAC5B,aAAa,GAAG,IAAI,CAAA;QACpB,IAAI,GAAG,WAAW,CAAA;KACrB;IACD,IAAI,CAAC,IAAA,aAAK,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAAE,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;IACzC,IAAI,CAAC,IAAA,aAAK,EAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAAE,kBAAkB,CAAC,IAAI,CAAC,GAAG,KAAK,CAAA;IAEtE,OAAO,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACzC,IAAI,UAAU;YAAE,MAAM,GAAG,gBAAC,CAAC,KAAK,CAAA;QAChC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACxB,IAAI;gBACA,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE;oBACvB,gBAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAA,CAAC,sBAAsB;oBACvD,MAAM,CAAC,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAA;gBAC3C,CAAC,EAAE,OAAO,CAAC,CAAA;gBACX,MAAM,GAAG,GAAG,MAAM,aAAa,EAAE,CAAA;gBACjC,YAAY,CAAC,EAAE,CAAC,CAAA;gBAChB,OAAO,CAAC,GAAG,CAAC,CAAA;aACf;YAAC,OAAO,GAAG,EAAE;gBACV,MAAM,CAAC,GAAG,CAAC,CAAA;aACd;QACL,CAAC,CAAC,CAAA;QACF,mBAAmB,CAAC,IAAI,CAAC,CAAA;IAC7B,CAAC,CAAC,CAAA;AACN,CAAC;AAzBD,kCAyBC;AAEM,KAAK,UAAU,mBAAmB,CAAC,IAAI;IAC1C,IAAI,kBAAkB,CAAC,IAAI,CAAC,KAAK,IAAI;QAAE,OAAM,CAAC,UAAU;IACxD,kBAAkB,CAAC,IAAI,CAAC,GAAG,IAAI,CAAA,CAAC,+BAA+B;IAC/D,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM;QAAE,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAA,CAAC,QAAQ;IAC/D,kBAAkB,CAAC,IAAI,CAAC,GAAG,KAAK,CAAA,CAAC,8BAA8B;AACnE,CAAC,CAAC,iEAAiE;AALnE,kDAKC;AACD,kEAAkE;AAElE,4EAA4E;AACrE,KAAK,UAAU,kBAAkB,CAAC,eAAe,EAAE,qBAAqB,GAAG,EAAE;IAChF,IAAI,GAAG,GAAG,KAAK,CAAA;IACf,UAAU,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,IAAI,EAAE,qBAAqB,GAAG,IAAI,CAAC,CAAA;IAC1D,OAAO,IAAA,aAAK,EAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC,IAAI,kBAAkB,CAAC,eAAe,CAAC,KAAK,IAAI,EAAE;QAC/F,IAAI,GAAG;YAAE,MAAK;QACd,MAAM,IAAA,qBAAO,EAAC,EAAE,CAAC,CAAA;KACpB;AACL,CAAC;AAPD,gDAOC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const transaction_utils_1 = require("./transaction-utils");
|
|
4
|
+
const timer_utils_1 = require("./timer-utils");
|
|
5
|
+
describe('TRANSACTION TEST', () => {
|
|
6
|
+
const statusArr = [];
|
|
7
|
+
const asyncCallback = i => async () => {
|
|
8
|
+
await (0, timer_utils_1.timeout)(1000);
|
|
9
|
+
statusArr.push(i);
|
|
10
|
+
};
|
|
11
|
+
it('should execute the async callback and resolve the result', async () => {
|
|
12
|
+
(0, transaction_utils_1.transaction)('test', asyncCallback(1), 1500);
|
|
13
|
+
(0, transaction_utils_1.transaction)('test', asyncCallback(2), 1500);
|
|
14
|
+
const now = Date.now();
|
|
15
|
+
await (0, transaction_utils_1.transaction)('test', asyncCallback(3), 1500);
|
|
16
|
+
const timeSpent = Date.now() - now;
|
|
17
|
+
expect(statusArr).toEqual([1, 2, 3]);
|
|
18
|
+
expect(timeSpent < 5000).toEqual(true);
|
|
19
|
+
expect(timeSpent > 2999).toEqual(true);
|
|
20
|
+
});
|
|
21
|
+
it('Second run', async () => {
|
|
22
|
+
(0, transaction_utils_1.transaction)('test', asyncCallback(4), 1500);
|
|
23
|
+
(0, transaction_utils_1.transaction)('test', asyncCallback(5), 1500);
|
|
24
|
+
const now = Date.now();
|
|
25
|
+
await (0, transaction_utils_1.transaction)('test', asyncCallback(6), 1500);
|
|
26
|
+
const timeSpent = Date.now() - now;
|
|
27
|
+
expect(statusArr).toEqual([1, 2, 3, 4, 5, 6]);
|
|
28
|
+
expect(timeSpent < 5000).toEqual(true);
|
|
29
|
+
expect(timeSpent > 2999).toEqual(true);
|
|
30
|
+
});
|
|
31
|
+
const infiniteCallback = async () => await (0, timer_utils_1.timeout)(5000);
|
|
32
|
+
it('Transaction timeout if the transaction is infinite and other transaction run correctly', async () => {
|
|
33
|
+
const now = Date.now();
|
|
34
|
+
let hasErr = false;
|
|
35
|
+
try {
|
|
36
|
+
await (0, transaction_utils_1.transaction)('test', infiniteCallback, 1000);
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
hasErr = true;
|
|
40
|
+
}
|
|
41
|
+
const timeSpent = Date.now() - now;
|
|
42
|
+
await (0, transaction_utils_1.transaction)('test', asyncCallback(7), 1500);
|
|
43
|
+
expect(hasErr).toEqual(true);
|
|
44
|
+
expect(statusArr).toEqual([1, 2, 3, 4, 5, 6, 7]);
|
|
45
|
+
expect(timeSpent < 2000).toEqual(true);
|
|
46
|
+
expect(timeSpent > 999).toEqual(true);
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=transaction-utils.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-utils.spec.js","sourceRoot":"","sources":["../../src/transaction-utils.spec.ts"],"names":[],"mappings":"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"}
|
package/jest.config.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* For a detailed explanation regarding each configuration property, visit:
|
|
3
|
+
* https://jestjs.io/docs/configuration
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import type { Config } from 'jest'
|
|
7
|
+
|
|
8
|
+
const config: Config = {
|
|
9
|
+
clearMocks: true,
|
|
10
|
+
collectCoverage: true,
|
|
11
|
+
coverageDirectory: 'coverage',
|
|
12
|
+
coverageProvider: 'v8',
|
|
13
|
+
// testPathIgnorePatterns: ['dist/**/*'],
|
|
14
|
+
testTimeout: 9999,
|
|
15
|
+
transform: {
|
|
16
|
+
'^.+\\.tsx?$': 'ts-jest',
|
|
17
|
+
// '^.+\\.js$': '../../node_modules/babel-jest',
|
|
18
|
+
},
|
|
19
|
+
testRegex: ['.*\\.spec\\.[jt]sx?$'],
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export default config
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "topkat-utils",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.101",
|
|
4
4
|
"type": "commonjs",
|
|
5
5
|
"types": "index.ts",
|
|
6
6
|
"main": "dist",
|
|
@@ -14,16 +14,22 @@
|
|
|
14
14
|
},
|
|
15
15
|
"scripts": {
|
|
16
16
|
"build": "tsc",
|
|
17
|
-
"bump:major": "npm run build
|
|
18
|
-
"bump:minor": "npm run build
|
|
19
|
-
"bump:patch": "npm run build
|
|
17
|
+
"bump:major": "yarn test:ci && npm run build && node node_modules/bump-simple/bump-simple.js --major",
|
|
18
|
+
"bump:minor": "yarn test:ci && npm run build && node node_modules/bump-simple/bump-simple.js --minor",
|
|
19
|
+
"bump:patch": "yarn test:ci && npm run build && node node_modules/bump-simple/bump-simple.js --patch",
|
|
20
|
+
"test": "jest --watchAll",
|
|
21
|
+
"test:ci": "jest --ci --runInBand --maxConcurrency=1 --silent"
|
|
20
22
|
},
|
|
21
23
|
"devDependencies": {
|
|
24
|
+
"@types/jest": "^29.5.12",
|
|
22
25
|
"@types/node": "^18.11.18",
|
|
26
|
+
"@typescript-eslint/eslint-plugin": "latest",
|
|
27
|
+
"@typescript-eslint/parser": "latest",
|
|
23
28
|
"bump-simple": "^1.0.0",
|
|
24
29
|
"eslint": "^8.0.0",
|
|
25
|
-
"
|
|
26
|
-
"
|
|
27
|
-
"
|
|
30
|
+
"jest": "^29.7.0",
|
|
31
|
+
"ts-jest": "^29.2.4",
|
|
32
|
+
"ts-node": "^10.9.2",
|
|
33
|
+
"typescript": "^4.9.5"
|
|
28
34
|
}
|
|
29
35
|
}
|
package/src/error-utils.ts
CHANGED
|
@@ -133,11 +133,11 @@ export class DescriptiveError<ExpectedOriginalError = any> extends Error {
|
|
|
133
133
|
if (!isset(extraInfos.value) && this.options.hasOwnProperty('value')) extraInfos.value = 'undefined'
|
|
134
134
|
if (!isset(extraInfos.gotValue) && this.options.hasOwnProperty('gotValue')) extraInfos.gotValue = 'undefined'
|
|
135
135
|
|
|
136
|
-
this.isAxiosError = (extraInfos?.err?.stack || extraInfos.stack || this.stack)?.startsWith('Axios') || false
|
|
136
|
+
this.isAxiosError = this.isAxiosError || (extraInfos?.err?.stack || extraInfos.stack || this.stack)?.startsWith('Axios') || false
|
|
137
137
|
|
|
138
138
|
if (this.isAxiosError) {
|
|
139
139
|
// trying to extract response
|
|
140
|
-
extraInfos.responseData =
|
|
140
|
+
extraInfos.responseData = err?.response?.data || extraInfos.response?.data
|
|
141
141
|
}
|
|
142
142
|
|
|
143
143
|
if (isset(ressource)) {
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
import { transaction } from './transaction-utils'
|
|
5
|
+
|
|
6
|
+
import { timeout } from './timer-utils'
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
describe('TRANSACTION TEST', () => {
|
|
10
|
+
const statusArr = [] as number[]
|
|
11
|
+
|
|
12
|
+
const asyncCallback = i => async () => {
|
|
13
|
+
await timeout(1000)
|
|
14
|
+
statusArr.push(i)
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
it('should execute the async callback and resolve the result', async () => {
|
|
18
|
+
|
|
19
|
+
transaction('test', asyncCallback(1), 1500)
|
|
20
|
+
transaction('test', asyncCallback(2), 1500)
|
|
21
|
+
const now = Date.now()
|
|
22
|
+
await transaction('test', asyncCallback(3), 1500)
|
|
23
|
+
const timeSpent = Date.now() - now
|
|
24
|
+
|
|
25
|
+
expect(statusArr).toEqual([1, 2, 3])
|
|
26
|
+
|
|
27
|
+
expect(timeSpent < 5000).toEqual(true)
|
|
28
|
+
expect(timeSpent > 2999).toEqual(true)
|
|
29
|
+
|
|
30
|
+
})
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
it('Second run', async () => {
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
transaction('test', asyncCallback(4), 1500)
|
|
38
|
+
transaction('test', asyncCallback(5), 1500)
|
|
39
|
+
const now = Date.now()
|
|
40
|
+
await transaction('test', asyncCallback(6), 1500)
|
|
41
|
+
const timeSpent = Date.now() - now
|
|
42
|
+
|
|
43
|
+
expect(statusArr).toEqual([1, 2, 3, 4, 5, 6])
|
|
44
|
+
|
|
45
|
+
expect(timeSpent < 5000).toEqual(true)
|
|
46
|
+
expect(timeSpent > 2999).toEqual(true)
|
|
47
|
+
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
const infiniteCallback = async () => await timeout(5000)
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
it('Transaction timeout if the transaction is infinite and other transaction run correctly', async () => {
|
|
54
|
+
|
|
55
|
+
const now = Date.now()
|
|
56
|
+
let hasErr = false
|
|
57
|
+
try {
|
|
58
|
+
await transaction('test', infiniteCallback, 1000)
|
|
59
|
+
} catch (err) {
|
|
60
|
+
hasErr = true
|
|
61
|
+
}
|
|
62
|
+
const timeSpent = Date.now() - now
|
|
63
|
+
|
|
64
|
+
await transaction('test', asyncCallback(7), 1500)
|
|
65
|
+
|
|
66
|
+
expect(hasErr).toEqual(true)
|
|
67
|
+
|
|
68
|
+
expect(statusArr).toEqual([1, 2, 3, 4, 5, 6, 7])
|
|
69
|
+
|
|
70
|
+
expect(timeSpent < 2000).toEqual(true)
|
|
71
|
+
expect(timeSpent > 999).toEqual(true)
|
|
72
|
+
|
|
73
|
+
})
|
|
74
|
+
})
|
package/src/transaction-utils.ts
CHANGED
|
@@ -28,11 +28,12 @@ export async function transaction(name, asyncCallback, timeout = 120000, doNotTh
|
|
|
28
28
|
if (doNotThrow) reject = C.error
|
|
29
29
|
queue[name].push(async () => {
|
|
30
30
|
try {
|
|
31
|
-
setTimeout(() => {
|
|
32
|
-
C.warning('Transaction
|
|
31
|
+
const to = setTimeout(() => {
|
|
32
|
+
C.warning('Transaction Timeout') // in case not catched
|
|
33
33
|
reject(new Error('transactionTimeout'))
|
|
34
34
|
}, timeout)
|
|
35
35
|
const res = await asyncCallback()
|
|
36
|
+
clearTimeout(to)
|
|
36
37
|
resolve(res)
|
|
37
38
|
} catch (err) {
|
|
38
39
|
reject(err)
|