@mecanizou/telemetry-hub 1.0.0 → 1.0.2

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 (95) hide show
  1. package/.github/workflows/pull_request.yml +32 -32
  2. package/.github/workflows/release.yml +129 -129
  3. package/.prettierignore +4 -4
  4. package/CHANGELOG.md +14 -0
  5. package/DOCS_GUIDE.md +151 -0
  6. package/README.md +248 -0
  7. package/dist/core/__tests__/logger-types.test.d.ts +1 -0
  8. package/dist/core/__tests__/logger-types.test.js +325 -0
  9. package/dist/core/__tests__/logger.test.d.ts +1 -0
  10. package/dist/core/__tests__/logger.test.js +337 -0
  11. package/dist/core/__tests__/tracer.test.d.ts +1 -0
  12. package/dist/core/__tests__/tracer.test.js +330 -0
  13. package/dist/core/index.d.ts +4 -0
  14. package/dist/core/index.js +8 -0
  15. package/dist/core/logger-types.d.ts +43 -0
  16. package/dist/core/logger-types.js +3 -0
  17. package/dist/core/logger.d.ts +13 -0
  18. package/dist/core/logger.js +123 -0
  19. package/dist/core/tracer-types.d.ts +50 -0
  20. package/dist/core/tracer-types.js +3 -0
  21. package/dist/core/tracer.d.ts +10 -0
  22. package/dist/core/tracer.js +114 -0
  23. package/dist/index.d.ts +3 -1
  24. package/dist/index.js +4 -2
  25. package/dist/sst/__tests__/telemetry.test.d.ts +1 -0
  26. package/dist/sst/__tests__/telemetry.test.js +138 -0
  27. package/dist/sst/index.d.ts +1 -0
  28. package/dist/sst/index.js +18 -0
  29. package/dist/sst/middy/index.d.ts +1 -0
  30. package/dist/sst/middy/index.js +18 -0
  31. package/dist/sst/middy/middleware.d.ts +5 -0
  32. package/dist/sst/middy/middleware.js +157 -0
  33. package/dist/sst/telemetry.d.ts +4 -0
  34. package/dist/sst/telemetry.js +121 -0
  35. package/dist/telemetry/core/__tests__/logger-types.test.d.ts +1 -0
  36. package/dist/telemetry/core/__tests__/logger-types.test.js +325 -0
  37. package/dist/telemetry/core/__tests__/logger.test.d.ts +1 -0
  38. package/dist/telemetry/core/__tests__/logger.test.js +337 -0
  39. package/dist/telemetry/core/__tests__/tracer.test.d.ts +1 -0
  40. package/dist/telemetry/core/__tests__/tracer.test.js +330 -0
  41. package/dist/telemetry/core/index.d.ts +4 -0
  42. package/dist/telemetry/core/index.js +8 -0
  43. package/dist/telemetry/core/logger-types.d.ts +43 -0
  44. package/dist/telemetry/core/logger-types.js +3 -0
  45. package/dist/telemetry/core/logger.d.ts +13 -0
  46. package/dist/telemetry/core/logger.js +123 -0
  47. package/dist/telemetry/core/tracer-types.d.ts +50 -0
  48. package/dist/telemetry/core/tracer-types.js +3 -0
  49. package/dist/telemetry/core/tracer.d.ts +10 -0
  50. package/dist/telemetry/core/tracer.js +114 -0
  51. package/dist/telemetry/index.d.ts +3 -0
  52. package/dist/telemetry/index.js +20 -0
  53. package/dist/telemetry/sst/__tests__/telemetry.test.d.ts +1 -0
  54. package/dist/telemetry/sst/__tests__/telemetry.test.js +138 -0
  55. package/dist/telemetry/sst/index.d.ts +1 -0
  56. package/dist/telemetry/sst/index.js +18 -0
  57. package/dist/telemetry/sst/middy/index.d.ts +1 -0
  58. package/dist/telemetry/sst/middy/index.js +18 -0
  59. package/dist/telemetry/sst/middy/middleware.d.ts +5 -0
  60. package/dist/telemetry/sst/middy/middleware.js +157 -0
  61. package/dist/telemetry/sst/telemetry.d.ts +4 -0
  62. package/dist/telemetry/sst/telemetry.js +121 -0
  63. package/dist/telemetry/tsed/__tests__/config.test.d.ts +1 -0
  64. package/dist/telemetry/tsed/__tests__/config.test.js +146 -0
  65. package/dist/telemetry/tsed/__tests__/service.test.d.ts +1 -0
  66. package/dist/telemetry/tsed/__tests__/service.test.js +63 -0
  67. package/dist/telemetry/tsed/config.d.ts +26 -0
  68. package/dist/telemetry/tsed/config.js +166 -0
  69. package/dist/telemetry/tsed/index.d.ts +4 -0
  70. package/dist/telemetry/tsed/index.js +21 -0
  71. package/dist/telemetry/tsed/log-telemetry.d.ts +1 -0
  72. package/dist/telemetry/tsed/log-telemetry.js +196 -0
  73. package/dist/telemetry/tsed/service.d.ts +26 -0
  74. package/dist/telemetry/tsed/service.js +150 -0
  75. package/dist/telemetry/tsed/sync-log-record-processor.d.ts +11 -0
  76. package/dist/telemetry/tsed/sync-log-record-processor.js +74 -0
  77. package/dist/tsed/__tests__/config.test.d.ts +1 -0
  78. package/dist/tsed/__tests__/config.test.js +146 -0
  79. package/dist/tsed/__tests__/service.test.d.ts +1 -0
  80. package/dist/tsed/__tests__/service.test.js +63 -0
  81. package/dist/tsed/config.d.ts +26 -0
  82. package/dist/tsed/config.js +166 -0
  83. package/dist/tsed/index.d.ts +4 -0
  84. package/dist/tsed/index.js +21 -0
  85. package/dist/tsed/log-telemetry.d.ts +1 -0
  86. package/dist/tsed/log-telemetry.js +196 -0
  87. package/dist/tsed/service.d.ts +26 -0
  88. package/dist/tsed/service.js +150 -0
  89. package/dist/tsed/sync-log-record-processor.d.ts +11 -0
  90. package/dist/tsed/sync-log-record-processor.js +74 -0
  91. package/package.json +72 -56
  92. package/release.config.js +23 -23
  93. package/vitest.config.ts +22 -0
  94. package/dist/check-if-is-working.d.ts +0 -1
  95. package/dist/check-if-is-working.js +0 -8
