klubok 0.4.2 → 0.4.4

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 (2) hide show
  1. package/dist/index.js +36 -28
  2. package/package.json +9 -6
package/dist/index.js CHANGED
@@ -16,17 +16,47 @@ exports.onError = onError;
16
16
  function klubok(...fns) {
17
17
  const funcs = fns.filter(f => !f.onError);
18
18
  const onError = fns.find(f => f.onError);
19
- return (rootCtx = {}, mock, only) => {
19
+ return async (rootCtx = {}, mock, only) => {
20
20
  let isExit = false;
21
- return funcs.reduce(mock == null && only == null
22
- ? (acc, fn) => acc.then(ctx => !fn.mutable && Reflect.has(ctx, fn.key)
23
- ? Promise.reject(new Error(`Try to override existing alias "${fn.key}". Let's rename alias or use "mut" wrapper`))
21
+ if (mock == null && only == null) {
22
+ let ctx = rootCtx;
23
+ for (const fn of funcs) {
24
+ if (!fn.mutable && ctx[fn.key]) {
25
+ throw new Error(`Try to override existing alias "${fn.key}". Let's rename alias or use "mut" wrapper`);
26
+ }
27
+ if (isExit) {
28
+ break;
29
+ }
30
+ try {
31
+ const resp = await fn(ctx);
32
+ if (fn.exitable && resp) {
33
+ isExit = true;
34
+ }
35
+ ctx = { ...ctx, [fn.key]: resp };
36
+ }
37
+ catch (error) {
38
+ await onError?.({ ...ctx, $error: error });
39
+ if (error instanceof Error) {
40
+ error.stack += '\ncontext: ' + (0, node_util_1.inspect)(ctx);
41
+ }
42
+ throw error;
43
+ }
44
+ }
45
+ return ctx;
46
+ }
47
+ return funcs.reduce((acc, fn) => acc.then(ctx => !fn.mutable && Reflect.has(ctx, fn.key) && !Reflect.has(mock ?? {}, fn.key)
48
+ ? Promise.reject(new Error(`Try to override existing alias "${fn.key}". Let's rename alias or use "mut" wrapper`))
49
+ : (mock && Reflect.has(mock, fn.key) && typeof Reflect.get(mock, fn.key) !== 'function') ||
50
+ (only && only.length && !only.includes(fn.key))
51
+ ? ctx
24
52
  : (async () => {
25
53
  try {
26
54
  if (isExit) {
27
55
  return ctx;
28
56
  }
29
- return await Promise.resolve(fn(ctx)).then(resp => (fn.exitable && resp && (isExit = true), { ...ctx, [fn.key]: resp }));
57
+ return await Promise.resolve(mock && Reflect.has(mock, fn.key) && typeof Reflect.get(mock, fn.key) === 'function'
58
+ ? Reflect.get(mock, fn.key)(ctx)
59
+ : fn(ctx)).then(resp => (fn.exitable && resp && (isExit = true), { ...ctx, [fn.key]: resp }));
30
60
  }
31
61
  catch (error) {
32
62
  await onError?.({ ...ctx, $error: error });
@@ -35,28 +65,6 @@ function klubok(...fns) {
35
65
  }
36
66
  throw error;
37
67
  }
38
- })())
39
- : (acc, fn) => acc.then(ctx => !fn.mutable && Reflect.has(ctx, fn.key) && !Reflect.has(mock ?? {}, fn.key)
40
- ? Promise.reject(new Error(`Try to override existing alias "${fn.key}". Let's rename alias or use "mut" wrapper`))
41
- : (mock && Reflect.has(mock, fn.key) && typeof Reflect.get(mock, fn.key) !== 'function') ||
42
- (only && only.length && !only.includes(fn.key))
43
- ? ctx
44
- : (async () => {
45
- try {
46
- if (isExit) {
47
- return ctx;
48
- }
49
- return await Promise.resolve(mock && Reflect.has(mock, fn.key) && typeof Reflect.get(mock, fn.key) === 'function'
50
- ? Reflect.get(mock, fn.key)(ctx)
51
- : fn(ctx)).then(resp => (fn.exitable && resp && (isExit = true), { ...ctx, [fn.key]: resp }));
52
- }
53
- catch (error) {
54
- await onError?.({ ...ctx, $error: error });
55
- if (error instanceof Error) {
56
- error.stack += '\ncontext: ' + (0, node_util_1.inspect)(ctx);
57
- }
58
- throw error;
59
- }
60
- })()), Promise.resolve({ ...rootCtx, ...mock }));
68
+ })()), Promise.resolve({ ...rootCtx, ...mock }));
61
69
  };
62
70
  }
package/package.json CHANGED
@@ -1,20 +1,21 @@
1
1
  {
2
2
  "name": "klubok",
3
- "version": "0.4.2",
3
+ "version": "0.4.4",
4
4
  "description": "Do notation pipes for Promise-based or pure functions which easy to mock",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "repository": {
8
8
  "type": "git",
9
- "url": "git@github.com:darky/klubok.git"
9
+ "url": "git+ssh://git@github.com/darky/klubok.git"
10
10
  },
11
11
  "files": [
12
12
  "dist/index.js",
13
13
  "dist/index.d.ts"
14
14
  ],
15
15
  "scripts": {
16
+ "bench": "node ./bench.ts",
16
17
  "build": "rm -rf dist && tsc",
17
- "test": "node --experimental-strip-types --test ./test.ts",
18
+ "test": "node --test ./test.ts",
18
19
  "test:types": "cp index.test-d.ts ./dist/ && npx tsd",
19
20
  "prepublishOnly": "npm run build"
20
21
  },
@@ -33,8 +34,10 @@
33
34
  "author": "Vladislav Botvin",
34
35
  "license": "MIT",
35
36
  "devDependencies": {
36
- "@types/node": "^22.10.6",
37
- "tsd": "^0.31.2",
38
- "typescript": "^5.7.3"
37
+ "@types/node": "^22.15.3",
38
+ "klubok": "0.4.3",
39
+ "tinybench": "^4.0.1",
40
+ "tsd": "^0.32.0",
41
+ "typescript": "^5.8.3"
39
42
  }
40
43
  }