@cardano-sdk/util-dev 0.4.1-nightly.4 → 0.4.1-nightly.5
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/README.md +75 -0
- package/dist/cjs/TestLogger.d.ts +35 -0
- package/dist/cjs/TestLogger.d.ts.map +1 -0
- package/dist/cjs/TestLogger.js +101 -0
- package/dist/cjs/TestLogger.js.map +1 -0
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/TestLogger.d.ts +35 -0
- package/dist/esm/TestLogger.d.ts.map +1 -0
- package/dist/esm/TestLogger.js +71 -0
- package/dist/esm/TestLogger.js.map +1 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -3
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
declare const logLevels: {
|
|
3
|
+
debug: number;
|
|
4
|
+
error: number;
|
|
5
|
+
fatal: number;
|
|
6
|
+
info: number;
|
|
7
|
+
trace: number;
|
|
8
|
+
warn: number;
|
|
9
|
+
};
|
|
10
|
+
declare type LogLevel = keyof typeof logLevels;
|
|
11
|
+
export declare type LogFunction = (...args: unknown[]) => void;
|
|
12
|
+
export declare type LoggedMessage = {
|
|
13
|
+
level: LogLevel;
|
|
14
|
+
message: unknown[];
|
|
15
|
+
};
|
|
16
|
+
export declare type Logger = {
|
|
17
|
+
[l in LogLevel]: LogFunction;
|
|
18
|
+
};
|
|
19
|
+
export declare type TestLogger = Logger & {
|
|
20
|
+
messages: LoggedMessage[];
|
|
21
|
+
};
|
|
22
|
+
declare type TestStream = {
|
|
23
|
+
columns?: number;
|
|
24
|
+
isTTY?: boolean;
|
|
25
|
+
write: Function;
|
|
26
|
+
};
|
|
27
|
+
export interface TestLoggerOptions {
|
|
28
|
+
env?: NodeJS.ProcessEnv;
|
|
29
|
+
record?: boolean;
|
|
30
|
+
stream?: TestStream;
|
|
31
|
+
}
|
|
32
|
+
export declare const createLogger: (options?: TestLoggerOptions) => TestLogger;
|
|
33
|
+
export declare const logger: TestLogger;
|
|
34
|
+
export {};
|
|
35
|
+
//# sourceMappingURL=TestLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestLogger.d.ts","sourceRoot":"","sources":["../../src/TestLogger.ts"],"names":[],"mappings":";AAMA,QAAA,MAAM,SAAS;;;;;;;CAA+D,CAAC;AAG/E,aAAK,QAAQ,GAAG,MAAM,OAAO,SAAS,CAAC;AAMvC,oBAAY,WAAW,GAAG,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;AAKvD,oBAAY,aAAa,GAAG;IAAE,KAAK,EAAE,QAAQ,CAAC;IAAC,OAAO,EAAE,OAAO,EAAE,CAAA;CAAE,CAAC;AAKpE,oBAAY,MAAM,GAAG;KAAG,CAAC,IAAI,QAAQ,GAAG,WAAW;CAAE,CAAC;AAMtD,oBAAY,UAAU,GAAG,MAAM,GAAG;IAAE,QAAQ,EAAE,aAAa,EAAE,CAAA;CAAE,CAAC;AAEhE,aAAK,UAAU,GAAG;IAAE,OAAO,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,QAAQ,CAAA;CAAE,CAAC;AAKzE,MAAM,WAAW,iBAAiB;IAIhC,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;IAKxB,MAAM,CAAC,EAAE,OAAO,CAAC;IAKjB,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB;AAsCD,eAAO,MAAM,YAAY,aAAa,iBAAiB,eA0CtD,CAAC;AAKF,eAAO,MAAM,MAAM,YAAiB,CAAC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import * as envalid from 'envalid';
|
|
2
|
+
import { inspect } from 'util';
|
|
3
|
+
import JSONbig from 'json-bigint';
|
|
4
|
+
const logLevels = { debug: 2, error: 5, fatal: 6, info: 3, trace: 1, warn: 4 };
|
|
5
|
+
const logLevelLabels = ['', 'TRACE ', 'DEBUG ', 'INFO ', 'WARNING', 'ERROR ', 'FATAL '];
|
|
6
|
+
const getConfig = (env, stream) => {
|
|
7
|
+
const { TL_ARRAY, TL_BREAK, TL_COLOR, TL_COMPACT, TL_DEPTH, TL_HIDDEN, TL_JSON, TL_LEVEL, TL_PROXY, TL_STRING } = envalid.cleanEnv(env, {
|
|
8
|
+
TL_ARRAY: envalid.num({ default: 100 }),
|
|
9
|
+
TL_BREAK: envalid.num({ default: stream?.columns ? stream?.columns - 33 : 90 }),
|
|
10
|
+
TL_COLOR: envalid.bool({ default: stream?.isTTY || false }),
|
|
11
|
+
TL_COMPACT: envalid.num({ default: 3 }),
|
|
12
|
+
TL_DEPTH: envalid.num({ default: 2 }),
|
|
13
|
+
TL_HIDDEN: envalid.bool({ default: false }),
|
|
14
|
+
TL_JSON: envalid.bool({ default: false }),
|
|
15
|
+
TL_LEVEL: envalid.str({ choices: Object.keys(logLevels), default: 'fatal' }),
|
|
16
|
+
TL_PROXY: envalid.bool({ default: false }),
|
|
17
|
+
TL_STRING: envalid.num({ default: 1000 })
|
|
18
|
+
});
|
|
19
|
+
const inspectOptions = {
|
|
20
|
+
breakLength: TL_BREAK || Number.POSITIVE_INFINITY,
|
|
21
|
+
colors: TL_COLOR,
|
|
22
|
+
compact: TL_COMPACT || false,
|
|
23
|
+
depth: TL_DEPTH || Number.POSITIVE_INFINITY,
|
|
24
|
+
maxArrayLength: TL_ARRAY || Number.POSITIVE_INFINITY,
|
|
25
|
+
maxStringLength: TL_STRING || Number.POSITIVE_INFINITY,
|
|
26
|
+
showHidden: TL_HIDDEN,
|
|
27
|
+
showProxy: TL_PROXY,
|
|
28
|
+
sorted: true
|
|
29
|
+
};
|
|
30
|
+
return { inspectOptions, minHeight: logLevels[TL_LEVEL], useJSON: TL_JSON };
|
|
31
|
+
};
|
|
32
|
+
export const createLogger = (options = {}) => {
|
|
33
|
+
const { env, record, stream } = { env: process.env, stream: process.stdout, ...options };
|
|
34
|
+
const { minHeight, inspectOptions, useJSON } = getConfig(env, stream);
|
|
35
|
+
const messages = [];
|
|
36
|
+
const stringify = (data) => {
|
|
37
|
+
switch (typeof data) {
|
|
38
|
+
case 'bigint':
|
|
39
|
+
case 'boolean':
|
|
40
|
+
case 'number':
|
|
41
|
+
case 'symbol':
|
|
42
|
+
return data.toString();
|
|
43
|
+
case 'string':
|
|
44
|
+
return data;
|
|
45
|
+
case 'undefined':
|
|
46
|
+
return 'undefined';
|
|
47
|
+
case 'object':
|
|
48
|
+
if (useJSON)
|
|
49
|
+
return JSONbig.stringify(data);
|
|
50
|
+
case 'function':
|
|
51
|
+
return inspect(data, inspectOptions);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
const getLogFunction = ([level, height]) => {
|
|
55
|
+
const label = logLevelLabels[height];
|
|
56
|
+
return (...message) => {
|
|
57
|
+
if (record)
|
|
58
|
+
messages.push({ level, message });
|
|
59
|
+
if (height < minHeight)
|
|
60
|
+
return;
|
|
61
|
+
const line = message.map(stringify).join(' ');
|
|
62
|
+
const now = new Date().toISOString().replace('T', ' ').replace('Z', '');
|
|
63
|
+
const lines = line.split('\n').map((_) => `${now} ${label} ${_}\n`);
|
|
64
|
+
stream.write(lines.join(''));
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
const logger = Object.fromEntries(Object.entries(logLevels).map((_) => [_[0], getLogFunction(_)]));
|
|
68
|
+
return { messages, ...logger };
|
|
69
|
+
};
|
|
70
|
+
export const logger = createLogger();
|
|
71
|
+
//# sourceMappingURL=TestLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TestLogger.js","sourceRoot":"","sources":["../../src/TestLogger.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * as AssetId from './assetId';
|
|
2
2
|
export * as CslTestUtil from './cslTestUtil';
|
|
3
3
|
export * as TxTestUtil from './txTestUtil';
|
|
4
|
+
export * from './TestLogger';
|
|
4
5
|
export * from './util';
|
|
5
6
|
export * from './createStubStakePoolProvider';
|
|
6
7
|
export * from './stubLogger';
|
package/dist/esm/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,QAAQ,CAAC;AACvB,cAAc,+BAA+B,CAAC;AAC9C,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,cAAc,CAAC;AAC7B,cAAc,QAAQ,CAAC;AACvB,cAAc,+BAA+B,CAAC;AAC9C,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * as AssetId from './assetId';
|
|
2
2
|
export * as CslTestUtil from './cslTestUtil';
|
|
3
3
|
export * as TxTestUtil from './txTestUtil';
|
|
4
|
+
export * from './TestLogger';
|
|
4
5
|
export * from './util';
|
|
5
6
|
export * from './createStubStakePoolProvider';
|
|
6
7
|
export * from './stubLogger';
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,QAAQ,CAAC;AACvB,cAAc,+BAA+B,CAAC;AAC9C,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,cAAc,CAAC;AAC7B,cAAc,QAAQ,CAAC;AACvB,cAAc,+BAA+B,CAAC;AAC9C,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC"}
|