@@ -0,0 +1,337 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const vitest_1 = require("vitest");
13
+ const logger_1 = require("../logger");
14
+ const api_logs_1 = require("@opentelemetry/api-logs");
15
+ (0, vitest_1.describe)('StandardLogger', () => {
16
+ let mockLogger;
17
+ let standardLogger;
18
+ (0, vitest_1.beforeEach)(() => {
19
+ mockLogger = {
20
+ emit: vitest_1.vi.fn(),
21
+ };
22
+ standardLogger = new logger_1.StandardLogger(mockLogger, 'test-service');
23
+ });
24
+ (0, vitest_1.describe)('logError', () => {
25
+ (0, vitest_1.it)('deve emitir log com severity ERROR', () => __awaiter(void 0, void 0, void 0, function* () {
26
+ const errorData = {
27
+ message: 'Test error message',
28
+ serviceName: 'test-service',
29
+ environment: 'test',
30
+ };
31
+ yield standardLogger.logError(errorData);
32
+ (0, vitest_1.expect)(mockLogger.emit).toHaveBeenCalledTimes(1);
33
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
34
+ (0, vitest_1.expect)(emittedLog.severityNumber).toBe(api_logs_1.SeverityNumber.ERROR);
35
+ (0, vitest_1.expect)(emittedLog.severityText).toBe('ERROR');
36
+ (0, vitest_1.expect)(emittedLog.body).toBe('Test error message');
37
+ }));
38
+ (0, vitest_1.it)('deve incluir informações do erro quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
39
+ const error = new Error('Custom error');
40
+ const errorData = {
41
+ message: 'Error occurred',
42
+ error,
43
+ serviceName: 'test-service',
44
+ environment: 'production',
45
+ };
46
+ yield standardLogger.logError(errorData);
47
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
48
+ (0, vitest_1.expect)(emittedLog.attributes['error.type']).toBe('Error');
49
+ (0, vitest_1.expect)(emittedLog.attributes['error.message']).toBe('Custom error');
50
+ (0, vitest_1.expect)(emittedLog.attributes['error.stack']).toBeDefined();
51
+ }));
52
+ (0, vitest_1.it)('deve incluir contexto HTTP quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
53
+ const errorData = {
54
+ message: 'HTTP error',
55
+ serviceName: 'test-service',
56
+ environment: 'production',
57
+ http: {
58
+ method: 'POST',
59
+ url: '/api/test',
60
+ endpoint: '/api/test',
61
+ statusCode: 500,
62
+ headers: { 'content-type': 'application/json' },
63
+ body: { test: 'data' },
64
+ params: { id: '123' },
65
+ query: { filter: 'active' },
66
+ },
67
+ };
68
+ yield standardLogger.logError(errorData);
69
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
70
+ (0, vitest_1.expect)(emittedLog.attributes['http.method']).toBe('POST');
71
+ (0, vitest_1.expect)(emittedLog.attributes['http.url']).toBe('/api/test');
72
+ (0, vitest_1.expect)(emittedLog.attributes['http.endpoint']).toBe('/api/test');
73
+ (0, vitest_1.expect)(emittedLog.attributes['http.status_code']).toBe(500);
74
+ (0, vitest_1.expect)(emittedLog.attributes['http.headers']).toBe(JSON.stringify({ 'content-type': 'application/json' }));
75
+ (0, vitest_1.expect)(emittedLog.attributes['http.body']).toBe(JSON.stringify({ test: 'data' }));
76
+ }));
77
+ (0, vitest_1.it)('deve incluir informações de usuário quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
78
+ const errorData = {
79
+ message: 'User error',
80
+ serviceName: 'test-service',
81
+ environment: 'production',
82
+ user: {
83
+ accountUserUid: 'user-123',
84
+ accountUid: 'account-456',
85
+ applicationUid: 'app-789',
86
+ },
87
+ };
88
+ yield standardLogger.logError(errorData);
89
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
90
+ (0, vitest_1.expect)(emittedLog.attributes['accountUser.uid']).toBe('user-123');
91
+ (0, vitest_1.expect)(emittedLog.attributes['account.uid']).toBe('account-456');
92
+ (0, vitest_1.expect)(emittedLog.attributes['application.uid']).toBe('app-789');
93
+ }));
94
+ (0, vitest_1.it)('deve incluir informações de execução quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
95
+ const errorData = {
96
+ message: 'Execution error',
97
+ serviceName: 'test-service',
98
+ environment: 'production',
99
+ execution: {
100
+ requestId: 'req-123',
101
+ awsRequestId: 'aws-456',
102
+ functionName: 'testFunction',
103
+ invocationId: 'inv-789',
104
+ controller: 'TestController',
105
+ controllerMethod: 'testMethod',
106
+ origin: 'mobile',
107
+ },
108
+ };
109
+ yield standardLogger.logError(errorData);
110
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
111
+ (0, vitest_1.expect)(emittedLog.attributes['request.id']).toBe('req-123');
112
+ (0, vitest_1.expect)(emittedLog.attributes['aws.request.id']).toBe('aws-456');
113
+ (0, vitest_1.expect)(emittedLog.attributes['faas.name']).toBe('testFunction');
114
+ (0, vitest_1.expect)(emittedLog.attributes['faas.invocation_id']).toBe('inv-789');
115
+ (0, vitest_1.expect)(emittedLog.attributes['controller.name']).toBe('TestController');
116
+ (0, vitest_1.expect)(emittedLog.attributes['controller.method']).toBe('testMethod');
117
+ (0, vitest_1.expect)(emittedLog.attributes['origin']).toBe('mobile');
118
+ }));
119
+ (0, vitest_1.it)('deve incluir métricas de performance quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
120
+ const errorData = {
121
+ message: 'Performance error',
122
+ serviceName: 'test-service',
123
+ environment: 'production',
124
+ performance: {
125
+ durationMs: 1500,
126
+ success: false,
127
+ },
128
+ };
129
+ yield standardLogger.logError(errorData);
130
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
131
+ (0, vitest_1.expect)(emittedLog.attributes['duration.ms']).toBe(1500);
132
+ (0, vitest_1.expect)(emittedLog.attributes['execution.success']).toBe(false);
133
+ }));
134
+ (0, vitest_1.it)('deve incluir contexto adicional quando fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
135
+ const errorData = {
136
+ message: 'Context error',
137
+ serviceName: 'test-service',
138
+ environment: 'production',
139
+ context: {
140
+ additionalInfo: 'some data',
141
+ nested: { value: 123 },
142
+ },
143
+ };
144
+ yield standardLogger.logError(errorData);
145
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
146
+ (0, vitest_1.expect)(emittedLog.attributes['context']).toBe(JSON.stringify({ additionalInfo: 'some data', nested: { value: 123 } }));
147
+ }));
148
+ (0, vitest_1.it)('deve usar serviceName padrão quando não fornecido', () => __awaiter(void 0, void 0, void 0, function* () {
149
+ const errorData = {
150
+ message: 'Default service error',
151
+ serviceName: '',
152
+ environment: 'production',
153
+ };
154
+ yield standardLogger.logError(errorData);
155
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
156
+ (0, vitest_1.expect)(emittedLog.attributes['service.name']).toBe('test-service');
157
+ }));
158
+ (0, vitest_1.it)('deve adicionar timestamp automaticamente', () => __awaiter(void 0, void 0, void 0, function* () {
159
+ const errorData = {
160
+ message: 'Timestamp test',
161
+ serviceName: 'test-service',
162
+ environment: 'production',
163
+ };
164
+ yield standardLogger.logError(errorData);
165
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
166
+ (0, vitest_1.expect)(emittedLog.attributes['timestamp']).toBeDefined();
167
+ (0, vitest_1.expect)(emittedLog.attributes['timestamp']).toMatch(/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z$/);
168
+ }));
169
+ (0, vitest_1.it)('deve filtrar valores undefined e null dos atributos', () => __awaiter(void 0, void 0, void 0, function* () {
170
+ const errorData = {
171
+ message: 'Filter test',
172
+ serviceName: 'test-service',
173
+ environment: 'production',
174
+ user: {
175
+ accountUserUid: 'user-123',
176
+ accountUid: undefined,
177
+ applicationUid: undefined,
178
+ },
179
+ };
180
+ yield standardLogger.logError(errorData);
181
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
182
+ (0, vitest_1.expect)(emittedLog.attributes['accountUser.uid']).toBe('user-123');
183
+ (0, vitest_1.expect)(emittedLog.attributes['account.uid']).toBeUndefined();
184
+ (0, vitest_1.expect)(emittedLog.attributes['application.uid']).toBeUndefined();
185
+ }));
186
+ });
187
+ (0, vitest_1.describe)('logInfo', () => {
188
+ (0, vitest_1.it)('deve emitir log com severity INFO', () => __awaiter(void 0, void 0, void 0, function* () {
189
+ const infoData = {
190
+ message: 'Info message',
191
+ serviceName: 'test-service',
192
+ environment: 'production',
193
+ };
194
+ yield standardLogger.logInfo(infoData);
195
+ (0, vitest_1.expect)(mockLogger.emit).toHaveBeenCalledTimes(1);
196
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
197
+ (0, vitest_1.expect)(emittedLog.severityNumber).toBe(api_logs_1.SeverityNumber.INFO);
198
+ (0, vitest_1.expect)(emittedLog.severityText).toBe('INFO');
199
+ (0, vitest_1.expect)(emittedLog.body).toBe('Info message');
200
+ }));
201
+ (0, vitest_1.it)('deve incluir dados de performance em log de sucesso', () => __awaiter(void 0, void 0, void 0, function* () {
202
+ const infoData = {
203
+ message: 'Request completed',
204
+ serviceName: 'test-service',
205
+ environment: 'production',
206
+ performance: {
207
+ durationMs: 250,
208
+ success: true,
209
+ },
210
+ };
211
+ yield standardLogger.logInfo(infoData);
212
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
213
+ (0, vitest_1.expect)(emittedLog.attributes['duration.ms']).toBe(250);
214
+ (0, vitest_1.expect)(emittedLog.attributes['execution.success']).toBe(true);
215
+ }));
216
+ });
217
+ (0, vitest_1.describe)('logWarn', () => {
218
+ (0, vitest_1.it)('deve emitir log com severity WARN', () => __awaiter(void 0, void 0, void 0, function* () {
219
+ const warnData = {
220
+ message: 'Warning message',
221
+ serviceName: 'test-service',
222
+ environment: 'production',
223
+ };
224
+ yield standardLogger.logWarn(warnData);
225
+ (0, vitest_1.expect)(mockLogger.emit).toHaveBeenCalledTimes(1);
226
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
227
+ (0, vitest_1.expect)(emittedLog.severityNumber).toBe(api_logs_1.SeverityNumber.WARN);
228
+ (0, vitest_1.expect)(emittedLog.severityText).toBe('WARN');
229
+ (0, vitest_1.expect)(emittedLog.body).toBe('Warning message');
230
+ }));
231
+ });
232
+ (0, vitest_1.describe)('logDebug', () => {
233
+ (0, vitest_1.it)('deve emitir log com severity DEBUG', () => __awaiter(void 0, void 0, void 0, function* () {
234
+ const debugData = {
235
+ message: 'Debug message',
236
+ serviceName: 'test-service',
237
+ environment: 'development',
238
+ };
239
+ yield standardLogger.logDebug(debugData);
240
+ (0, vitest_1.expect)(mockLogger.emit).toHaveBeenCalledTimes(1);
241
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
242
+ (0, vitest_1.expect)(emittedLog.severityNumber).toBe(api_logs_1.SeverityNumber.DEBUG);
243
+ (0, vitest_1.expect)(emittedLog.severityText).toBe('DEBUG');
244
+ (0, vitest_1.expect)(emittedLog.body).toBe('Debug message');
245
+ }));
246
+ });
247
+ (0, vitest_1.describe)('buildAttributes', () => {
248
+ (0, vitest_1.it)('deve construir atributos completos com todos os campos', () => __awaiter(void 0, void 0, void 0, function* () {
249
+ const fullData = {
250
+ message: 'Complete log',
251
+ serviceName: 'complete-service',
252
+ environment: 'production',
253
+ error: new Error('Test error'),
254
+ http: {
255
+ method: 'GET',
256
+ url: '/api/users',
257
+ endpoint: '/api/users',
258
+ statusCode: 200,
259
+ },
260
+ user: {
261
+ accountUserUid: 'user-abc',
262
+ accountUid: 'account-xyz',
263
+ applicationUid: 'app-123',
264
+ },
265
+ execution: {
266
+ requestId: 'req-001',
267
+ awsRequestId: 'aws-002',
268
+ functionName: 'getUsers',
269
+ invocationId: 'inv-003',
270
+ controller: 'UserController',
271
+ controllerMethod: 'getAll',
272
+ origin: 'web',
273
+ },
274
+ performance: {
275
+ durationMs: 300,
276
+ success: true,
277
+ },
278
+ context: {
279
+ custom: 'data',
280
+ },
281
+ };
282
+ yield standardLogger.logInfo(fullData);
283
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
284
+ const attrs = emittedLog.attributes;
285
+ (0, vitest_1.expect)(attrs['service.name']).toBe('complete-service');
286
+ (0, vitest_1.expect)(attrs['deployment.environment.name']).toBe('production');
287
+ (0, vitest_1.expect)(attrs['error.type']).toBe('Error');
288
+ (0, vitest_1.expect)(attrs['http.method']).toBe('GET');
289
+ (0, vitest_1.expect)(attrs['accountUser.uid']).toBe('user-abc');
290
+ (0, vitest_1.expect)(attrs['request.id']).toBe('req-001');
291
+ (0, vitest_1.expect)(attrs['duration.ms']).toBe(300);
292
+ (0, vitest_1.expect)(attrs['context']).toBe(JSON.stringify({ custom: 'data' }));
293
+ }));
294
+ (0, vitest_1.it)('deve lidar com campos HTTP parciais', () => __awaiter(void 0, void 0, void 0, function* () {
295
+ const partialHttpData = {
296
+ message: 'Partial HTTP',
297
+ serviceName: 'test-service',
298
+ environment: 'production',
299
+ http: {
300
+ method: 'POST',
301
+ endpoint: '/api/test',
302
+ },
303
+ };
304
+ yield standardLogger.logInfo(partialHttpData);
305
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
306
+ (0, vitest_1.expect)(emittedLog.attributes['http.method']).toBe('POST');
307
+ (0, vitest_1.expect)(emittedLog.attributes['http.endpoint']).toBe('/api/test');
308
+ (0, vitest_1.expect)(emittedLog.attributes['http.url']).toBeUndefined();
309
+ (0, vitest_1.expect)(emittedLog.attributes['http.status_code']).toBeUndefined();
310
+ }));
311
+ });
312
+ (0, vitest_1.describe)('construtor', () => {
313
+ (0, vitest_1.it)('deve aceitar serviceName padrão personalizado', () => {
314
+ const customLogger = new logger_1.StandardLogger(mockLogger, 'custom-service');
315
+ const logData = {
316
+ message: 'Test',
317
+ serviceName: '',
318
+ environment: 'test',
319
+ };
320
+ customLogger.logInfo(logData);
321
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
322
+ (0, vitest_1.expect)(emittedLog.attributes['service.name']).toBe('custom-service');
323
+ });
324
+ (0, vitest_1.it)('deve usar "unknown-service" como padrão quando não especificado', () => {
325
+ const defaultLogger = new logger_1.StandardLogger(mockLogger);
326
+ const logData = {
327
+ message: 'Test',
328
+ serviceName: '',
329
+ environment: 'test',
330
+ };
331
+ defaultLogger.logInfo(logData);
332
+ const emittedLog = mockLogger.emit.mock.calls[0][0];
333
+ (0, vitest_1.expect)(emittedLog.attributes['service.name']).toBe('unknown-service');
334
+ });
335
+ });
336
+ });
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/logger.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, vi, beforeEach } from 'vitest';\r\nimport { StandardLogger } from '../logger';\r\nimport { SeverityNumber } from '@opentelemetry/api-logs';\r\n\r\ndescribe('StandardLogger', () => {\r\n  let mockLogger: any;\r\n  let standardLogger: StandardLogger;\r\n\r\n  beforeEach(() => {\r\n    mockLogger = {\r\n      emit: vi.fn(),\r\n    };\r\n    standardLogger = new StandardLogger(mockLogger, 'test-service');\r\n  });\r\n\r\n  describe('logError', () => {\r\n    it('deve emitir log com severity ERROR', async () => {\r\n      const errorData = {\r\n        message: 'Test error message',\r\n        serviceName: 'test-service',\r\n        environment: 'test',\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      expect(mockLogger.emit).toHaveBeenCalledTimes(1);\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.severityNumber).toBe(SeverityNumber.ERROR);\r\n      expect(emittedLog.severityText).toBe('ERROR');\r\n      expect(emittedLog.body).toBe('Test error message');\r\n    });\r\n\r\n    it('deve incluir informações do erro quando fornecido', async () => {\r\n      const error = new Error('Custom error');\r\n      const errorData = {\r\n        message: 'Error occurred',\r\n        error,\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['error.type']).toBe('Error');\r\n      expect(emittedLog.attributes['error.message']).toBe('Custom error');\r\n      expect(emittedLog.attributes['error.stack']).toBeDefined();\r\n    });\r\n\r\n    it('deve incluir contexto HTTP quando fornecido', async () => {\r\n      const errorData = {\r\n        message: 'HTTP error',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        http: {\r\n          method: 'POST',\r\n          url: '/api/test',\r\n          endpoint: '/api/test',\r\n          statusCode: 500,\r\n          headers: { 'content-type': 'application/json' },\r\n          body: { test: 'data' },\r\n          params: { id: '123' },\r\n          query: { filter: 'active' },\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['http.method']).toBe('POST');\r\n      expect(emittedLog.attributes['http.url']).toBe('/api/test');\r\n      expect(emittedLog.attributes['http.endpoint']).toBe('/api/test');\r\n      expect(emittedLog.attributes['http.status_code']).toBe(500);\r\n      expect(emittedLog.attributes['http.headers']).toBe(\r\n        JSON.stringify({ 'content-type': 'application/json' })\r\n      );\r\n      expect(emittedLog.attributes['http.body']).toBe(\r\n        JSON.stringify({ test: 'data' })\r\n      );\r\n    });\r\n\r\n    it('deve incluir informações de usuário quando fornecido', async () => {\r\n      const errorData = {\r\n        message: 'User error',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        user: {\r\n          accountUserUid: 'user-123',\r\n          accountUid: 'account-456',\r\n          applicationUid: 'app-789',\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['accountUser.uid']).toBe('user-123');\r\n      expect(emittedLog.attributes['account.uid']).toBe('account-456');\r\n      expect(emittedLog.attributes['application.uid']).toBe('app-789');\r\n    });\r\n\r\n    it('deve incluir informações de execução quando fornecido', async () => {\r\n      const errorData = {\r\n        message: 'Execution error',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        execution: {\r\n          requestId: 'req-123',\r\n          awsRequestId: 'aws-456',\r\n          functionName: 'testFunction',\r\n          invocationId: 'inv-789',\r\n          controller: 'TestController',\r\n          controllerMethod: 'testMethod',\r\n          origin: 'mobile',\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['request.id']).toBe('req-123');\r\n      expect(emittedLog.attributes['aws.request.id']).toBe('aws-456');\r\n      expect(emittedLog.attributes['faas.name']).toBe('testFunction');\r\n      expect(emittedLog.attributes['faas.invocation_id']).toBe('inv-789');\r\n      expect(emittedLog.attributes['controller.name']).toBe('TestController');\r\n      expect(emittedLog.attributes['controller.method']).toBe('testMethod');\r\n      expect(emittedLog.attributes['origin']).toBe('mobile');\r\n    });\r\n\r\n    it('deve incluir métricas de performance quando fornecido', async () => {\r\n      const errorData = {\r\n        message: 'Performance error',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        performance: {\r\n          durationMs: 1500,\r\n          success: false,\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['duration.ms']).toBe(1500);\r\n      expect(emittedLog.attributes['execution.success']).toBe(false);\r\n    });\r\n\r\n    it('deve incluir contexto adicional quando fornecido', async () => {\r\n      const errorData = {\r\n        message: 'Context error',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        context: {\r\n          additionalInfo: 'some data',\r\n          nested: { value: 123 },\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['context']).toBe(\r\n        JSON.stringify({ additionalInfo: 'some data', nested: { value: 123 } })\r\n      );\r\n    });\r\n\r\n    it('deve usar serviceName padrão quando não fornecido', async () => {\r\n      const errorData = {\r\n        message: 'Default service error',\r\n        serviceName: '', // Empty string para testar fallback\r\n        environment: 'production',\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['service.name']).toBe('test-service');\r\n    });\r\n\r\n    it('deve adicionar timestamp automaticamente', async () => {\r\n      const errorData = {\r\n        message: 'Timestamp test',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['timestamp']).toBeDefined();\r\n      expect(emittedLog.attributes['timestamp']).toMatch(\r\n        /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{3}Z$/\r\n      );\r\n    });\r\n\r\n    it('deve filtrar valores undefined e null dos atributos', async () => {\r\n      const errorData = {\r\n        message: 'Filter test',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        user: {\r\n          accountUserUid: 'user-123',\r\n          accountUid: undefined as any,\r\n          applicationUid: undefined as any,\r\n        },\r\n      };\r\n\r\n      await standardLogger.logError(errorData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['accountUser.uid']).toBe('user-123');\r\n      expect(emittedLog.attributes['account.uid']).toBeUndefined();\r\n      expect(emittedLog.attributes['application.uid']).toBeUndefined();\r\n    });\r\n  });\r\n\r\n  describe('logInfo', () => {\r\n    it('deve emitir log com severity INFO', async () => {\r\n      const infoData = {\r\n        message: 'Info message',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n      };\r\n\r\n      await standardLogger.logInfo(infoData);\r\n\r\n      expect(mockLogger.emit).toHaveBeenCalledTimes(1);\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.severityNumber).toBe(SeverityNumber.INFO);\r\n      expect(emittedLog.severityText).toBe('INFO');\r\n      expect(emittedLog.body).toBe('Info message');\r\n    });\r\n\r\n    it('deve incluir dados de performance em log de sucesso', async () => {\r\n      const infoData = {\r\n        message: 'Request completed',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        performance: {\r\n          durationMs: 250,\r\n          success: true,\r\n        },\r\n      };\r\n\r\n      await standardLogger.logInfo(infoData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['duration.ms']).toBe(250);\r\n      expect(emittedLog.attributes['execution.success']).toBe(true);\r\n    });\r\n  });\r\n\r\n  describe('logWarn', () => {\r\n    it('deve emitir log com severity WARN', async () => {\r\n      const warnData = {\r\n        message: 'Warning message',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n      };\r\n\r\n      await standardLogger.logWarn(warnData);\r\n\r\n      expect(mockLogger.emit).toHaveBeenCalledTimes(1);\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.severityNumber).toBe(SeverityNumber.WARN);\r\n      expect(emittedLog.severityText).toBe('WARN');\r\n      expect(emittedLog.body).toBe('Warning message');\r\n    });\r\n  });\r\n\r\n  describe('logDebug', () => {\r\n    it('deve emitir log com severity DEBUG', async () => {\r\n      const debugData = {\r\n        message: 'Debug message',\r\n        serviceName: 'test-service',\r\n        environment: 'development',\r\n      };\r\n\r\n      await standardLogger.logDebug(debugData);\r\n\r\n      expect(mockLogger.emit).toHaveBeenCalledTimes(1);\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.severityNumber).toBe(SeverityNumber.DEBUG);\r\n      expect(emittedLog.severityText).toBe('DEBUG');\r\n      expect(emittedLog.body).toBe('Debug message');\r\n    });\r\n  });\r\n\r\n  describe('buildAttributes', () => {\r\n    it('deve construir atributos completos com todos os campos', async () => {\r\n      const fullData = {\r\n        message: 'Complete log',\r\n        serviceName: 'complete-service',\r\n        environment: 'production',\r\n        error: new Error('Test error'),\r\n        http: {\r\n          method: 'GET',\r\n          url: '/api/users',\r\n          endpoint: '/api/users',\r\n          statusCode: 200,\r\n        },\r\n        user: {\r\n          accountUserUid: 'user-abc',\r\n          accountUid: 'account-xyz',\r\n          applicationUid: 'app-123',\r\n        },\r\n        execution: {\r\n          requestId: 'req-001',\r\n          awsRequestId: 'aws-002',\r\n          functionName: 'getUsers',\r\n          invocationId: 'inv-003',\r\n          controller: 'UserController',\r\n          controllerMethod: 'getAll',\r\n          origin: 'web',\r\n        },\r\n        performance: {\r\n          durationMs: 300,\r\n          success: true,\r\n        },\r\n        context: {\r\n          custom: 'data',\r\n        },\r\n      };\r\n\r\n      await standardLogger.logInfo(fullData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      const attrs = emittedLog.attributes;\r\n\r\n      // Verificar todos os campos\r\n      expect(attrs['service.name']).toBe('complete-service');\r\n      expect(attrs['deployment.environment.name']).toBe('production');\r\n      expect(attrs['error.type']).toBe('Error');\r\n      expect(attrs['http.method']).toBe('GET');\r\n      expect(attrs['accountUser.uid']).toBe('user-abc');\r\n      expect(attrs['request.id']).toBe('req-001');\r\n      expect(attrs['duration.ms']).toBe(300);\r\n      expect(attrs['context']).toBe(JSON.stringify({ custom: 'data' }));\r\n    });\r\n\r\n    it('deve lidar com campos HTTP parciais', async () => {\r\n      const partialHttpData = {\r\n        message: 'Partial HTTP',\r\n        serviceName: 'test-service',\r\n        environment: 'production',\r\n        http: {\r\n          method: 'POST',\r\n          endpoint: '/api/test',\r\n          // url, statusCode, headers, etc não fornecidos\r\n        },\r\n      };\r\n\r\n      await standardLogger.logInfo(partialHttpData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['http.method']).toBe('POST');\r\n      expect(emittedLog.attributes['http.endpoint']).toBe('/api/test');\r\n      expect(emittedLog.attributes['http.url']).toBeUndefined();\r\n      expect(emittedLog.attributes['http.status_code']).toBeUndefined();\r\n    });\r\n  });\r\n\r\n  describe('construtor', () => {\r\n    it('deve aceitar serviceName padrão personalizado', () => {\r\n      const customLogger = new StandardLogger(mockLogger, 'custom-service');\r\n      const logData = {\r\n        message: 'Test',\r\n        serviceName: '',\r\n        environment: 'test',\r\n      };\r\n\r\n      customLogger.logInfo(logData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['service.name']).toBe('custom-service');\r\n    });\r\n\r\n    it('deve usar \"unknown-service\" como padrão quando não especificado', () => {\r\n      const defaultLogger = new StandardLogger(mockLogger);\r\n      const logData = {\r\n        message: 'Test',\r\n        serviceName: '',\r\n        environment: 'test',\r\n      };\r\n\r\n      defaultLogger.logInfo(logData);\r\n\r\n      const emittedLog = mockLogger.emit.mock.calls[0][0];\r\n      expect(emittedLog.attributes['service.name']).toBe('unknown-service');\r\n    });\r\n  });\r\n});\r\n"]}
@@ -0,0 +1 @@
1
+ export {};