@ls-stack/utils 3.65.0 → 3.67.0
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/dist/{arrayUtils.d.cts → arrayUtils.d.mts} +24 -23
- package/dist/arrayUtils.mjs +249 -0
- package/dist/assertions-qMxfVhSu.mjs +207 -0
- package/dist/{assertions.d.ts → assertions.d.mts} +4 -3
- package/dist/assertions.mjs +3 -0
- package/dist/asyncQueue.d.mts +497 -0
- package/dist/asyncQueue.mjs +757 -0
- package/dist/{awaitDebounce.d.cts → awaitDebounce.d.mts} +11 -6
- package/dist/awaitDebounce.mjs +54 -0
- package/dist/{cache.d.ts → cache.d.mts} +76 -68
- package/dist/cache.mjs +355 -0
- package/dist/castValues-DfICShCc.mjs +19 -0
- package/dist/{castValues.d.cts → castValues.d.mts} +3 -2
- package/dist/castValues.mjs +3 -0
- package/dist/{concurrentCalls.d.ts → concurrentCalls.d.mts} +74 -65
- package/dist/concurrentCalls.mjs +295 -0
- package/dist/consoleFmt.d.mts +55 -0
- package/dist/consoleFmt.mjs +63 -0
- package/dist/conversions-DTmwEMIu.mjs +12 -0
- package/dist/conversions.d.mts +4 -0
- package/dist/conversions.mjs +3 -0
- package/dist/createThrottleController.d.mts +18 -0
- package/dist/createThrottleController.mjs +40 -0
- package/dist/debounce.d.mts +47 -0
- package/dist/debounce.mjs +117 -0
- package/dist/dedent.d.mts +74 -0
- package/dist/dedent.mjs +80 -0
- package/dist/deepEqual-C7EZEixx.mjs +78 -0
- package/dist/{deepEqual.d.cts → deepEqual.d.mts} +3 -2
- package/dist/deepEqual.mjs +3 -0
- package/dist/{deepReplaceValues.d.cts → deepReplaceValues.d.mts} +4 -3
- package/dist/deepReplaceValues.mjs +61 -0
- package/dist/diffParser.d.mts +79 -0
- package/dist/diffParser.mjs +424 -0
- package/dist/enhancedMap.d.mts +21 -0
- package/dist/enhancedMap.mjs +69 -0
- package/dist/exhaustiveMatch.d.mts +10 -0
- package/dist/exhaustiveMatch.mjs +48 -0
- package/dist/{filterObjectOrArrayKeys.d.cts → filterObjectOrArrayKeys.d.mts} +15 -8
- package/dist/filterObjectOrArrayKeys.mjs +497 -0
- package/dist/{getAutoIncrementId.d.cts → getAutoIncrementId.d.mts} +9 -5
- package/dist/getAutoIncrementId.mjs +53 -0
- package/dist/{getCompositeKey.d.cts → getCompositeKey.d.mts} +3 -2
- package/dist/getCompositeKey.mjs +50 -0
- package/dist/{getValueStableKey.d.cts → getValueStableKey.d.mts} +5 -3
- package/dist/getValueStableKey.mjs +17 -0
- package/dist/{hash.d.cts → hash.d.mts} +3 -2
- package/dist/hash.mjs +28 -0
- package/dist/interpolate.d.mts +17 -0
- package/dist/interpolate.mjs +28 -0
- package/dist/{iteratorUtils.d.cts → iteratorUtils.d.mts} +5 -4
- package/dist/iteratorUtils.mjs +39 -0
- package/dist/keepPrevIfUnchanged.d.mts +12 -0
- package/dist/keepPrevIfUnchanged.mjs +9 -0
- package/dist/keyedMap.d.mts +76 -0
- package/dist/keyedMap.mjs +139 -0
- package/dist/keyedSet.d.mts +77 -0
- package/dist/keyedSet.mjs +129 -0
- package/dist/{levenshtein.d.cts → levenshtein.d.mts} +3 -2
- package/dist/levenshtein.mjs +121 -0
- package/dist/main.d.mts +4 -0
- package/dist/main.mjs +7 -0
- package/dist/matchPath.d.mts +50 -0
- package/dist/matchPath.mjs +81 -0
- package/dist/mathUtils-BDP1lM_z.mjs +81 -0
- package/dist/{mathUtils.d.cts → mathUtils.d.mts} +3 -2
- package/dist/mathUtils.mjs +3 -0
- package/dist/{mutationUtils.d.cts → mutationUtils.d.mts} +6 -5
- package/dist/mutationUtils.mjs +44 -0
- package/dist/{objUtils.d.ts → objUtils.d.mts} +8 -6
- package/dist/objUtils.mjs +115 -0
- package/dist/parallelAsyncCalls.d.mts +83 -0
- package/dist/parallelAsyncCalls.mjs +121 -0
- package/dist/partialEqual.d.mts +139 -0
- package/dist/partialEqual.mjs +1055 -0
- package/dist/promiseUtils.d.mts +9 -0
- package/dist/promiseUtils.mjs +17 -0
- package/dist/regexUtils.d.mts +18 -0
- package/dist/regexUtils.mjs +34 -0
- package/dist/{retryOnError.d.cts → retryOnError.d.mts} +38 -37
- package/dist/retryOnError.mjs +91 -0
- package/dist/{runShellCmd.d.ts → runShellCmd.d.mts} +24 -15
- package/dist/runShellCmd.mjs +151 -0
- package/dist/{safeJson.d.cts → safeJson.d.mts} +3 -2
- package/dist/safeJson.mjs +30 -0
- package/dist/{saferTyping.d.cts → saferTyping.d.mts} +4 -3
- package/dist/saferTyping.mjs +45 -0
- package/dist/serializeXML.d.mts +23 -0
- package/dist/serializeXML.mjs +74 -0
- package/dist/{shallowEqual.d.cts → shallowEqual.d.mts} +3 -2
- package/dist/shallowEqual.mjs +54 -0
- package/dist/sleep.d.mts +4 -0
- package/dist/sleep.mjs +7 -0
- package/dist/stringUtils-DjhWOiYn.mjs +113 -0
- package/dist/{stringUtils.d.cts → stringUtils.d.mts} +3 -2
- package/dist/stringUtils.mjs +3 -0
- package/dist/{testUtils.d.ts → testUtils.d.mts} +83 -52
- package/dist/testUtils.mjs +310 -0
- package/dist/{throttle.d.ts → throttle.d.mts} +18 -17
- package/dist/throttle.mjs +102 -0
- package/dist/time-sr2lhQRw.mjs +67 -0
- package/dist/{time.d.ts → time.d.mts} +8 -7
- package/dist/time.mjs +3 -0
- package/dist/{timers.d.cts → timers.d.mts} +22 -13
- package/dist/timers.mjs +220 -0
- package/dist/{tsResult.d.cts → tsResult.d.mts} +52 -48
- package/dist/tsResult.mjs +142 -0
- package/dist/typeGuards-B1mzA-Rz.mjs +128 -0
- package/dist/{typeGuards.d.cts → typeGuards.d.mts} +3 -2
- package/dist/typeGuards.mjs +3 -0
- package/dist/{typeUtils.d.ts → typeUtils.d.mts} +13 -34
- package/dist/typeUtils.mjs +1 -0
- package/dist/{typedStrings.d.cts → typedStrings.d.mts} +5 -4
- package/dist/typedStrings.mjs +131 -0
- package/dist/typingFnUtils-Bb8drgKF.mjs +101 -0
- package/dist/{typingFnUtils.d.cts → typingFnUtils.d.mts} +13 -22
- package/dist/typingFnUtils.mjs +3 -0
- package/dist/{typingTestUtils.d.cts → typingTestUtils.d.mts} +11 -15
- package/dist/typingTestUtils.mjs +80 -0
- package/dist/typingUtils.d.mts +20 -0
- package/dist/typingUtils.mjs +1 -0
- package/dist/yamlStringify.d.mts +17 -0
- package/dist/yamlStringify.mjs +189 -0
- package/package.json +65 -242
- package/dist/arrayUtils.cjs +0 -229
- package/dist/arrayUtils.d.ts +0 -171
- package/dist/arrayUtils.js +0 -42
- package/dist/assertions.cjs +0 -107
- package/dist/assertions.d.cts +0 -192
- package/dist/assertions.js +0 -25
- package/dist/asyncQueue.cjs +0 -672
- package/dist/asyncQueue.d.cts +0 -488
- package/dist/asyncQueue.d.ts +0 -488
- package/dist/asyncQueue.js +0 -631
- package/dist/awaitDebounce.cjs +0 -106
- package/dist/awaitDebounce.d.ts +0 -41
- package/dist/awaitDebounce.js +0 -28
- package/dist/cache.cjs +0 -367
- package/dist/cache.d.cts +0 -228
- package/dist/cache.js +0 -19
- package/dist/castValues.cjs +0 -50
- package/dist/castValues.d.ts +0 -4
- package/dist/castValues.js +0 -8
- package/dist/chunk-5DZT3Z5Z.js +0 -8
- package/dist/chunk-6FBIEPWU.js +0 -96
- package/dist/chunk-6FIBVC2P.js +0 -56
- package/dist/chunk-7CQPOM5I.js +0 -100
- package/dist/chunk-B6DNOZCP.js +0 -369
- package/dist/chunk-BM4PYVOX.js +0 -109
- package/dist/chunk-C2SVCIWE.js +0 -57
- package/dist/chunk-CCUPDGSZ.js +0 -132
- package/dist/chunk-DBOWTYR4.js +0 -49
- package/dist/chunk-DFXNVEH6.js +0 -14
- package/dist/chunk-DX2524CZ.js +0 -314
- package/dist/chunk-GMJTLFM6.js +0 -60
- package/dist/chunk-IATIXMCE.js +0 -20
- package/dist/chunk-II4R3VVX.js +0 -25
- package/dist/chunk-JF2MDHOJ.js +0 -40
- package/dist/chunk-JQFUKJU5.js +0 -71
- package/dist/chunk-MI4UE2PQ.js +0 -561
- package/dist/chunk-PUKVXYYL.js +0 -52
- package/dist/chunk-QQS7I7ZL.js +0 -16
- package/dist/chunk-VAAMRG4K.js +0 -20
- package/dist/chunk-WFQJUJTC.js +0 -182
- package/dist/chunk-ZXIKIA5B.js +0 -178
- package/dist/concurrentCalls.cjs +0 -406
- package/dist/concurrentCalls.d.cts +0 -116
- package/dist/concurrentCalls.js +0 -346
- package/dist/consoleFmt.cjs +0 -85
- package/dist/consoleFmt.d.cts +0 -54
- package/dist/consoleFmt.d.ts +0 -54
- package/dist/consoleFmt.js +0 -60
- package/dist/conversions.cjs +0 -44
- package/dist/conversions.d.cts +0 -3
- package/dist/conversions.d.ts +0 -3
- package/dist/conversions.js +0 -6
- package/dist/createThrottleController.cjs +0 -193
- package/dist/createThrottleController.d.cts +0 -13
- package/dist/createThrottleController.d.ts +0 -13
- package/dist/createThrottleController.js +0 -61
- package/dist/debounce.cjs +0 -157
- package/dist/debounce.d.cts +0 -46
- package/dist/debounce.d.ts +0 -46
- package/dist/debounce.js +0 -8
- package/dist/dedent.cjs +0 -104
- package/dist/dedent.d.cts +0 -73
- package/dist/dedent.d.ts +0 -73
- package/dist/dedent.js +0 -79
- package/dist/deepEqual.cjs +0 -96
- package/dist/deepEqual.d.ts +0 -21
- package/dist/deepEqual.js +0 -8
- package/dist/deepReplaceValues.cjs +0 -87
- package/dist/deepReplaceValues.d.ts +0 -27
- package/dist/deepReplaceValues.js +0 -7
- package/dist/enhancedMap.cjs +0 -131
- package/dist/enhancedMap.d.cts +0 -20
- package/dist/enhancedMap.d.ts +0 -20
- package/dist/enhancedMap.js +0 -10
- package/dist/exhaustiveMatch.cjs +0 -66
- package/dist/exhaustiveMatch.d.cts +0 -9
- package/dist/exhaustiveMatch.d.ts +0 -9
- package/dist/exhaustiveMatch.js +0 -40
- package/dist/filterObjectOrArrayKeys.cjs +0 -619
- package/dist/filterObjectOrArrayKeys.d.ts +0 -88
- package/dist/filterObjectOrArrayKeys.js +0 -9
- package/dist/getAutoIncrementId.cjs +0 -44
- package/dist/getAutoIncrementId.d.ts +0 -46
- package/dist/getAutoIncrementId.js +0 -18
- package/dist/getCompositeKey.cjs +0 -86
- package/dist/getCompositeKey.d.ts +0 -11
- package/dist/getCompositeKey.js +0 -8
- package/dist/getValueStableKey.cjs +0 -89
- package/dist/getValueStableKey.d.ts +0 -15
- package/dist/getValueStableKey.js +0 -11
- package/dist/hash.cjs +0 -57
- package/dist/hash.d.ts +0 -7
- package/dist/hash.js +0 -32
- package/dist/interpolate.cjs +0 -88
- package/dist/interpolate.d.cts +0 -11
- package/dist/interpolate.d.ts +0 -11
- package/dist/interpolate.js +0 -46
- package/dist/iteratorUtils.cjs +0 -73
- package/dist/iteratorUtils.d.ts +0 -10
- package/dist/iteratorUtils.js +0 -44
- package/dist/keepPrevIfUnchanged.cjs +0 -102
- package/dist/keepPrevIfUnchanged.d.cts +0 -7
- package/dist/keepPrevIfUnchanged.d.ts +0 -7
- package/dist/keepPrevIfUnchanged.js +0 -7
- package/dist/keyedMap.cjs +0 -224
- package/dist/keyedMap.d.cts +0 -75
- package/dist/keyedMap.d.ts +0 -75
- package/dist/keyedMap.js +0 -145
- package/dist/keyedSet.cjs +0 -205
- package/dist/keyedSet.d.cts +0 -76
- package/dist/keyedSet.d.ts +0 -76
- package/dist/keyedSet.js +0 -126
- package/dist/levenshtein.cjs +0 -180
- package/dist/levenshtein.d.ts +0 -5
- package/dist/levenshtein.js +0 -153
- package/dist/main.cjs +0 -32
- package/dist/main.d.cts +0 -3
- package/dist/main.d.ts +0 -3
- package/dist/main.js +0 -7
- package/dist/matchPath.cjs +0 -155
- package/dist/matchPath.d.cts +0 -53
- package/dist/matchPath.d.ts +0 -53
- package/dist/matchPath.js +0 -108
- package/dist/mathUtils.cjs +0 -81
- package/dist/mathUtils.d.ts +0 -54
- package/dist/mathUtils.js +0 -22
- package/dist/mutationUtils.cjs +0 -153
- package/dist/mutationUtils.d.ts +0 -15
- package/dist/mutationUtils.js +0 -55
- package/dist/objUtils.cjs +0 -242
- package/dist/objUtils.d.cts +0 -28
- package/dist/objUtils.js +0 -38
- package/dist/parallelAsyncCalls.cjs +0 -162
- package/dist/parallelAsyncCalls.d.cts +0 -82
- package/dist/parallelAsyncCalls.d.ts +0 -82
- package/dist/parallelAsyncCalls.js +0 -126
- package/dist/partialEqual.cjs +0 -1196
- package/dist/partialEqual.d.cts +0 -141
- package/dist/partialEqual.d.ts +0 -141
- package/dist/partialEqual.js +0 -1168
- package/dist/promiseUtils.cjs +0 -38
- package/dist/promiseUtils.d.cts +0 -8
- package/dist/promiseUtils.d.ts +0 -8
- package/dist/promiseUtils.js +0 -6
- package/dist/regexUtils.cjs +0 -60
- package/dist/regexUtils.d.cts +0 -17
- package/dist/regexUtils.d.ts +0 -17
- package/dist/regexUtils.js +0 -33
- package/dist/retryOnError.cjs +0 -130
- package/dist/retryOnError.d.ts +0 -83
- package/dist/retryOnError.js +0 -101
- package/dist/runShellCmd.cjs +0 -127
- package/dist/runShellCmd.d.cts +0 -90
- package/dist/runShellCmd.js +0 -98
- package/dist/safeJson.cjs +0 -45
- package/dist/safeJson.d.ts +0 -16
- package/dist/safeJson.js +0 -8
- package/dist/saferTyping.cjs +0 -52
- package/dist/saferTyping.d.ts +0 -47
- package/dist/saferTyping.js +0 -23
- package/dist/serializeXML.cjs +0 -154
- package/dist/serializeXML.d.cts +0 -22
- package/dist/serializeXML.d.ts +0 -22
- package/dist/serializeXML.js +0 -116
- package/dist/shallowEqual.cjs +0 -88
- package/dist/shallowEqual.d.ts +0 -4
- package/dist/shallowEqual.js +0 -63
- package/dist/sleep.cjs +0 -32
- package/dist/sleep.d.cts +0 -3
- package/dist/sleep.d.ts +0 -3
- package/dist/sleep.js +0 -6
- package/dist/stringUtils.cjs +0 -155
- package/dist/stringUtils.d.ts +0 -55
- package/dist/stringUtils.js +0 -50
- package/dist/testUtils.cjs +0 -1490
- package/dist/testUtils.d.cts +0 -133
- package/dist/testUtils.js +0 -359
- package/dist/throttle.cjs +0 -282
- package/dist/throttle.d.cts +0 -98
- package/dist/throttle.js +0 -38
- package/dist/time.cjs +0 -152
- package/dist/time.d.cts +0 -25
- package/dist/time.js +0 -38
- package/dist/timers.cjs +0 -194
- package/dist/timers.d.ts +0 -121
- package/dist/timers.js +0 -156
- package/dist/tsResult.cjs +0 -226
- package/dist/tsResult.d.ts +0 -114
- package/dist/tsResult.js +0 -180
- package/dist/typeGuards.cjs +0 -70
- package/dist/typeGuards.d.ts +0 -111
- package/dist/typeGuards.js +0 -18
- package/dist/typeUtils.cjs +0 -18
- package/dist/typeUtils.d.cts +0 -61
- package/dist/typeUtils.js +0 -0
- package/dist/typedStrings.cjs +0 -90
- package/dist/typedStrings.d.ts +0 -163
- package/dist/typedStrings.js +0 -57
- package/dist/typingFnUtils.cjs +0 -96
- package/dist/typingFnUtils.d.ts +0 -100
- package/dist/typingFnUtils.js +0 -30
- package/dist/typingTestUtils.cjs +0 -52
- package/dist/typingTestUtils.d.ts +0 -79
- package/dist/typingTestUtils.js +0 -27
- package/dist/typingUtils.cjs +0 -18
- package/dist/typingUtils.d.cts +0 -35
- package/dist/typingUtils.d.ts +0 -35
- package/dist/typingUtils.js +0 -0
- package/dist/yamlStringify.cjs +0 -423
- package/dist/yamlStringify.d.cts +0 -10
- package/dist/yamlStringify.d.ts +0 -10
- package/dist/yamlStringify.js +0 -9
package/dist/testUtils.d.cts
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { YamlStringifyOptions } from './yamlStringify.cjs';
|
|
2
|
-
|
|
3
|
-
declare function createLoggerStore({ filterKeys: defaultFilterKeys, rejectKeys: defaultRejectKeys, splitLongLines: defaultSplitLongLines, maxLineLengthBeforeSplit: defaultMaxLineLengthBeforeSplit, fromLastSnapshot: defaultFromLastSnapshot, arrays: defaultArrays, changesOnly: defaultChangesOnly, useEmojiForBooleans: defaultUseEmojiForBooleans, }?: {
|
|
4
|
-
filterKeys?: string[];
|
|
5
|
-
rejectKeys?: string[];
|
|
6
|
-
splitLongLines?: true;
|
|
7
|
-
maxLineLengthBeforeSplit?: number;
|
|
8
|
-
fromLastSnapshot?: boolean;
|
|
9
|
-
arrays?: 'all' | 'firstAndLast' | 'length' | {
|
|
10
|
-
firstNItems: number;
|
|
11
|
-
};
|
|
12
|
-
changesOnly?: boolean;
|
|
13
|
-
useEmojiForBooleans?: boolean;
|
|
14
|
-
}): {
|
|
15
|
-
add: (render: Record<string, unknown> | readonly Record<string, unknown>[]) => void;
|
|
16
|
-
reset: (keepLastRender?: boolean) => void;
|
|
17
|
-
getSnapshot: ({ arrays, changesOnly, filterKeys, rejectKeys, includeLastSnapshotEndMark, splitLongLines, maxLineLengthBeforeSplit, fromLastSnapshot, useEmojiForBooleans, }?: {
|
|
18
|
-
arrays?: "all" | "firstAndLast" | "length" | {
|
|
19
|
-
firstNItems: number;
|
|
20
|
-
};
|
|
21
|
-
changesOnly?: boolean;
|
|
22
|
-
filterKeys?: string[];
|
|
23
|
-
rejectKeys?: string[];
|
|
24
|
-
includeLastSnapshotEndMark?: boolean;
|
|
25
|
-
splitLongLines?: boolean;
|
|
26
|
-
maxLineLengthBeforeSplit?: number;
|
|
27
|
-
fromLastSnapshot?: boolean;
|
|
28
|
-
useEmojiForBooleans?: boolean;
|
|
29
|
-
}) => string;
|
|
30
|
-
waitNextLog: (timeout?: number) => Promise<void>;
|
|
31
|
-
readonly changesSnapshot: string;
|
|
32
|
-
readonly snapshot: string;
|
|
33
|
-
readonly snapshotFromLast: string;
|
|
34
|
-
logsCount: () => number;
|
|
35
|
-
readonly rendersTime: number[];
|
|
36
|
-
addMark: (label: string) => void;
|
|
37
|
-
};
|
|
38
|
-
declare function getResultFn<T extends (...args: any[]) => any>(fnGetter: () => T, wrapper?: (...args: any[]) => any): T;
|
|
39
|
-
declare function waitController(): {
|
|
40
|
-
wait: Promise<void>;
|
|
41
|
-
stopWaiting: () => void;
|
|
42
|
-
stopWaitingAfter: (ms: number) => void;
|
|
43
|
-
};
|
|
44
|
-
/**
|
|
45
|
-
* Produces a more compact and readable snapshot of a value using yaml. By
|
|
46
|
-
* default booleans are shown as `✅` and `❌`, use `showBooleansAs` to
|
|
47
|
-
* disable/configure this.
|
|
48
|
-
*
|
|
49
|
-
* Filtering patterns in `rejectKeys` and `filterKeys`:
|
|
50
|
-
*
|
|
51
|
-
* - `'prop'` - Only root-level properties named 'prop'
|
|
52
|
-
* - `'**prop'` - Any property named exactly 'prop' at any level (root or nested)
|
|
53
|
-
* - `'*.prop'` - Any nested property named 'prop' at second level (excludes
|
|
54
|
-
* root-level matches)
|
|
55
|
-
* - `'test.*.prop'` - Any property named 'prop' at second level of 'test'
|
|
56
|
-
* - `'test.*.test.**prop'` - Any property named 'prop' inside of 'test.*.test'
|
|
57
|
-
* - `'prop.nested'` - Exact nested property paths like `obj.prop.nested`
|
|
58
|
-
* - `'prop.**nested'` - All nested properties inside root `prop` with name
|
|
59
|
-
* `nested`
|
|
60
|
-
* - `'prop[0]'` - The first item of the `prop` array
|
|
61
|
-
* - `'prop[*]'` - All items of the `prop` array
|
|
62
|
-
* - `'prop[0].nested'` - `nested` prop of the first item of the `prop` array
|
|
63
|
-
* - `'prop[*].nested'` - `nested` prop of all items of the `prop` array
|
|
64
|
-
* - `'prop[*]**nested'` - all `nested` props of all items of the `prop` array
|
|
65
|
-
* - `'prop[0-2]'` - The first three items of the `prop` array
|
|
66
|
-
* - `'prop[4-*]'` - All items of the `prop` array from the fourth index to the
|
|
67
|
-
* end
|
|
68
|
-
* - `'prop[0-2].nested.**prop'` - Combining multiple nested patterns is supported
|
|
69
|
-
* - Root array:
|
|
70
|
-
*
|
|
71
|
-
* - `'[0]'` - The first item of the root array
|
|
72
|
-
* - `'[*]'` - All items of the array
|
|
73
|
-
* - `'[0].nested'` - `nested` prop of the first item of the array
|
|
74
|
-
* - `'[*].nested'` - `nested` prop of all items of the array
|
|
75
|
-
* - `'[*]**nested'` - all `nested` props of all items of the array
|
|
76
|
-
* - `'[0-2]'` - The first three items of the array
|
|
77
|
-
* - `'[4-*]'` - All items of the array from the fourth index to the end
|
|
78
|
-
* - Expanding the patterns with parentheses:
|
|
79
|
-
*
|
|
80
|
-
* - `'prop.test.(prop1|prop2|prop3.prop4)'` - Will produce `prop.test.prop1`,
|
|
81
|
-
* `prop.test.prop2`, and `prop.test.prop3.prop4`
|
|
82
|
-
* - Array filtering by value:
|
|
83
|
-
*
|
|
84
|
-
* - `'users[%name="John"]'` - Filters the `users` with the `name` property equal
|
|
85
|
-
* to `John`
|
|
86
|
-
* - `'users[%name="John" | "Jane"]'` - Filters the `users` with the `name`
|
|
87
|
-
* property equal to `John` or `Jane`
|
|
88
|
-
* - `'users[%name="John" | "Jane" && %age=20]'` - AND and OR are supported by
|
|
89
|
-
* using `&&` and `||`, nesting logical operators is not supported yet
|
|
90
|
-
* - `'users[%config.name="John" | "Jane"]'` - Dot notation is supported
|
|
91
|
-
*
|
|
92
|
-
* Check more supported patterns in {@link filterObjectOrArrayKeys} docs.
|
|
93
|
-
*
|
|
94
|
-
* @param value - The value to snapshot.
|
|
95
|
-
* @param options - The options for the snapshot.
|
|
96
|
-
* @param options.collapseObjects - Whether to collapse objects into a single
|
|
97
|
-
* line.
|
|
98
|
-
* @param options.maxLineLength - The maximum length of a line.
|
|
99
|
-
* @param options.showUndefined - Whether to show undefined values.
|
|
100
|
-
* @param options.showBooleansAs - Whether to show booleans as text, by default
|
|
101
|
-
* true is `✅` and false is `❌`
|
|
102
|
-
* @param options.rejectKeys - The keys to reject.
|
|
103
|
-
* @param options.filterKeys - The keys to filter.
|
|
104
|
-
* @param options.ignoreProps - The props to ignore.
|
|
105
|
-
* @param options.replaceValues - Function to replace values at specific paths.
|
|
106
|
-
* Returns `false` to keep original value or `{newValue}` to replace.
|
|
107
|
-
* @param options.sortKeys - Sort all keys by a specific order (default:
|
|
108
|
-
* `simpleValuesFirst`).
|
|
109
|
-
* @param options.sortPatterns - Sort specific keys by pattern. Use to control
|
|
110
|
-
* the order of specific properties. The same patterns as `filterKeys` are
|
|
111
|
-
* supported.
|
|
112
|
-
* @returns The compact snapshot of the value.
|
|
113
|
-
*/
|
|
114
|
-
declare function compactSnapshot(value: unknown, { collapseObjects, maxLineLength, showUndefined, showBooleansAs, replaceValues, rejectKeys, filterKeys, sortKeys, sortPatterns, ...options }?: YamlStringifyOptions & {
|
|
115
|
-
showBooleansAs?: boolean | {
|
|
116
|
-
props?: Record<string, {
|
|
117
|
-
trueText?: string;
|
|
118
|
-
falseText?: string;
|
|
119
|
-
} | true>;
|
|
120
|
-
ignoreProps?: string[];
|
|
121
|
-
trueText?: string;
|
|
122
|
-
falseText?: string;
|
|
123
|
-
};
|
|
124
|
-
replaceValues?: (value: unknown, path: string) => false | {
|
|
125
|
-
newValue: unknown;
|
|
126
|
-
};
|
|
127
|
-
rejectKeys?: string[] | string;
|
|
128
|
-
filterKeys?: string[] | string;
|
|
129
|
-
sortKeys?: 'asc' | 'desc' | 'simpleValuesFirst' | false;
|
|
130
|
-
sortPatterns?: string[];
|
|
131
|
-
}): string;
|
|
132
|
-
|
|
133
|
-
export { compactSnapshot, createLoggerStore, getResultFn, waitController };
|
package/dist/testUtils.js
DELETED
|
@@ -1,359 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
yamlStringify
|
|
3
|
-
} from "./chunk-B6DNOZCP.js";
|
|
4
|
-
import {
|
|
5
|
-
omit,
|
|
6
|
-
pick
|
|
7
|
-
} from "./chunk-ZXIKIA5B.js";
|
|
8
|
-
import "./chunk-GMJTLFM6.js";
|
|
9
|
-
import {
|
|
10
|
-
filterObjectOrArrayKeys
|
|
11
|
-
} from "./chunk-MI4UE2PQ.js";
|
|
12
|
-
import "./chunk-IATIXMCE.js";
|
|
13
|
-
import {
|
|
14
|
-
deepEqual
|
|
15
|
-
} from "./chunk-JQFUKJU5.js";
|
|
16
|
-
import {
|
|
17
|
-
deepReplaceValues
|
|
18
|
-
} from "./chunk-PUKVXYYL.js";
|
|
19
|
-
import {
|
|
20
|
-
defer
|
|
21
|
-
} from "./chunk-DFXNVEH6.js";
|
|
22
|
-
import {
|
|
23
|
-
clampMin
|
|
24
|
-
} from "./chunk-DBOWTYR4.js";
|
|
25
|
-
import "./chunk-BM4PYVOX.js";
|
|
26
|
-
import {
|
|
27
|
-
arrayWithPrevAndIndex,
|
|
28
|
-
filterAndMap
|
|
29
|
-
} from "./chunk-WFQJUJTC.js";
|
|
30
|
-
import {
|
|
31
|
-
isObject
|
|
32
|
-
} from "./chunk-C2SVCIWE.js";
|
|
33
|
-
import {
|
|
34
|
-
isPlainObject
|
|
35
|
-
} from "./chunk-JF2MDHOJ.js";
|
|
36
|
-
|
|
37
|
-
// src/testUtils.ts
|
|
38
|
-
function createLoggerStore({
|
|
39
|
-
filterKeys: defaultFilterKeys,
|
|
40
|
-
rejectKeys: defaultRejectKeys,
|
|
41
|
-
splitLongLines: defaultSplitLongLines = true,
|
|
42
|
-
maxLineLengthBeforeSplit: defaultMaxLineLengthBeforeSplit = 80,
|
|
43
|
-
fromLastSnapshot: defaultFromLastSnapshot = false,
|
|
44
|
-
arrays: defaultArrays = { firstNItems: 1 },
|
|
45
|
-
changesOnly: defaultChangesOnly = false,
|
|
46
|
-
useEmojiForBooleans: defaultUseEmojiForBooleans = true
|
|
47
|
-
} = {}) {
|
|
48
|
-
let logs = [];
|
|
49
|
-
let logsTime = [];
|
|
50
|
-
let startTime = Date.now();
|
|
51
|
-
let onNextLog = () => {
|
|
52
|
-
};
|
|
53
|
-
function reset(keepLastRender = false) {
|
|
54
|
-
logs = keepLastRender ? [logs.at(-1)] : [];
|
|
55
|
-
logsTime = [];
|
|
56
|
-
startTime = Date.now();
|
|
57
|
-
}
|
|
58
|
-
function add(render) {
|
|
59
|
-
if (!isObject(render)) {
|
|
60
|
-
for (const [i, r] of render.entries()) {
|
|
61
|
-
logs.push({
|
|
62
|
-
i: i + 1,
|
|
63
|
-
...r
|
|
64
|
-
});
|
|
65
|
-
logsTime.push(Date.now() - startTime);
|
|
66
|
-
}
|
|
67
|
-
} else {
|
|
68
|
-
logs.push(render);
|
|
69
|
-
logsTime.push(Date.now() - startTime);
|
|
70
|
-
}
|
|
71
|
-
onNextLog();
|
|
72
|
-
if (logs.length > 100) {
|
|
73
|
-
throw new Error("Too many logs");
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
function logsCount() {
|
|
77
|
-
return logs.filter((item) => !item._lastSnapshotMark).length;
|
|
78
|
-
}
|
|
79
|
-
async function waitNextLog(timeout = 50) {
|
|
80
|
-
return new Promise((resolve) => {
|
|
81
|
-
const timeoutId = setTimeout(() => {
|
|
82
|
-
throw new Error("Timeout");
|
|
83
|
-
}, timeout);
|
|
84
|
-
onNextLog = () => {
|
|
85
|
-
clearTimeout(timeoutId);
|
|
86
|
-
resolve();
|
|
87
|
-
};
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
function getSnapshot({
|
|
91
|
-
arrays = defaultArrays,
|
|
92
|
-
changesOnly = defaultChangesOnly,
|
|
93
|
-
filterKeys = defaultFilterKeys,
|
|
94
|
-
rejectKeys = defaultRejectKeys,
|
|
95
|
-
includeLastSnapshotEndMark = true,
|
|
96
|
-
splitLongLines = defaultSplitLongLines,
|
|
97
|
-
maxLineLengthBeforeSplit = defaultMaxLineLengthBeforeSplit,
|
|
98
|
-
fromLastSnapshot = defaultFromLastSnapshot,
|
|
99
|
-
useEmojiForBooleans = defaultUseEmojiForBooleans
|
|
100
|
-
} = {}) {
|
|
101
|
-
let rendersToUse = logs;
|
|
102
|
-
if (changesOnly || filterKeys || rejectKeys) {
|
|
103
|
-
rendersToUse = [];
|
|
104
|
-
for (let { item, prev } of arrayWithPrevAndIndex(logs)) {
|
|
105
|
-
if (item._lastSnapshotMark || item._mark) {
|
|
106
|
-
rendersToUse.push(item);
|
|
107
|
-
continue;
|
|
108
|
-
}
|
|
109
|
-
if (filterKeys) {
|
|
110
|
-
prev = prev && pick(prev, filterKeys);
|
|
111
|
-
item = pick(item, filterKeys);
|
|
112
|
-
}
|
|
113
|
-
if (rejectKeys) {
|
|
114
|
-
prev = prev && omit(prev, rejectKeys);
|
|
115
|
-
item = omit(item, rejectKeys);
|
|
116
|
-
}
|
|
117
|
-
if (!deepEqual(prev, item)) {
|
|
118
|
-
rendersToUse.push(item);
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
if (fromLastSnapshot) {
|
|
123
|
-
const lastSnapshotMark = rendersToUse.findLastIndex(
|
|
124
|
-
(item) => item._lastSnapshotMark === true
|
|
125
|
-
);
|
|
126
|
-
rendersToUse = rendersToUse.slice(clampMin(lastSnapshotMark, 0));
|
|
127
|
-
}
|
|
128
|
-
logs.push({ _lastSnapshotMark: true });
|
|
129
|
-
const propDivider = "\u22C5";
|
|
130
|
-
const snapShot = `
|
|
131
|
-
${filterAndMap(rendersToUse, (render, i) => {
|
|
132
|
-
if (render._lastSnapshotMark) {
|
|
133
|
-
if (includeLastSnapshotEndMark) {
|
|
134
|
-
if (rendersToUse.length === 1) {
|
|
135
|
-
return "\u22C5\u22C5\u22C5";
|
|
136
|
-
}
|
|
137
|
-
if (i !== rendersToUse.length - 1) {
|
|
138
|
-
return "\u22C5\u22C5\u22C5";
|
|
139
|
-
}
|
|
140
|
-
return false;
|
|
141
|
-
} else {
|
|
142
|
-
return false;
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
if (render._mark) {
|
|
146
|
-
const prevIsLastSnapshotMark = rendersToUse[i - 1]?._lastSnapshotMark;
|
|
147
|
-
let mark = `${prevIsLastSnapshotMark ? "" : "\n"}>>> ${String(render._mark)}`;
|
|
148
|
-
const nextRender = rendersToUse[i + 1];
|
|
149
|
-
if (nextRender && !nextRender._mark && !nextRender._lastSnapshotMark) {
|
|
150
|
-
mark = `${mark}
|
|
151
|
-
`;
|
|
152
|
-
}
|
|
153
|
-
return mark;
|
|
154
|
-
}
|
|
155
|
-
let line = "";
|
|
156
|
-
for (const [key, _value] of Object.entries(render)) {
|
|
157
|
-
let value = _value;
|
|
158
|
-
if (Array.isArray(value)) {
|
|
159
|
-
if (arrays === "length") {
|
|
160
|
-
value = `Array(${value.length})`;
|
|
161
|
-
} else if (arrays === "firstAndLast" && value.length > 2) {
|
|
162
|
-
const intermediateSize = clampMin(value.length - 2, 0);
|
|
163
|
-
value = [value[0], `\u2026(${intermediateSize} between)`, value.at(-1)];
|
|
164
|
-
} else if (typeof arrays === "object" && value.length > 2) {
|
|
165
|
-
value = [
|
|
166
|
-
...value.slice(0, arrays.firstNItems),
|
|
167
|
-
`\u2026(${value.length - arrays.firstNItems} more)`
|
|
168
|
-
];
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
if (typeof value === "boolean" && useEmojiForBooleans) {
|
|
172
|
-
value = value ? "\u2705" : "\u274C";
|
|
173
|
-
}
|
|
174
|
-
if (value === "") {
|
|
175
|
-
value = `''`;
|
|
176
|
-
}
|
|
177
|
-
if (typeof value === "object" && value !== null) {
|
|
178
|
-
value = JSON.stringify(value).replace(/:true/g, ":\u2705").replace(/:false/g, ":\u274C").replace(/:""/g, ":''").replace(/"/g, "").replace(/,/g, ", ");
|
|
179
|
-
}
|
|
180
|
-
line += `${key}: ${value} ${propDivider} `;
|
|
181
|
-
}
|
|
182
|
-
line = line.slice(0, (propDivider.length + 2) * -1);
|
|
183
|
-
if (splitLongLines && line.length > maxLineLengthBeforeSplit) {
|
|
184
|
-
const parts = line.split(` ${propDivider} `);
|
|
185
|
-
if (parts.length === 1) {
|
|
186
|
-
return line;
|
|
187
|
-
}
|
|
188
|
-
line = "";
|
|
189
|
-
const propDividerML = "\u22C5";
|
|
190
|
-
for (const { item, index } of arrayWithPrevAndIndex(parts)) {
|
|
191
|
-
if (index === 0) {
|
|
192
|
-
line += `\u250C\u2500
|
|
193
|
-
${propDividerML} `;
|
|
194
|
-
} else if (index === parts.length - 1) {
|
|
195
|
-
line += `${propDividerML} `;
|
|
196
|
-
} else {
|
|
197
|
-
line += `${propDividerML} `;
|
|
198
|
-
}
|
|
199
|
-
line += `${item}
|
|
200
|
-
`;
|
|
201
|
-
if (index === parts.length - 1) {
|
|
202
|
-
line += "\u2514\u2500";
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
} else {
|
|
206
|
-
line = `-> ${line}`;
|
|
207
|
-
}
|
|
208
|
-
return line;
|
|
209
|
-
}).join("\n")}
|
|
210
|
-
`;
|
|
211
|
-
return snapShot === `
|
|
212
|
-
\u22C5\u22C5\u22C5
|
|
213
|
-
` ? "\u22C5\u22C5\u22C5empty\u22C5\u22C5\u22C5" : snapShot;
|
|
214
|
-
}
|
|
215
|
-
function addMark(label) {
|
|
216
|
-
add({ _mark: label });
|
|
217
|
-
}
|
|
218
|
-
return {
|
|
219
|
-
add,
|
|
220
|
-
reset,
|
|
221
|
-
getSnapshot,
|
|
222
|
-
waitNextLog,
|
|
223
|
-
get changesSnapshot() {
|
|
224
|
-
return getSnapshot({ changesOnly: true });
|
|
225
|
-
},
|
|
226
|
-
get snapshot() {
|
|
227
|
-
return getSnapshot();
|
|
228
|
-
},
|
|
229
|
-
get snapshotFromLast() {
|
|
230
|
-
return getSnapshot({ fromLastSnapshot: true });
|
|
231
|
-
},
|
|
232
|
-
logsCount,
|
|
233
|
-
get rendersTime() {
|
|
234
|
-
return logsTime;
|
|
235
|
-
},
|
|
236
|
-
addMark
|
|
237
|
-
};
|
|
238
|
-
}
|
|
239
|
-
function getResultFn(fnGetter, wrapper) {
|
|
240
|
-
return (...args) => {
|
|
241
|
-
const fn = fnGetter();
|
|
242
|
-
if (wrapper) {
|
|
243
|
-
return wrapper(fn(...args));
|
|
244
|
-
} else {
|
|
245
|
-
return fn(...args);
|
|
246
|
-
}
|
|
247
|
-
};
|
|
248
|
-
}
|
|
249
|
-
function waitController() {
|
|
250
|
-
const { promise, resolve } = defer();
|
|
251
|
-
return {
|
|
252
|
-
wait: promise,
|
|
253
|
-
stopWaiting: () => {
|
|
254
|
-
resolve();
|
|
255
|
-
},
|
|
256
|
-
stopWaitingAfter: (ms) => {
|
|
257
|
-
setTimeout(() => {
|
|
258
|
-
resolve();
|
|
259
|
-
}, ms);
|
|
260
|
-
}
|
|
261
|
-
};
|
|
262
|
-
}
|
|
263
|
-
function compactSnapshot(value, {
|
|
264
|
-
collapseObjects = true,
|
|
265
|
-
maxLineLength = 100,
|
|
266
|
-
showUndefined = false,
|
|
267
|
-
showBooleansAs = true,
|
|
268
|
-
replaceValues,
|
|
269
|
-
rejectKeys,
|
|
270
|
-
filterKeys,
|
|
271
|
-
sortKeys,
|
|
272
|
-
sortPatterns,
|
|
273
|
-
...options
|
|
274
|
-
} = {}) {
|
|
275
|
-
let processedValue = value;
|
|
276
|
-
if (rejectKeys || filterKeys) {
|
|
277
|
-
if (isPlainObject(processedValue) || Array.isArray(processedValue)) {
|
|
278
|
-
processedValue = filterObjectOrArrayKeys(processedValue, {
|
|
279
|
-
rejectKeys,
|
|
280
|
-
filterKeys,
|
|
281
|
-
sortKeys,
|
|
282
|
-
sortPatterns
|
|
283
|
-
});
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
if (replaceValues) {
|
|
287
|
-
processedValue = deepReplaceValues(processedValue, replaceValues);
|
|
288
|
-
}
|
|
289
|
-
processedValue = showBooleansAs ? replaceBooleansWithEmoji(processedValue, showBooleansAs) : processedValue;
|
|
290
|
-
return `
|
|
291
|
-
${yamlStringify(processedValue, {
|
|
292
|
-
collapseObjects,
|
|
293
|
-
maxLineLength,
|
|
294
|
-
showUndefined,
|
|
295
|
-
...options
|
|
296
|
-
})}`;
|
|
297
|
-
}
|
|
298
|
-
function replaceBooleansWithEmoji(value, showBooleansAs, visited = /* @__PURE__ */ new Set()) {
|
|
299
|
-
if (showBooleansAs === false) {
|
|
300
|
-
return value;
|
|
301
|
-
}
|
|
302
|
-
const defaultTrueText = "\u2705";
|
|
303
|
-
const defaultFalseText = "\u274C";
|
|
304
|
-
const config = typeof showBooleansAs === "boolean" ? { trueText: defaultTrueText, falseText: defaultFalseText } : {
|
|
305
|
-
trueText: showBooleansAs.trueText ?? defaultTrueText,
|
|
306
|
-
falseText: showBooleansAs.falseText ?? defaultFalseText,
|
|
307
|
-
props: showBooleansAs.props ?? {},
|
|
308
|
-
ignoreProps: showBooleansAs.ignoreProps ?? []
|
|
309
|
-
};
|
|
310
|
-
function processValue(val, propName) {
|
|
311
|
-
if (typeof val === "boolean") {
|
|
312
|
-
if (propName && config.ignoreProps?.includes(propName)) {
|
|
313
|
-
return val;
|
|
314
|
-
}
|
|
315
|
-
if (propName && config.props?.[propName]) {
|
|
316
|
-
const propConfig = config.props[propName];
|
|
317
|
-
if (propConfig === true) {
|
|
318
|
-
return val ? config.trueText : config.falseText;
|
|
319
|
-
}
|
|
320
|
-
return val ? propConfig.trueText ?? config.trueText : propConfig.falseText ?? config.falseText;
|
|
321
|
-
}
|
|
322
|
-
return val ? config.trueText : config.falseText;
|
|
323
|
-
}
|
|
324
|
-
if (Array.isArray(val)) {
|
|
325
|
-
if (visited.has(val)) {
|
|
326
|
-
throw new Error("Circular reference detected in array");
|
|
327
|
-
}
|
|
328
|
-
visited.add(val);
|
|
329
|
-
try {
|
|
330
|
-
return val.map((item) => processValue(item));
|
|
331
|
-
} finally {
|
|
332
|
-
visited.delete(val);
|
|
333
|
-
}
|
|
334
|
-
}
|
|
335
|
-
if (isPlainObject(val)) {
|
|
336
|
-
if (visited.has(val)) {
|
|
337
|
-
throw new Error("Circular reference detected in object");
|
|
338
|
-
}
|
|
339
|
-
visited.add(val);
|
|
340
|
-
try {
|
|
341
|
-
const result = {};
|
|
342
|
-
for (const [key, itemValue] of Object.entries(val)) {
|
|
343
|
-
result[key] = processValue(itemValue, key);
|
|
344
|
-
}
|
|
345
|
-
return result;
|
|
346
|
-
} finally {
|
|
347
|
-
visited.delete(val);
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
return val;
|
|
351
|
-
}
|
|
352
|
-
return processValue(value);
|
|
353
|
-
}
|
|
354
|
-
export {
|
|
355
|
-
compactSnapshot,
|
|
356
|
-
createLoggerStore,
|
|
357
|
-
getResultFn,
|
|
358
|
-
waitController
|
|
359
|
-
};
|