@forgerock/sdk-logger 1.2.0 → 2.0.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/CHANGELOG.md CHANGED
@@ -1,5 +1,25 @@
1
1
  # @forgerock/sdk-logger
2
2
 
3
+ ## 2.0.0
4
+
5
+ ### Major Changes
6
+
7
+ - [#502](https://github.com/ForgeRock/ping-javascript-sdk/pull/502) [`9ad4062`](https://github.com/ForgeRock/ping-javascript-sdk/commit/9ad406268dd568d8d6f6447a07b656e317a9da8d) Thanks [@ryanbas21](https://github.com/ryanbas21)! - releasing version 2 of the ping javascript sdk
8
+
9
+ ### Patch Changes
10
+
11
+ - [#528](https://github.com/ForgeRock/ping-javascript-sdk/pull/528) [`ad81c13`](https://github.com/ForgeRock/ping-javascript-sdk/commit/ad81c13ab2b863be46a98803e48754b0e2b3746b) Thanks [@ancheetah](https://github.com/ancheetah)! - Fixes double logging when using custom logger. Custom logger should override default console logs.
12
+
13
+ - [#526](https://github.com/ForgeRock/ping-javascript-sdk/pull/526) [`5a9ea40`](https://github.com/ForgeRock/ping-javascript-sdk/commit/5a9ea4079af4698f2d7df4bb5e7b40261aece15c) Thanks [@ancheetah](https://github.com/ancheetah)! - Update READMES. Fix types and comments.
14
+
15
+ ## 1.3.0
16
+
17
+ ### Minor Changes
18
+
19
+ - [#412](https://github.com/ForgeRock/ping-javascript-sdk/pull/412) [`b0f4368`](https://github.com/ForgeRock/ping-javascript-sdk/commit/b0f4368637a788c5472587f5232678312a7eabfe) Thanks [@ryanbas21](https://github.com/ryanbas21)! - feat: Update SDK logger
20
+ - Updated ESLint configurations for consistent code style and linting rules.
21
+ - Ensured compatibility with `verbatimModuleSyntax` by correcting type-only imports and module exports.
22
+
3
23
  ## 1.2.0
4
24
 
5
25
  ### Minor Changes
package/README.md CHANGED
@@ -7,18 +7,19 @@ A flexible and configurable logging utility for the Ping Identity JavaScript SDK
7
7
  - Multiple log levels (`error`, `warn`, `info`, `debug`, `none`)
8
8
  - Ability to change log level at runtime
9
9
  - Support for multiple arguments in log messages
10
+ - Custom logger integration (bring your own logger implementation)
10
11
  - TypeScript support with proper type definitions
11
12
 
12
13
  ## Installation
13
14
 
14
15
  ```bash
15
- npm install @ping-identity/effects-logger
16
+ npm install @forgerock/sdk-logger
16
17
  ```
17
18
 
18
19
  ## Usage
19
20
 
20
21
  ```typescript
21
- import { logger } from '@ping-identity/effects-logger';
22
+ import { logger } from '@forgerock/sdk-logger';
22
23
 
23
24
  // Initialize the logger with a specific log level
24
25
  const log = logger({ level: 'info' });
@@ -38,6 +39,28 @@ log.changeLevel('none'); // Disable all logs
38
39
  log.error('This error will not be logged');
39
40
  ```
40
41
 
42
+ ### Using a Custom Logger
43
+
44
+ You can provide your own logger implementation (e.g., Sentry, LogRocket, or another service):
45
+
46
+ ```typescript
47
+ import { logger } from '@forgerock/sdk-logger';
48
+
49
+ const customLogger = {
50
+ error: (...args) => /* custom logging */,
51
+ warn: (...args) => /* custom logging */,
52
+ info: (...args) => /* custom logging */,
53
+ debug: (...args) => /* custom logging */,
54
+ };
55
+
56
+ // Initialize the logger with custom implementation
57
+ const log = logger({ level: 'info', custom: customLogger });
58
+
59
+ // Use the logger
60
+ log.error('Critical error:', new Error('Something failed'));
61
+ log.info('User logged in successfully');
62
+ ```
63
+
41
64
  ## Log Levels
42
65
 
43
66
  The logger supports the following log levels (in order of severity):
@@ -52,13 +75,14 @@ When a log level is set, only messages of that level or higher severity will be
52
75
 
53
76
  ## API Reference
54
77
 
55
- ### `logger({ level })`
78
+ ### `logger({ level, custom? })`
56
79
 
57
80
  Initializes a new logger instance.
58
81
 
59
82
  **Parameters:**
60
83
 
61
84
  - `level`: The initial log level (`'error'`, `'warn'`, `'info'`, `'debug'`, or `'none'`)
85
+ - `custom` (optional): A `CustomLogger` object to use instead of the default console implementation
62
86
 
63
87
  **Returns:** A logger instance with the following methods:
64
88
 
@@ -68,10 +92,27 @@ Initializes a new logger instance.
68
92
  - `debug(...args)`: Log a debug message
69
93
  - `changeLevel(level)`: Change the current log level
70
94
 
95
+ ### `CustomLogger` Interface
96
+
97
+ Defines the interface for custom logger implementations:
98
+
99
+ ```typescript
100
+ interface CustomLogger {
101
+ error: (...args: LogMessage[]) => void;
102
+ warn: (...args: LogMessage[]) => void;
103
+ info: (...args: LogMessage[]) => void;
104
+ debug: (...args: LogMessage[]) => void;
105
+ }
106
+
107
+ type LogMessage = string | number | object;
108
+ ```
109
+
110
+ When a custom logger is provided, all log calls will be delegated to your implementation. If no custom logger is provided, the logger falls back to the browser's native `console` methods.
111
+
71
112
  ## Building
72
113
 
73
- Run `nx build logger` to build the library.
114
+ Run `nx build sdk-logger` to build the library.
74
115
 
75
116
  ## Running unit tests
76
117
 
77
- Run `nx test @forgerock/sdk-logger` to execute the unit tests via [Vitest](https://vitest.dev/).
118
+ Run `nx test sdk-logger` to execute the unit tests via [Vitest](https://vitest.dev/).
@@ -0,0 +1,224 @@
1
+ body, html {
2
+ margin:0; padding: 0;
3
+ height: 100%;
4
+ }
5
+ body {
6
+ font-family: Helvetica Neue, Helvetica, Arial;
7
+ font-size: 14px;
8
+ color:#333;
9
+ }
10
+ .small { font-size: 12px; }
11
+ *, *:after, *:before {
12
+ -webkit-box-sizing:border-box;
13
+ -moz-box-sizing:border-box;
14
+ box-sizing:border-box;
15
+ }
16
+ h1 { font-size: 20px; margin: 0;}
17
+ h2 { font-size: 14px; }
18
+ pre {
19
+ font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
20
+ margin: 0;
21
+ padding: 0;
22
+ -moz-tab-size: 2;
23
+ -o-tab-size: 2;
24
+ tab-size: 2;
25
+ }
26
+ a { color:#0074D9; text-decoration:none; }
27
+ a:hover { text-decoration:underline; }
28
+ .strong { font-weight: bold; }
29
+ .space-top1 { padding: 10px 0 0 0; }
30
+ .pad2y { padding: 20px 0; }
31
+ .pad1y { padding: 10px 0; }
32
+ .pad2x { padding: 0 20px; }
33
+ .pad2 { padding: 20px; }
34
+ .pad1 { padding: 10px; }
35
+ .space-left2 { padding-left:55px; }
36
+ .space-right2 { padding-right:20px; }
37
+ .center { text-align:center; }
38
+ .clearfix { display:block; }
39
+ .clearfix:after {
40
+ content:'';
41
+ display:block;
42
+ height:0;
43
+ clear:both;
44
+ visibility:hidden;
45
+ }
46
+ .fl { float: left; }
47
+ @media only screen and (max-width:640px) {
48
+ .col3 { width:100%; max-width:100%; }
49
+ .hide-mobile { display:none!important; }
50
+ }
51
+
52
+ .quiet {
53
+ color: #7f7f7f;
54
+ color: rgba(0,0,0,0.5);
55
+ }
56
+ .quiet a { opacity: 0.7; }
57
+
58
+ .fraction {
59
+ font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
60
+ font-size: 10px;
61
+ color: #555;
62
+ background: #E8E8E8;
63
+ padding: 4px 5px;
64
+ border-radius: 3px;
65
+ vertical-align: middle;
66
+ }
67
+
68
+ div.path a:link, div.path a:visited { color: #333; }
69
+ table.coverage {
70
+ border-collapse: collapse;
71
+ margin: 10px 0 0 0;
72
+ padding: 0;
73
+ }
74
+
75
+ table.coverage td {
76
+ margin: 0;
77
+ padding: 0;
78
+ vertical-align: top;
79
+ }
80
+ table.coverage td.line-count {
81
+ text-align: right;
82
+ padding: 0 5px 0 20px;
83
+ }
84
+ table.coverage td.line-coverage {
85
+ text-align: right;
86
+ padding-right: 10px;
87
+ min-width:20px;
88
+ }
89
+
90
+ table.coverage td span.cline-any {
91
+ display: inline-block;
92
+ padding: 0 5px;
93
+ width: 100%;
94
+ }
95
+ .missing-if-branch {
96
+ display: inline-block;
97
+ margin-right: 5px;
98
+ border-radius: 3px;
99
+ position: relative;
100
+ padding: 0 4px;
101
+ background: #333;
102
+ color: yellow;
103
+ }
104
+
105
+ .skip-if-branch {
106
+ display: none;
107
+ margin-right: 10px;
108
+ position: relative;
109
+ padding: 0 4px;
110
+ background: #ccc;
111
+ color: white;
112
+ }
113
+ .missing-if-branch .typ, .skip-if-branch .typ {
114
+ color: inherit !important;
115
+ }
116
+ .coverage-summary {
117
+ border-collapse: collapse;
118
+ width: 100%;
119
+ }
120
+ .coverage-summary tr { border-bottom: 1px solid #bbb; }
121
+ .keyline-all { border: 1px solid #ddd; }
122
+ .coverage-summary td, .coverage-summary th { padding: 10px; }
123
+ .coverage-summary tbody { border: 1px solid #bbb; }
124
+ .coverage-summary td { border-right: 1px solid #bbb; }
125
+ .coverage-summary td:last-child { border-right: none; }
126
+ .coverage-summary th {
127
+ text-align: left;
128
+ font-weight: normal;
129
+ white-space: nowrap;
130
+ }
131
+ .coverage-summary th.file { border-right: none !important; }
132
+ .coverage-summary th.pct { }
133
+ .coverage-summary th.pic,
134
+ .coverage-summary th.abs,
135
+ .coverage-summary td.pct,
136
+ .coverage-summary td.abs { text-align: right; }
137
+ .coverage-summary td.file { white-space: nowrap; }
138
+ .coverage-summary td.pic { min-width: 120px !important; }
139
+ .coverage-summary tfoot td { }
140
+
141
+ .coverage-summary .sorter {
142
+ height: 10px;
143
+ width: 7px;
144
+ display: inline-block;
145
+ margin-left: 0.5em;
146
+ background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
147
+ }
148
+ .coverage-summary .sorted .sorter {
149
+ background-position: 0 -20px;
150
+ }
151
+ .coverage-summary .sorted-desc .sorter {
152
+ background-position: 0 -10px;
153
+ }
154
+ .status-line { height: 10px; }
155
+ /* yellow */
156
+ .cbranch-no { background: yellow !important; color: #111; }
157
+ /* dark red */
158
+ .red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
159
+ .low .chart { border:1px solid #C21F39 }
160
+ .highlighted,
161
+ .highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
162
+ background: #C21F39 !important;
163
+ }
164
+ /* medium red */
165
+ .cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
166
+ /* light red */
167
+ .low, .cline-no { background:#FCE1E5 }
168
+ /* light green */
169
+ .high, .cline-yes { background:rgb(230,245,208) }
170
+ /* medium green */
171
+ .cstat-yes { background:rgb(161,215,106) }
172
+ /* dark green */
173
+ .status-line.high, .high .cover-fill { background:rgb(77,146,33) }
174
+ .high .chart { border:1px solid rgb(77,146,33) }
175
+ /* dark yellow (gold) */
176
+ .status-line.medium, .medium .cover-fill { background: #f9cd0b; }
177
+ .medium .chart { border:1px solid #f9cd0b; }
178
+ /* light yellow */
179
+ .medium { background: #fff4c2; }
180
+
181
+ .cstat-skip { background: #ddd; color: #111; }
182
+ .fstat-skip { background: #ddd; color: #111 !important; }
183
+ .cbranch-skip { background: #ddd !important; color: #111; }
184
+
185
+ span.cline-neutral { background: #eaeaea; }
186
+
187
+ .coverage-summary td.empty {
188
+ opacity: .5;
189
+ padding-top: 4px;
190
+ padding-bottom: 4px;
191
+ line-height: 1;
192
+ color: #888;
193
+ }
194
+
195
+ .cover-fill, .cover-empty {
196
+ display:inline-block;
197
+ height: 12px;
198
+ }
199
+ .chart {
200
+ line-height: 0;
201
+ }
202
+ .cover-empty {
203
+ background: white;
204
+ }
205
+ .cover-full {
206
+ border-right: none !important;
207
+ }
208
+ pre.prettyprint {
209
+ border: none !important;
210
+ padding: 0 !important;
211
+ margin: 0 !important;
212
+ }
213
+ .com { color: #999 !important; }
214
+ .ignore-none { color: #999; font-weight: normal; }
215
+
216
+ .wrapper {
217
+ min-height: 100%;
218
+ height: auto !important;
219
+ height: 100%;
220
+ margin: 0 auto -48px;
221
+ }
222
+ .footer, .push {
223
+ height: 48px;
224
+ }
@@ -0,0 +1,87 @@
1
+ /* eslint-disable */
2
+ var jumpToCode = (function init() {
3
+ // Classes of code we would like to highlight in the file view
4
+ var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
5
+
6
+ // Elements to highlight in the file listing view
7
+ var fileListingElements = ['td.pct.low'];
8
+
9
+ // We don't want to select elements that are direct descendants of another match
10
+ var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
11
+
12
+ // Selector that finds elements on the page to which we can jump
13
+ var selector =
14
+ fileListingElements.join(', ') +
15
+ ', ' +
16
+ notSelector +
17
+ missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
18
+
19
+ // The NodeList of matching elements
20
+ var missingCoverageElements = document.querySelectorAll(selector);
21
+
22
+ var currentIndex;
23
+
24
+ function toggleClass(index) {
25
+ missingCoverageElements
26
+ .item(currentIndex)
27
+ .classList.remove('highlighted');
28
+ missingCoverageElements.item(index).classList.add('highlighted');
29
+ }
30
+
31
+ function makeCurrent(index) {
32
+ toggleClass(index);
33
+ currentIndex = index;
34
+ missingCoverageElements.item(index).scrollIntoView({
35
+ behavior: 'smooth',
36
+ block: 'center',
37
+ inline: 'center'
38
+ });
39
+ }
40
+
41
+ function goToPrevious() {
42
+ var nextIndex = 0;
43
+ if (typeof currentIndex !== 'number' || currentIndex === 0) {
44
+ nextIndex = missingCoverageElements.length - 1;
45
+ } else if (missingCoverageElements.length > 1) {
46
+ nextIndex = currentIndex - 1;
47
+ }
48
+
49
+ makeCurrent(nextIndex);
50
+ }
51
+
52
+ function goToNext() {
53
+ var nextIndex = 0;
54
+
55
+ if (
56
+ typeof currentIndex === 'number' &&
57
+ currentIndex < missingCoverageElements.length - 1
58
+ ) {
59
+ nextIndex = currentIndex + 1;
60
+ }
61
+
62
+ makeCurrent(nextIndex);
63
+ }
64
+
65
+ return function jump(event) {
66
+ if (
67
+ document.getElementById('fileSearch') === document.activeElement &&
68
+ document.activeElement != null
69
+ ) {
70
+ // if we're currently focused on the search input, we don't want to navigate
71
+ return;
72
+ }
73
+
74
+ switch (event.which) {
75
+ case 78: // n
76
+ case 74: // j
77
+ goToNext();
78
+ break;
79
+ case 66: // b
80
+ case 75: // k
81
+ case 80: // p
82
+ goToPrevious();
83
+ break;
84
+ }
85
+ };
86
+ })();
87
+ window.addEventListener('keydown', jumpToCode);
@@ -0,0 +1,5 @@
1
+ {"/home/workflows/workspace/packages/sdk-effects/logger/src/index.ts": {"path":"/home/workflows/workspace/packages/sdk-effects/logger/src/index.ts","all":true,"statementMap":{"0":{"start":{"line":1,"column":0},"end":{"line":1,"column":40}},"1":{"start":{"line":2,"column":0},"end":{"line":2,"column":38}}},"s":{"0":0,"1":0},"branchMap":{"0":{"type":"branch","line":1,"loc":{"start":{"line":1,"column":0},"end":{"line":2,"column":-1}},"locations":[{"start":{"line":1,"column":0},"end":{"line":2,"column":-1}}]}},"b":{"0":[0]},"fnMap":{"0":{"name":"(empty-report)","decl":{"start":{"line":1,"column":0},"end":{"line":2,"column":-1}},"loc":{"start":{"line":1,"column":0},"end":{"line":2,"column":-1}},"line":1}},"f":{"0":0}}
2
+ ,"/home/workflows/workspace/packages/sdk-effects/logger/src/types.ts": {"path":"/home/workflows/workspace/packages/sdk-effects/logger/src/types.ts","all":true,"statementMap":{"0":{"start":{"line":1,"column":0},"end":{"line":1,"column":53}}},"s":{"0":0},"branchMap":{"0":{"type":"branch","line":1,"loc":{"start":{"line":1,"column":53},"end":{"line":1,"column":53}},"locations":[{"start":{"line":1,"column":53},"end":{"line":1,"column":53}}]}},"b":{"0":[0]},"fnMap":{"0":{"name":"(empty-report)","decl":{"start":{"line":1,"column":53},"end":{"line":1,"column":53}},"loc":{"start":{"line":1,"column":53},"end":{"line":1,"column":53}},"line":1}},"f":{"0":0}}
3
+ ,"/home/workflows/workspace/packages/sdk-effects/logger/src/lib/logger.effects.ts": {"path":"/home/workflows/workspace/packages/sdk-effects/logger/src/lib/logger.effects.ts","all":false,"statementMap":{"9":{"start":{"line":10,"column":0},"end":{"line":10,"column":76}},"10":{"start":{"line":11,"column":0},"end":{"line":11,"column":50}},"11":{"start":{"line":12,"column":0},"end":{"line":12,"column":31}},"14":{"start":{"line":15,"column":0},"end":{"line":15,"column":24}},"15":{"start":{"line":16,"column":0},"end":{"line":16,"column":37}},"16":{"start":{"line":17,"column":0},"end":{"line":17,"column":69}},"17":{"start":{"line":18,"column":0},"end":{"line":18,"column":99}},"18":{"start":{"line":19,"column":0},"end":{"line":19,"column":99}},"19":{"start":{"line":20,"column":0},"end":{"line":20,"column":37}},"20":{"start":{"line":21,"column":0},"end":{"line":21,"column":69}},"21":{"start":{"line":22,"column":0},"end":{"line":22,"column":4}},"24":{"start":{"line":25,"column":0},"end":{"line":25,"column":75}},"25":{"start":{"line":26,"column":0},"end":{"line":26,"column":53}},"26":{"start":{"line":27,"column":0},"end":{"line":27,"column":15}},"27":{"start":{"line":28,"column":0},"end":{"line":28,"column":14}},"28":{"start":{"line":29,"column":0},"end":{"line":29,"column":14}},"29":{"start":{"line":30,"column":0},"end":{"line":30,"column":15}},"30":{"start":{"line":31,"column":0},"end":{"line":31,"column":15}},"31":{"start":{"line":32,"column":0},"end":{"line":32,"column":6}},"33":{"start":{"line":34,"column":0},"end":{"line":34,"column":86}},"34":{"start":{"line":35,"column":0},"end":{"line":35,"column":4}},"37":{"start":{"line":38,"column":0},"end":{"line":38,"column":10}},"38":{"start":{"line":39,"column":0},"end":{"line":39,"column":39}},"39":{"start":{"line":40,"column":0},"end":{"line":40,"column":23}},"40":{"start":{"line":41,"column":0},"end":{"line":41,"column":6}},"41":{"start":{"line":42,"column":0},"end":{"line":42,"column":39}},"42":{"start":{"line":43,"column":0},"end":{"line":43,"column":41}},"43":{"start":{"line":44,"column":0},"end":{"line":44,"column":36}},"44":{"start":{"line":45,"column":0},"end":{"line":45,"column":7}},"45":{"start":{"line":46,"column":0},"end":{"line":46,"column":6}},"46":{"start":{"line":47,"column":0},"end":{"line":47,"column":38}},"47":{"start":{"line":48,"column":0},"end":{"line":48,"column":40}},"48":{"start":{"line":49,"column":0},"end":{"line":49,"column":35}},"49":{"start":{"line":50,"column":0},"end":{"line":50,"column":7}},"50":{"start":{"line":51,"column":0},"end":{"line":51,"column":6}},"51":{"start":{"line":52,"column":0},"end":{"line":52,"column":38}},"52":{"start":{"line":53,"column":0},"end":{"line":53,"column":40}},"53":{"start":{"line":54,"column":0},"end":{"line":54,"column":35}},"54":{"start":{"line":55,"column":0},"end":{"line":55,"column":7}},"55":{"start":{"line":56,"column":0},"end":{"line":56,"column":6}},"56":{"start":{"line":57,"column":0},"end":{"line":57,"column":39}},"57":{"start":{"line":58,"column":0},"end":{"line":58,"column":41}},"58":{"start":{"line":59,"column":0},"end":{"line":59,"column":36}},"59":{"start":{"line":60,"column":0},"end":{"line":60,"column":7}},"60":{"start":{"line":61,"column":0},"end":{"line":61,"column":6}},"61":{"start":{"line":62,"column":0},"end":{"line":62,"column":4}},"62":{"start":{"line":63,"column":0},"end":{"line":63,"column":1}}},"s":{"9":1,"10":7,"11":7,"14":7,"15":7,"16":2,"17":7,"18":7,"19":7,"20":2,"21":7,"24":7,"25":14,"26":14,"27":14,"28":14,"29":14,"30":14,"31":14,"33":14,"34":14,"37":7,"38":7,"39":1,"40":1,"41":7,"42":3,"43":2,"44":2,"45":3,"46":7,"47":4,"48":1,"49":1,"50":4,"51":7,"52":3,"53":1,"54":1,"55":3,"56":7,"57":4,"58":2,"59":2,"60":4,"61":7,"62":7},"branchMap":{"0":{"type":"branch","line":10,"loc":{"start":{"line":10,"column":7},"end":{"line":63,"column":1}},"locations":[{"start":{"line":10,"column":7},"end":{"line":63,"column":1}}]},"1":{"type":"branch","line":11,"loc":{"start":{"line":11,"column":34},"end":{"line":11,"column":50}},"locations":[{"start":{"line":11,"column":34},"end":{"line":11,"column":50}}]},"2":{"type":"branch","line":16,"loc":{"start":{"line":16,"column":11},"end":{"line":17,"column":69}},"locations":[{"start":{"line":16,"column":11},"end":{"line":17,"column":69}}]},"3":{"type":"branch","line":17,"loc":{"start":{"line":17,"column":6},"end":{"line":17,"column":22}},"locations":[{"start":{"line":17,"column":6},"end":{"line":17,"column":22}}]},"4":{"type":"branch","line":17,"loc":{"start":{"line":17,"column":14},"end":{"line":17,"column":46}},"locations":[{"start":{"line":17,"column":14},"end":{"line":17,"column":46}}]},"5":{"type":"branch","line":18,"loc":{"start":{"line":18,"column":10},"end":{"line":18,"column":99}},"locations":[{"start":{"line":18,"column":10},"end":{"line":18,"column":99}}]},"6":{"type":"branch","line":18,"loc":{"start":{"line":18,"column":38},"end":{"line":18,"column":53}},"locations":[{"start":{"line":18,"column":38},"end":{"line":18,"column":53}}]},"7":{"type":"branch","line":18,"loc":{"start":{"line":18,"column":46},"end":{"line":18,"column":76}},"locations":[{"start":{"line":18,"column":46},"end":{"line":18,"column":76}}]},"8":{"type":"branch","line":19,"loc":{"start":{"line":19,"column":10},"end":{"line":19,"column":99}},"locations":[{"start":{"line":19,"column":10},"end":{"line":19,"column":99}}]},"9":{"type":"branch","line":19,"loc":{"start":{"line":19,"column":38},"end":{"line":19,"column":53}},"locations":[{"start":{"line":19,"column":38},"end":{"line":19,"column":53}}]},"10":{"type":"branch","line":19,"loc":{"start":{"line":19,"column":46},"end":{"line":19,"column":76}},"locations":[{"start":{"line":19,"column":46},"end":{"line":19,"column":76}}]},"11":{"type":"branch","line":20,"loc":{"start":{"line":20,"column":11},"end":{"line":21,"column":69}},"locations":[{"start":{"line":20,"column":11},"end":{"line":21,"column":69}}]},"12":{"type":"branch","line":21,"loc":{"start":{"line":21,"column":6},"end":{"line":21,"column":22}},"locations":[{"start":{"line":21,"column":6},"end":{"line":21,"column":22}}]},"13":{"type":"branch","line":21,"loc":{"start":{"line":21,"column":14},"end":{"line":21,"column":46}},"locations":[{"start":{"line":21,"column":14},"end":{"line":21,"column":46}}]},"14":{"type":"branch","line":25,"loc":{"start":{"line":25,"column":20},"end":{"line":35,"column":4}},"locations":[{"start":{"line":25,"column":20},"end":{"line":35,"column":4}}]},"15":{"type":"branch","line":34,"loc":{"start":{"line":34,"column":51},"end":{"line":34,"column":86}},"locations":[{"start":{"line":34,"column":51},"end":{"line":34,"column":86}}]},"16":{"type":"branch","line":39,"loc":{"start":{"line":39,"column":17},"end":{"line":41,"column":6}},"locations":[{"start":{"line":39,"column":17},"end":{"line":41,"column":6}}]},"17":{"type":"branch","line":42,"loc":{"start":{"line":42,"column":11},"end":{"line":46,"column":6}},"locations":[{"start":{"line":42,"column":11},"end":{"line":46,"column":6}}]},"18":{"type":"branch","line":43,"loc":{"start":{"line":43,"column":40},"end":{"line":45,"column":7}},"locations":[{"start":{"line":43,"column":40},"end":{"line":45,"column":7}}]},"19":{"type":"branch","line":47,"loc":{"start":{"line":47,"column":10},"end":{"line":51,"column":6}},"locations":[{"start":{"line":47,"column":10},"end":{"line":51,"column":6}}]},"20":{"type":"branch","line":48,"loc":{"start":{"line":48,"column":39},"end":{"line":50,"column":7}},"locations":[{"start":{"line":48,"column":39},"end":{"line":50,"column":7}}]},"21":{"type":"branch","line":52,"loc":{"start":{"line":52,"column":10},"end":{"line":56,"column":6}},"locations":[{"start":{"line":52,"column":10},"end":{"line":56,"column":6}}]},"22":{"type":"branch","line":53,"loc":{"start":{"line":53,"column":39},"end":{"line":55,"column":7}},"locations":[{"start":{"line":53,"column":39},"end":{"line":55,"column":7}}]},"23":{"type":"branch","line":57,"loc":{"start":{"line":57,"column":11},"end":{"line":61,"column":6}},"locations":[{"start":{"line":57,"column":11},"end":{"line":61,"column":6}}]},"24":{"type":"branch","line":58,"loc":{"start":{"line":58,"column":40},"end":{"line":60,"column":7}},"locations":[{"start":{"line":58,"column":40},"end":{"line":60,"column":7}}]}},"b":{"0":[7],"1":[0],"2":[2],"3":[0],"4":[0],"5":[1],"6":[0],"7":[0],"8":[1],"9":[0],"10":[0],"11":[2],"12":[0],"13":[0],"14":[14],"15":[6],"16":[1],"17":[3],"18":[2],"19":[4],"20":[1],"21":[3],"22":[1],"23":[4],"24":[2]},"fnMap":{"0":{"name":"logger","decl":{"start":{"line":10,"column":7},"end":{"line":63,"column":1}},"loc":{"start":{"line":10,"column":7},"end":{"line":63,"column":1}},"line":10},"1":{"name":"error","decl":{"start":{"line":16,"column":11},"end":{"line":17,"column":69}},"loc":{"start":{"line":16,"column":11},"end":{"line":17,"column":69}},"line":16},"2":{"name":"warn","decl":{"start":{"line":18,"column":10},"end":{"line":18,"column":99}},"loc":{"start":{"line":18,"column":10},"end":{"line":18,"column":99}},"line":18},"3":{"name":"info","decl":{"start":{"line":19,"column":10},"end":{"line":19,"column":99}},"loc":{"start":{"line":19,"column":10},"end":{"line":19,"column":99}},"line":19},"4":{"name":"debug","decl":{"start":{"line":20,"column":11},"end":{"line":21,"column":69}},"loc":{"start":{"line":20,"column":11},"end":{"line":21,"column":69}},"line":20},"5":{"name":"shouldLog","decl":{"start":{"line":25,"column":20},"end":{"line":35,"column":4}},"loc":{"start":{"line":25,"column":20},"end":{"line":35,"column":4}},"line":25},"6":{"name":"changeLevel","decl":{"start":{"line":39,"column":17},"end":{"line":41,"column":6}},"loc":{"start":{"line":39,"column":17},"end":{"line":41,"column":6}},"line":39},"7":{"name":"error","decl":{"start":{"line":42,"column":11},"end":{"line":46,"column":6}},"loc":{"start":{"line":42,"column":11},"end":{"line":46,"column":6}},"line":42},"8":{"name":"warn","decl":{"start":{"line":47,"column":10},"end":{"line":51,"column":6}},"loc":{"start":{"line":47,"column":10},"end":{"line":51,"column":6}},"line":47},"9":{"name":"info","decl":{"start":{"line":52,"column":10},"end":{"line":56,"column":6}},"loc":{"start":{"line":52,"column":10},"end":{"line":56,"column":6}},"line":52},"10":{"name":"debug","decl":{"start":{"line":57,"column":11},"end":{"line":61,"column":6}},"loc":{"start":{"line":57,"column":11},"end":{"line":61,"column":6}},"line":57}},"f":{"0":7,"1":2,"2":1,"3":1,"4":2,"5":14,"6":1,"7":3,"8":4,"9":3,"10":4}}
4
+ ,"/home/workflows/workspace/packages/sdk-effects/logger/src/lib/logger.types.ts": {"path":"/home/workflows/workspace/packages/sdk-effects/logger/src/lib/logger.types.ts","all":true,"statementMap":{},"s":{},"branchMap":{"0":{"type":"branch","line":1,"loc":{"start":{"line":1,"column":572},"end":{"line":19,"column":50}},"locations":[{"start":{"line":1,"column":572},"end":{"line":19,"column":50}}]}},"b":{"0":[1]},"fnMap":{"0":{"name":"(empty-report)","decl":{"start":{"line":1,"column":572},"end":{"line":19,"column":50}},"loc":{"start":{"line":1,"column":572},"end":{"line":19,"column":50}},"line":1}},"f":{"0":1}}
5
+ }
Binary file
@@ -0,0 +1,131 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for All files</title>
7
+ <meta charset="utf-8" />
8
+ <link rel="stylesheet" href="prettify.css" />
9
+ <link rel="stylesheet" href="base.css" />
10
+ <link rel="shortcut icon" type="image/x-icon" href="favicon.png" />
11
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
12
+ <style type='text/css'>
13
+ .coverage-summary .sorter {
14
+ background-image: url(sort-arrow-sprite.png);
15
+ }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <div class='wrapper'>
21
+ <div class='pad1'>
22
+ <h1>All files</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">94% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>47/50</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">60.71% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>17/28</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">85.71% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>12/14</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">94% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>47/50</span>
50
+ </div>
51
+
52
+
53
+ </div>
54
+ <p class="quiet">
55
+ Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
+ </p>
57
+ <template id="filterTemplate">
58
+ <div class="quiet">
59
+ Filter:
60
+ <input type="search" id="fileSearch">
61
+ </div>
62
+ </template>
63
+ </div>
64
+ <div class='status-line high'></div>
65
+ <div class="pad1">
66
+ <table class="coverage-summary">
67
+ <thead>
68
+ <tr>
69
+ <th data-col="file" data-fmt="html" data-html="true" class="file">File</th>
70
+ <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th>
71
+ <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th>
72
+ <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th>
73
+ <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th>
74
+ <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th>
75
+ <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th>
76
+ <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th>
77
+ <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th>
78
+ <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th>
79
+ </tr>
80
+ </thead>
81
+ <tbody><tr>
82
+ <td class="file low" data-value="src"><a href="src/index.html">src</a></td>
83
+ <td data-value="0" class="pic low">
84
+ <div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
85
+ </td>
86
+ <td data-value="0" class="pct low">0%</td>
87
+ <td data-value="3" class="abs low">0/3</td>
88
+ <td data-value="0" class="pct low">0%</td>
89
+ <td data-value="2" class="abs low">0/2</td>
90
+ <td data-value="0" class="pct low">0%</td>
91
+ <td data-value="2" class="abs low">0/2</td>
92
+ <td data-value="0" class="pct low">0%</td>
93
+ <td data-value="3" class="abs low">0/3</td>
94
+ </tr>
95
+
96
+ <tr>
97
+ <td class="file high" data-value="src/lib"><a href="src/lib/index.html">src/lib</a></td>
98
+ <td data-value="100" class="pic high">
99
+ <div class="chart"><div class="cover-fill cover-full" style="width: 100%"></div><div class="cover-empty" style="width: 0%"></div></div>
100
+ </td>
101
+ <td data-value="100" class="pct high">100%</td>
102
+ <td data-value="47" class="abs high">47/47</td>
103
+ <td data-value="65.38" class="pct medium">65.38%</td>
104
+ <td data-value="26" class="abs medium">17/26</td>
105
+ <td data-value="100" class="pct high">100%</td>
106
+ <td data-value="12" class="abs high">12/12</td>
107
+ <td data-value="100" class="pct high">100%</td>
108
+ <td data-value="47" class="abs high">47/47</td>
109
+ </tr>
110
+
111
+ </tbody>
112
+ </table>
113
+ </div>
114
+ <div class='push'></div><!-- for sticky footer -->
115
+ </div><!-- /wrapper -->
116
+ <div class='footer quiet pad2 space-top1 center small'>
117
+ Code coverage generated by
118
+ <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
119
+ at 2026-03-19T17:04:16.096Z
120
+ </div>
121
+ <script src="prettify.js"></script>
122
+ <script>
123
+ window.onload = function () {
124
+ prettyPrint();
125
+ };
126
+ </script>
127
+ <script src="sorter.js"></script>
128
+ <script src="block-navigation.js"></script>
129
+ </body>
130
+ </html>
131
+
@@ -0,0 +1 @@
1
+ .pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee}