@mecanizou/telemetry-hub 1.0.2 → 1.0.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.
Files changed (72) 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 +36 -14
  5. package/DOCS_GUIDE.md +151 -151
  6. package/README.md +248 -248
  7. package/dist/core/__tests__/logger-types.test.js +1 -1
  8. package/dist/core/__tests__/logger.test.js +1 -1
  9. package/dist/core/__tests__/tracer.test.js +1 -1
  10. package/dist/core/index.js +1 -1
  11. package/dist/core/logger-types.js +1 -1
  12. package/dist/core/logger.js +1 -1
  13. package/dist/core/tracer-types.js +1 -1
  14. package/dist/core/tracer.js +1 -1
  15. package/dist/index.js +1 -1
  16. package/dist/sst/__tests__/telemetry.test.js +1 -1
  17. package/dist/sst/index.js +1 -1
  18. package/dist/sst/middy/index.js +1 -1
  19. package/dist/sst/middy/middleware.js +1 -1
  20. package/dist/sst/telemetry.js +1 -1
  21. package/dist/tsed/__tests__/config.test.js +1 -1
  22. package/dist/tsed/__tests__/service.test.js +1 -1
  23. package/dist/tsed/config.js +1 -1
  24. package/dist/tsed/index.js +1 -1
  25. package/dist/tsed/log-telemetry.js +1 -1
  26. package/dist/tsed/service.js +1 -1
  27. package/dist/tsed/sync-log-record-processor.js +1 -1
  28. package/package.json +72 -72
  29. package/release.config.js +23 -23
  30. package/vitest.config.ts +22 -22
  31. package/dist/telemetry/core/__tests__/logger-types.test.d.ts +0 -1
  32. package/dist/telemetry/core/__tests__/logger-types.test.js +0 -325
  33. package/dist/telemetry/core/__tests__/logger.test.d.ts +0 -1
  34. package/dist/telemetry/core/__tests__/logger.test.js +0 -337
  35. package/dist/telemetry/core/__tests__/tracer.test.d.ts +0 -1
  36. package/dist/telemetry/core/__tests__/tracer.test.js +0 -330
  37. package/dist/telemetry/core/index.d.ts +0 -4
  38. package/dist/telemetry/core/index.js +0 -8
  39. package/dist/telemetry/core/logger-types.d.ts +0 -43
  40. package/dist/telemetry/core/logger-types.js +0 -3
  41. package/dist/telemetry/core/logger.d.ts +0 -13
  42. package/dist/telemetry/core/logger.js +0 -123
  43. package/dist/telemetry/core/tracer-types.d.ts +0 -50
  44. package/dist/telemetry/core/tracer-types.js +0 -3
  45. package/dist/telemetry/core/tracer.d.ts +0 -10
  46. package/dist/telemetry/core/tracer.js +0 -114
  47. package/dist/telemetry/index.d.ts +0 -3
  48. package/dist/telemetry/index.js +0 -20
  49. package/dist/telemetry/sst/__tests__/telemetry.test.d.ts +0 -1
  50. package/dist/telemetry/sst/__tests__/telemetry.test.js +0 -138
  51. package/dist/telemetry/sst/index.d.ts +0 -1
  52. package/dist/telemetry/sst/index.js +0 -18
  53. package/dist/telemetry/sst/middy/index.d.ts +0 -1
  54. package/dist/telemetry/sst/middy/index.js +0 -18
  55. package/dist/telemetry/sst/middy/middleware.d.ts +0 -5
  56. package/dist/telemetry/sst/middy/middleware.js +0 -157
  57. package/dist/telemetry/sst/telemetry.d.ts +0 -4
  58. package/dist/telemetry/sst/telemetry.js +0 -121
  59. package/dist/telemetry/tsed/__tests__/config.test.d.ts +0 -1
  60. package/dist/telemetry/tsed/__tests__/config.test.js +0 -146
  61. package/dist/telemetry/tsed/__tests__/service.test.d.ts +0 -1
  62. package/dist/telemetry/tsed/__tests__/service.test.js +0 -63
  63. package/dist/telemetry/tsed/config.d.ts +0 -26
  64. package/dist/telemetry/tsed/config.js +0 -166
  65. package/dist/telemetry/tsed/index.d.ts +0 -4
  66. package/dist/telemetry/tsed/index.js +0 -21
  67. package/dist/telemetry/tsed/log-telemetry.d.ts +0 -1
  68. package/dist/telemetry/tsed/log-telemetry.js +0 -196
  69. package/dist/telemetry/tsed/service.d.ts +0 -26
  70. package/dist/telemetry/tsed/service.js +0 -150
  71. package/dist/telemetry/tsed/sync-log-record-processor.d.ts +0 -11
  72. package/dist/telemetry/tsed/sync-log-record-processor.js +0 -74
package/package.json CHANGED
@@ -1,72 +1,72 @@
1
- {
2
- "name": "@mecanizou/telemetry-hub",
3
- "version": "1.0.2",
4
- "description": "Mecanizou telemetry lib",
5
- "main": "dist/index.js",
6
- "types": "dist/index.d.ts",
7
- "config": {
8
- "commitizen": {
9
- "path": "./node_modules/cz-conventional-changelog"
10
- }
11
- },
12
- "devDependencies": {
13
- "@commitlint/cli": "^20.1.0",
14
- "@commitlint/config-conventional": "^20.0.0",
15
- "@semantic-release/changelog": "^6.0.3",
16
- "@semantic-release/commit-analyzer": "^13.0.1",
17
- "@semantic-release/git": "^10.0.1",
18
- "@semantic-release/github": "^12.0.2",
19
- "@semantic-release/npm": "^13.1.2",
20
- "@semantic-release/release-notes-generator": "^14.1.0",
21
- "@types/node": "^24.10.1",
22
- "@vitest/coverage-v8": "^4.0.15",
23
- "commitizen": "^4.3.0",
24
- "cz-conventional-changelog": "^3.3.0",
25
- "eslint": "^9.39.0",
26
- "eslint-plugin-prettier": "^5.5.4",
27
- "lint-staged": "^13.3.0",
28
- "prettier": "^3.6.2",
29
- "semantic-release": "^25.0.2",
30
- "typescript": "^5.9.3",
31
- "vitest": "^4.0.13"
32
- },
33
- "dependencies": {
34
- "@middy/core": "^6.4.5",
35
- "@opentelemetry/api": "^1.9.0",
36
- "@opentelemetry/api-logs": "^0.56.0",
37
- "@opentelemetry/exporter-logs-otlp-http": "^0.56.0",
38
- "@opentelemetry/exporter-metrics-otlp-http": "^0.56.0",
39
- "@opentelemetry/exporter-trace-otlp-http": "^0.56.0",
40
- "@opentelemetry/resources": "^1.30.0",
41
- "@opentelemetry/sdk-logs": "^0.56.0",
42
- "@opentelemetry/sdk-metrics": "^1.30.0",
43
- "@opentelemetry/sdk-node": "^0.56.0",
44
- "@opentelemetry/semantic-conventions": "^1.30.0",
45
- "@tsed/di": "^8.19.4",
46
- "@tsed/platform-serverless": "^8.19.4"
47
- },
48
- "scripts": {
49
- "check": "npx prettier --check .",
50
- "build": "npx tsc",
51
- "fix": "npx prettier --write .",
52
- "lint": "npx eslint .",
53
- "test": "npm run test:common -- run",
54
- "test:tsc": "npx tsc --noEmit",
55
- "test:common": "npx vitest",
56
- "test:verbose": "npm run test:common",
57
- "test:coverage": "npm run test:common -- --coverage",
58
- "test:watch": "npm run test:common -- --watch",
59
- "test:debug": "node --inspect-brk -r ts-node/register node_modules/.bin/vitest --runInBand --no-cache --watch",
60
- "prepublishOnly": "npm run build"
61
- },
62
- "repository": {
63
- "type": "git",
64
- "url": "git+https://github.com/mecanizou-eco/telemetry-hub.git"
65
- },
66
- "author": "",
67
- "license": "ISC",
68
- "bugs": {
69
- "url": "https://github.com/mecanizou-eco/telemetry-hub/issues"
70
- },
71
- "homepage": "https://github.com/mecanizou-eco/telemetry-hub#readme"
72
- }
1
+ {
2
+ "name": "@mecanizou/telemetry-hub",
3
+ "version": "1.0.5",
4
+ "description": "Mecanizou telemetry lib",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "config": {
8
+ "commitizen": {
9
+ "path": "./node_modules/cz-conventional-changelog"
10
+ }
11
+ },
12
+ "devDependencies": {
13
+ "@commitlint/cli": "^20.1.0",
14
+ "@commitlint/config-conventional": "^20.0.0",
15
+ "@semantic-release/changelog": "^6.0.3",
16
+ "@semantic-release/commit-analyzer": "^13.0.1",
17
+ "@semantic-release/git": "^10.0.1",
18
+ "@semantic-release/github": "^12.0.2",
19
+ "@semantic-release/npm": "^13.1.2",
20
+ "@semantic-release/release-notes-generator": "^14.1.0",
21
+ "@types/node": "^24.10.1",
22
+ "@vitest/coverage-v8": "^4.0.15",
23
+ "commitizen": "^4.3.0",
24
+ "cz-conventional-changelog": "^3.3.0",
25
+ "eslint": "^9.39.0",
26
+ "eslint-plugin-prettier": "^5.5.4",
27
+ "lint-staged": "^13.3.0",
28
+ "prettier": "^3.6.2",
29
+ "semantic-release": "^25.0.2",
30
+ "typescript": "^5.9.3",
31
+ "vitest": "^4.0.13"
32
+ },
33
+ "dependencies": {
34
+ "@middy/core": "^6.4.5",
35
+ "@opentelemetry/api": "^1.9.0",
36
+ "@opentelemetry/api-logs": "^0.56.0",
37
+ "@opentelemetry/exporter-logs-otlp-http": "^0.56.0",
38
+ "@opentelemetry/exporter-metrics-otlp-http": "^0.56.0",
39
+ "@opentelemetry/exporter-trace-otlp-http": "^0.56.0",
40
+ "@opentelemetry/resources": "^1.30.0",
41
+ "@opentelemetry/sdk-logs": "^0.56.0",
42
+ "@opentelemetry/sdk-metrics": "^1.30.0",
43
+ "@opentelemetry/sdk-node": "^0.56.0",
44
+ "@opentelemetry/semantic-conventions": "^1.30.0",
45
+ "@tsed/di": "8.19.5",
46
+ "@tsed/platform-serverless": "8.19.5"
47
+ },
48
+ "scripts": {
49
+ "check": "npx prettier --check .",
50
+ "build": "npx tsc",
51
+ "fix": "npx prettier --write .",
52
+ "lint": "npx eslint .",
53
+ "test": "npm run test:common -- run",
54
+ "test:tsc": "npx tsc --noEmit",
55
+ "test:common": "npx vitest",
56
+ "test:verbose": "npm run test:common",
57
+ "test:coverage": "npm run test:common -- --coverage",
58
+ "test:watch": "npm run test:common -- --watch",
59
+ "test:debug": "node --inspect-brk -r ts-node/register node_modules/.bin/vitest --runInBand --no-cache --watch",
60
+ "prepublishOnly": "npm run build"
61
+ },
62
+ "repository": {
63
+ "type": "git",
64
+ "url": "git+https://github.com/mecanizou-eco/telemetry-hub.git"
65
+ },
66
+ "author": "",
67
+ "license": "ISC",
68
+ "bugs": {
69
+ "url": "https://github.com/mecanizou-eco/telemetry-hub/issues"
70
+ },
71
+ "homepage": "https://github.com/mecanizou-eco/telemetry-hub#readme"
72
+ }
package/release.config.js CHANGED
@@ -1,23 +1,23 @@
1
- module.exports = {
2
- branches: [
3
- '+([0-9])?(.{+([0-9]),x}).x',
4
- 'master',
5
- 'next',
6
- {
7
- name: 'beta',
8
- prerelease: true,
9
- },
10
- {
11
- name: 'alpha',
12
- prerelease: true,
13
- },
14
- ],
15
- plugins: [
16
- '@semantic-release/commit-analyzer',
17
- '@semantic-release/release-notes-generator',
18
- '@semantic-release/changelog',
19
- '@semantic-release/npm',
20
- '@semantic-release/git',
21
- '@semantic-release/github',
22
- ],
23
- };
1
+ module.exports = {
2
+ branches: [
3
+ '+([0-9])?(.{+([0-9]),x}).x',
4
+ 'master',
5
+ 'next',
6
+ {
7
+ name: 'beta',
8
+ prerelease: true,
9
+ },
10
+ {
11
+ name: 'alpha',
12
+ prerelease: true,
13
+ },
14
+ ],
15
+ plugins: [
16
+ '@semantic-release/commit-analyzer',
17
+ '@semantic-release/release-notes-generator',
18
+ '@semantic-release/changelog',
19
+ '@semantic-release/npm',
20
+ '@semantic-release/git',
21
+ '@semantic-release/github',
22
+ ],
23
+ };
package/vitest.config.ts CHANGED
@@ -1,22 +1,22 @@
1
- import { defineConfig } from 'vitest/config';
2
-
3
- export default defineConfig({
4
- test: {
5
- exclude: [
6
- '**/node_modules/**',
7
- '**/dist/**',
8
- '**/.{idea,git,cache,output,temp}/**',
9
- ],
10
- coverage: {
11
- provider: 'v8',
12
- reporter: ['text', 'json', 'html'],
13
- exclude: [
14
- '**/node_modules/**',
15
- '**/dist/**',
16
- '**/__tests__/**',
17
- '**/*.test.ts',
18
- '**/*.spec.ts',
19
- ],
20
- },
21
- },
22
- });
1
+ import { defineConfig } from 'vitest/config';
2
+
3
+ export default defineConfig({
4
+ test: {
5
+ exclude: [
6
+ '**/node_modules/**',
7
+ '**/dist/**',
8
+ '**/.{idea,git,cache,output,temp}/**',
9
+ ],
10
+ coverage: {
11
+ provider: 'v8',
12
+ reporter: ['text', 'json', 'html'],
13
+ exclude: [
14
+ '**/node_modules/**',
15
+ '**/dist/**',
16
+ '**/__tests__/**',
17
+ '**/*.test.ts',
18
+ '**/*.spec.ts',
19
+ ],
20
+ },
21
+ },
22
+ });
@@ -1 +0,0 @@
1
- export {};
@@ -1,325 +0,0 @@
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
- (0, vitest_1.describe)('Types - StandardLogData', () => {
14
- (0, vitest_1.it)('deve aceitar log mínimo válido', () => {
15
- const minimalLog = {
16
- severity: 'INFO',
17
- message: 'Test message',
18
- serviceName: 'test-service',
19
- environment: 'test',
20
- timestamp: new Date().toISOString(),
21
- };
22
- (0, vitest_1.expect)(minimalLog).toBeDefined();
23
- (0, vitest_1.expect)(minimalLog.severity).toBe('INFO');
24
- });
25
- (0, vitest_1.it)('deve aceitar todos os níveis de severity', () => {
26
- const severities = [
27
- 'ERROR',
28
- 'WARN',
29
- 'INFO',
30
- 'DEBUG',
31
- ];
32
- severities.forEach((severity) => {
33
- const log = {
34
- severity,
35
- message: 'Test',
36
- serviceName: 'test',
37
- environment: 'test',
38
- timestamp: new Date().toISOString(),
39
- };
40
- (0, vitest_1.expect)(log.severity).toBe(severity);
41
- });
42
- });
43
- (0, vitest_1.it)('deve aceitar log completo com todos os campos opcionais', () => {
44
- const completeLog = {
45
- severity: 'ERROR',
46
- message: 'Complete log message',
47
- error: new Error('Test error'),
48
- serviceName: 'complete-service',
49
- environment: 'production',
50
- http: {
51
- method: 'POST',
52
- url: 'https://api.example.com/test',
53
- endpoint: '/test',
54
- statusCode: 500,
55
- headers: { 'content-type': 'application/json' },
56
- body: { test: 'data' },
57
- params: { id: '123' },
58
- query: { filter: 'active' },
59
- },
60
- user: {
61
- accountUserUid: 'user-123',
62
- accountUid: 'account-456',
63
- applicationUid: 'app-789',
64
- },
65
- execution: {
66
- requestId: 'req-abc',
67
- awsRequestId: 'aws-xyz',
68
- functionName: 'testFunction',
69
- invocationId: 'inv-123',
70
- controller: 'TestController',
71
- controllerMethod: 'testMethod',
72
- origin: 'mobile',
73
- },
74
- performance: {
75
- durationMs: 1500,
76
- success: false,
77
- },
78
- context: {
79
- customField: 'customValue',
80
- nested: {
81
- data: 123,
82
- },
83
- },
84
- timestamp: new Date().toISOString(),
85
- };
86
- (0, vitest_1.expect)(completeLog).toBeDefined();
87
- (0, vitest_1.expect)(completeLog.http).toBeDefined();
88
- (0, vitest_1.expect)(completeLog.user).toBeDefined();
89
- (0, vitest_1.expect)(completeLog.execution).toBeDefined();
90
- (0, vitest_1.expect)(completeLog.performance).toBeDefined();
91
- (0, vitest_1.expect)(completeLog.context).toBeDefined();
92
- });
93
- (0, vitest_1.it)('deve aceitar campos HTTP parciais', () => {
94
- var _a, _b, _c;
95
- const partialHttpLog = {
96
- severity: 'INFO',
97
- message: 'Partial HTTP',
98
- serviceName: 'test',
99
- environment: 'test',
100
- http: {
101
- method: 'GET',
102
- endpoint: '/api/users',
103
- },
104
- timestamp: new Date().toISOString(),
105
- };
106
- (0, vitest_1.expect)((_a = partialHttpLog.http) === null || _a === void 0 ? void 0 : _a.method).toBe('GET');
107
- (0, vitest_1.expect)((_b = partialHttpLog.http) === null || _b === void 0 ? void 0 : _b.endpoint).toBe('/api/users');
108
- (0, vitest_1.expect)((_c = partialHttpLog.http) === null || _c === void 0 ? void 0 : _c.url).toBeUndefined();
109
- });
110
- (0, vitest_1.it)('deve aceitar campos de usuário parciais', () => {
111
- var _a, _b;
112
- const partialUserLog = {
113
- severity: 'INFO',
114
- message: 'Partial user',
115
- serviceName: 'test',
116
- environment: 'test',
117
- user: {
118
- accountUserUid: 'user-123',
119
- },
120
- timestamp: new Date().toISOString(),
121
- };
122
- (0, vitest_1.expect)((_a = partialUserLog.user) === null || _a === void 0 ? void 0 : _a.accountUserUid).toBe('user-123');
123
- (0, vitest_1.expect)((_b = partialUserLog.user) === null || _b === void 0 ? void 0 : _b.accountUid).toBeUndefined();
124
- });
125
- (0, vitest_1.it)('deve aceitar campos de execução parciais', () => {
126
- var _a, _b, _c;
127
- const partialExecLog = {
128
- severity: 'DEBUG',
129
- message: 'Partial execution',
130
- serviceName: 'test',
131
- environment: 'test',
132
- execution: {
133
- requestId: 'req-123',
134
- controller: 'TestController',
135
- },
136
- timestamp: new Date().toISOString(),
137
- };
138
- (0, vitest_1.expect)((_a = partialExecLog.execution) === null || _a === void 0 ? void 0 : _a.requestId).toBe('req-123');
139
- (0, vitest_1.expect)((_b = partialExecLog.execution) === null || _b === void 0 ? void 0 : _b.controller).toBe('TestController');
140
- (0, vitest_1.expect)((_c = partialExecLog.execution) === null || _c === void 0 ? void 0 : _c.awsRequestId).toBeUndefined();
141
- });
142
- (0, vitest_1.it)('deve aceitar performance com apenas durationMs', () => {
143
- var _a, _b;
144
- const durationOnlyLog = {
145
- severity: 'INFO',
146
- message: 'Duration only',
147
- serviceName: 'test',
148
- environment: 'test',
149
- performance: {
150
- durationMs: 500,
151
- },
152
- timestamp: new Date().toISOString(),
153
- };
154
- (0, vitest_1.expect)((_a = durationOnlyLog.performance) === null || _a === void 0 ? void 0 : _a.durationMs).toBe(500);
155
- (0, vitest_1.expect)((_b = durationOnlyLog.performance) === null || _b === void 0 ? void 0 : _b.success).toBeUndefined();
156
- });
157
- (0, vitest_1.it)('deve aceitar performance com apenas success', () => {
158
- var _a, _b;
159
- const successOnlyLog = {
160
- severity: 'INFO',
161
- message: 'Success only',
162
- serviceName: 'test',
163
- environment: 'test',
164
- performance: {
165
- success: true,
166
- },
167
- timestamp: new Date().toISOString(),
168
- };
169
- (0, vitest_1.expect)((_a = successOnlyLog.performance) === null || _a === void 0 ? void 0 : _a.success).toBe(true);
170
- (0, vitest_1.expect)((_b = successOnlyLog.performance) === null || _b === void 0 ? void 0 : _b.durationMs).toBeUndefined();
171
- });
172
- (0, vitest_1.it)('deve aceitar contexto com estruturas aninhadas complexas', () => {
173
- var _a, _b;
174
- const complexContextLog = {
175
- severity: 'ERROR',
176
- message: 'Complex context',
177
- serviceName: 'test',
178
- environment: 'test',
179
- context: {
180
- level1: {
181
- level2: {
182
- level3: {
183
- value: 'deep',
184
- array: [1, 2, 3],
185
- },
186
- },
187
- },
188
- simpleValue: 'test',
189
- numericValue: 123,
190
- booleanValue: true,
191
- },
192
- timestamp: new Date().toISOString(),
193
- };
194
- (0, vitest_1.expect)((_a = complexContextLog.context) === null || _a === void 0 ? void 0 : _a.level1).toBeDefined();
195
- (0, vitest_1.expect)((_b = complexContextLog.context) === null || _b === void 0 ? void 0 : _b.simpleValue).toBe('test');
196
- });
197
- });
198
- (0, vitest_1.describe)('Types - IStandardLogger', () => {
199
- (0, vitest_1.it)('deve definir interface com os 4 métodos de log', () => {
200
- const mockLogger = {
201
- logError: () => __awaiter(void 0, void 0, void 0, function* () { }),
202
- logInfo: () => __awaiter(void 0, void 0, void 0, function* () { }),
203
- logWarn: () => __awaiter(void 0, void 0, void 0, function* () { }),
204
- logDebug: () => __awaiter(void 0, void 0, void 0, function* () { }),
205
- };
206
- (0, vitest_1.expect)(mockLogger.logError).toBeDefined();
207
- (0, vitest_1.expect)(mockLogger.logInfo).toBeDefined();
208
- (0, vitest_1.expect)(mockLogger.logWarn).toBeDefined();
209
- (0, vitest_1.expect)(mockLogger.logDebug).toBeDefined();
210
- });
211
- (0, vitest_1.it)('deve aceitar dados sem severity e timestamp nos métodos', () => __awaiter(void 0, void 0, void 0, function* () {
212
- const mockLogger = {
213
- logError: (data) => __awaiter(void 0, void 0, void 0, function* () {
214
- (0, vitest_1.expect)(data.message).toBe('Error message');
215
- (0, vitest_1.expect)(data.serviceName).toBe('test');
216
- (0, vitest_1.expect)(data.severity).toBeUndefined();
217
- (0, vitest_1.expect)(data.timestamp).toBeUndefined();
218
- }),
219
- logInfo: () => __awaiter(void 0, void 0, void 0, function* () { }),
220
- logWarn: () => __awaiter(void 0, void 0, void 0, function* () { }),
221
- logDebug: () => __awaiter(void 0, void 0, void 0, function* () { }),
222
- };
223
- yield mockLogger.logError({
224
- message: 'Error message',
225
- serviceName: 'test',
226
- environment: 'test',
227
- });
228
- }));
229
- });
230
- (0, vitest_1.describe)('Types - Validação de campos', () => {
231
- (0, vitest_1.describe)('severity', () => {
232
- (0, vitest_1.it)('deve aceitar apenas valores válidos', () => {
233
- const validSeverities = ['ERROR', 'WARN', 'INFO', 'DEBUG'];
234
- validSeverities.forEach((severity) => {
235
- const log = {
236
- severity,
237
- message: 'test',
238
- serviceName: 'test',
239
- environment: 'test',
240
- timestamp: new Date().toISOString(),
241
- };
242
- (0, vitest_1.expect)(log.severity).toBe(severity);
243
- });
244
- });
245
- });
246
- (0, vitest_1.describe)('environment', () => {
247
- (0, vitest_1.it)('deve aceitar ambientes comuns', () => {
248
- const environments = ['development', 'staging', 'production', 'test'];
249
- environments.forEach((env) => {
250
- const log = {
251
- severity: 'INFO',
252
- message: 'test',
253
- serviceName: 'test',
254
- environment: env,
255
- timestamp: new Date().toISOString(),
256
- };
257
- (0, vitest_1.expect)(log.environment).toBe(env);
258
- });
259
- });
260
- });
261
- (0, vitest_1.describe)('timestamp', () => {
262
- (0, vitest_1.it)('deve aceitar formato ISO 8601', () => {
263
- const isoTimestamp = new Date().toISOString();
264
- const log = {
265
- severity: 'INFO',
266
- message: 'test',
267
- serviceName: 'test',
268
- environment: 'test',
269
- timestamp: isoTimestamp,
270
- };
271
- (0, vitest_1.expect)(log.timestamp).toMatch(/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z$/);
272
- });
273
- });
274
- (0, vitest_1.describe)('http.statusCode', () => {
275
- (0, vitest_1.it)('deve aceitar códigos HTTP válidos', () => {
276
- const statusCodes = [200, 201, 400, 401, 404, 500, 502, 503];
277
- statusCodes.forEach((statusCode) => {
278
- var _a;
279
- const log = {
280
- severity: 'INFO',
281
- message: 'test',
282
- serviceName: 'test',
283
- environment: 'test',
284
- http: { statusCode },
285
- timestamp: new Date().toISOString(),
286
- };
287
- (0, vitest_1.expect)((_a = log.http) === null || _a === void 0 ? void 0 : _a.statusCode).toBe(statusCode);
288
- });
289
- });
290
- });
291
- (0, vitest_1.describe)('performance.durationMs', () => {
292
- (0, vitest_1.it)('deve aceitar valores numéricos positivos', () => {
293
- const durations = [0, 100, 500, 1000, 5000, 10000];
294
- durations.forEach((durationMs) => {
295
- var _a;
296
- const log = {
297
- severity: 'INFO',
298
- message: 'test',
299
- serviceName: 'test',
300
- environment: 'test',
301
- performance: { durationMs },
302
- timestamp: new Date().toISOString(),
303
- };
304
- (0, vitest_1.expect)((_a = log.performance) === null || _a === void 0 ? void 0 : _a.durationMs).toBe(durationMs);
305
- });
306
- });
307
- });
308
- (0, vitest_1.describe)('performance.success', () => {
309
- (0, vitest_1.it)('deve aceitar valores booleanos', () => {
310
- [true, false].forEach((success) => {
311
- var _a;
312
- const log = {
313
- severity: 'INFO',
314
- message: 'test',
315
- serviceName: 'test',
316
- environment: 'test',
317
- performance: { success },
318
- timestamp: new Date().toISOString(),
319
- };
320
- (0, vitest_1.expect)((_a = log.performance) === null || _a === void 0 ? void 0 : _a.success).toBe(success);
321
- });
322
- });
323
- });
324
- });
325
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLXR5cGVzLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdGVsZW1ldHJ5L2NvcmUvX190ZXN0c19fL2xvZ2dlci10eXBlcy50ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUEsbUNBQThDO0FBRzlDLElBQUEsaUJBQVEsRUFBQyx5QkFBeUIsRUFBRSxHQUFHLEVBQUU7SUFDdkMsSUFBQSxXQUFFLEVBQUMsZ0NBQWdDLEVBQUUsR0FBRyxFQUFFO1FBQ3hDLE1BQU0sVUFBVSxHQUFvQjtZQUNsQyxRQUFRLEVBQUUsTUFBTTtZQUNoQixPQUFPLEVBQUUsY0FBYztZQUN2QixXQUFXLEVBQUUsY0FBYztZQUMzQixXQUFXLEVBQUUsTUFBTTtZQUNuQixTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLEVBQUU7U0FDcEMsQ0FBQztRQUVGLElBQUEsZUFBTSxFQUFDLFVBQVUsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ2pDLElBQUEsZUFBTSxFQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0MsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFBLFdBQUUsRUFBQywwQ0FBMEMsRUFBRSxHQUFHLEVBQUU7UUFDbEQsTUFBTSxVQUFVLEdBQWtDO1lBQ2hELE9BQU87WUFDUCxNQUFNO1lBQ04sTUFBTTtZQUNOLE9BQU87U0FDUixDQUFDO1FBRUYsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQzlCLE1BQU0sR0FBRyxHQUFvQjtnQkFDM0IsUUFBUTtnQkFDUixPQUFPLEVBQUUsTUFBTTtnQkFDZixXQUFXLEVBQUUsTUFBTTtnQkFDbkIsV0FBVyxFQUFFLE1BQU07Z0JBQ25CLFNBQVMsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRTthQUNwQyxDQUFDO1lBQ0YsSUFBQSxl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RUFBRTtpQkFDcEMsQ0FBQztnQkFDRixJQUFBLGVBQU0sRUFBQyxNQUFBLEdBQUcsQ0FBQyxXQUFXLDBDQUFFLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUN2RCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFBLGlCQUFRLEVBQUMscUJBQXFCLEVBQUUsR0FBRyxFQUFFO1FBQ25DLElBQUEsV0FBRSxFQUFDLGdDQUFnQyxFQUFFLEdBQUcsRUFBRTtZQUN4QyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTs7Z0JBQ2hDLE1BQU0sR0FBRyxHQUFvQjtvQkFDM0IsUUFBUSxFQUFFLE1BQU07b0JBQ2hCLE9BQU8sRUFBRSxNQUFNO29CQUNmLFdBQVcsRUFBRSxNQUFNO29CQUNuQixXQUFXLEVBQUUsTUFBTTtvQkFDbkIsV0FBVyxFQUFFLEVBQUUsT0FBTyxFQUFFO29CQUN4QixTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLEVBQUU7aUJBQ3BDLENBQUM7Z0JBQ0YsSUFBQSxlQUFNLEVBQUMsTUFBQSxHQUFHLENBQUMsV0FBVywwQ0FBRSxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDakQsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkZXNjcmliZSwgaXQsIGV4cGVjdCB9IGZyb20gJ3ZpdGVzdCc7XHJcbmltcG9ydCB0eXBlIHsgU3RhbmRhcmRMb2dEYXRhLCBJU3RhbmRhcmRMb2dnZXIgfSBmcm9tICcuLi9sb2dnZXItdHlwZXMnO1xyXG5cclxuZGVzY3JpYmUoJ1R5cGVzIC0gU3RhbmRhcmRMb2dEYXRhJywgKCkgPT4ge1xyXG4gIGl0KCdkZXZlIGFjZWl0YXIgbG9nIG3DrW5pbW8gdsOhbGlkbycsICgpID0+IHtcclxuICAgIGNvbnN0IG1pbmltYWxMb2c6IFN0YW5kYXJkTG9nRGF0YSA9IHtcclxuICAgICAgc2V2ZXJpdHk6ICdJTkZPJyxcclxuICAgICAgbWVzc2FnZTogJ1Rlc3QgbWVzc2FnZScsXHJcbiAgICAgIHNlcnZpY2VOYW1lOiAndGVzdC1zZXJ2aWNlJyxcclxuICAgICAgZW52aXJvbm1lbnQ6ICd0ZXN0JyxcclxuICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICB9O1xyXG5cclxuICAgIGV4cGVjdChtaW5pbWFsTG9nKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgZXhwZWN0KG1pbmltYWxMb2cuc2V2ZXJpdHkpLnRvQmUoJ0lORk8nKTtcclxuICB9KTtcclxuXHJcbiAgaXQoJ2RldmUgYWNlaXRhciB0b2RvcyBvcyBuw612ZWlzIGRlIHNldmVyaXR5JywgKCkgPT4ge1xyXG4gICAgY29uc3Qgc2V2ZXJpdGllczogU3RhbmRhcmRMb2dEYXRhWydzZXZlcml0eSddW10gPSBbXHJcbiAgICAgICdFUlJPUicsXHJcbiAgICAgICdXQVJOJyxcclxuICAgICAgJ0lORk8nLFxyXG4gICAgICAnREVCVUcnLFxyXG4gICAgXTtcclxuXHJcbiAgICBzZXZlcml0aWVzLmZvckVhY2goKHNldmVyaXR5KSA9PiB7XHJcbiAgICAgIGNvbnN0IGxvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICAgIHNldmVyaXR5LFxyXG4gICAgICAgIG1lc3NhZ2U6ICdUZXN0JyxcclxuICAgICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3QnLFxyXG4gICAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICAgIH07XHJcbiAgICAgIGV4cGVjdChsb2cuc2V2ZXJpdHkpLnRvQmUoc2V2ZXJpdHkpO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGl0KCdkZXZlIGFjZWl0YXIgbG9nIGNvbXBsZXRvIGNvbSB0b2RvcyBvcyBjYW1wb3Mgb3BjaW9uYWlzJywgKCkgPT4ge1xyXG4gICAgY29uc3QgY29tcGxldGVMb2c6IFN0YW5kYXJkTG9nRGF0YSA9IHtcclxuICAgICAgc2V2ZXJpdHk6ICdFUlJPUicsXHJcbiAgICAgIG1lc3NhZ2U6ICdDb21wbGV0ZSBsb2cgbWVzc2FnZScsXHJcbiAgICAgIGVycm9yOiBuZXcgRXJyb3IoJ1Rlc3QgZXJyb3InKSxcclxuICAgICAgc2VydmljZU5hbWU6ICdjb21wbGV0ZS1zZXJ2aWNlJyxcclxuICAgICAgZW52aXJvbm1lbnQ6ICdwcm9kdWN0aW9uJyxcclxuICAgICAgaHR0cDoge1xyXG4gICAgICAgIG1ldGhvZDogJ1BPU1QnLFxyXG4gICAgICAgIHVybDogJ2h0dHBzOi8vYXBpLmV4YW1wbGUuY29tL3Rlc3QnLFxyXG4gICAgICAgIGVuZHBvaW50OiAnL3Rlc3QnLFxyXG4gICAgICAgIHN0YXR1c0NvZGU6IDUwMCxcclxuICAgICAgICBoZWFkZXJzOiB7ICdjb250ZW50LXR5cGUnOiAnYXBwbGljYXRpb24vanNvbicgfSxcclxuICAgICAgICBib2R5OiB7IHRlc3Q6ICdkYXRhJyB9LFxyXG4gICAgICAgIHBhcmFtczogeyBpZDogJzEyMycgfSxcclxuICAgICAgICBxdWVyeTogeyBmaWx0ZXI6ICdhY3RpdmUnIH0sXHJcbiAgICAgIH0sXHJcbiAgICAgIHVzZXI6IHtcclxuICAgICAgICBhY2NvdW50VXNlclVpZDogJ3VzZXItMTIzJyxcclxuICAgICAgICBhY2NvdW50VWlkOiAnYWNjb3VudC00NTYnLFxyXG4gICAgICAgIGFwcGxpY2F0aW9uVWlkOiAnYXBwLTc4OScsXHJcbiAgICAgIH0sXHJcbiAgICAgIGV4ZWN1dGlvbjoge1xyXG4gICAgICAgIHJlcXVlc3RJZDogJ3JlcS1hYmMnLFxyXG4gICAgICAgIGF3c1JlcXVlc3RJZDogJ2F3cy14eXonLFxyXG4gICAgICAgIGZ1bmN0aW9uTmFtZTogJ3Rlc3RGdW5jdGlvbicsXHJcbiAgICAgICAgaW52b2NhdGlvbklkOiAnaW52LTEyMycsXHJcbiAgICAgICAgY29udHJvbGxlcjogJ1Rlc3RDb250cm9sbGVyJyxcclxuICAgICAgICBjb250cm9sbGVyTWV0aG9kOiAndGVzdE1ldGhvZCcsXHJcbiAgICAgICAgb3JpZ2luOiAnbW9iaWxlJyxcclxuICAgICAgfSxcclxuICAgICAgcGVyZm9ybWFuY2U6IHtcclxuICAgICAgICBkdXJhdGlvbk1zOiAxNTAwLFxyXG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxyXG4gICAgICB9LFxyXG4gICAgICBjb250ZXh0OiB7XHJcbiAgICAgICAgY3VzdG9tRmllbGQ6ICdjdXN0b21WYWx1ZScsXHJcbiAgICAgICAgbmVzdGVkOiB7XHJcbiAgICAgICAgICBkYXRhOiAxMjMsXHJcbiAgICAgICAgfSxcclxuICAgICAgfSxcclxuICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICB9O1xyXG5cclxuICAgIGV4cGVjdChjb21wbGV0ZUxvZykudG9CZURlZmluZWQoKTtcclxuICAgIGV4cGVjdChjb21wbGV0ZUxvZy5odHRwKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgZXhwZWN0KGNvbXBsZXRlTG9nLnVzZXIpLnRvQmVEZWZpbmVkKCk7XHJcbiAgICBleHBlY3QoY29tcGxldGVMb2cuZXhlY3V0aW9uKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgZXhwZWN0KGNvbXBsZXRlTG9nLnBlcmZvcm1hbmNlKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgZXhwZWN0KGNvbXBsZXRlTG9nLmNvbnRleHQpLnRvQmVEZWZpbmVkKCk7XHJcbiAgfSk7XHJcblxyXG4gIGl0KCdkZXZlIGFjZWl0YXIgY2FtcG9zIEhUVFAgcGFyY2lhaXMnLCAoKSA9PiB7XHJcbiAgICBjb25zdCBwYXJ0aWFsSHR0cExvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICBzZXZlcml0eTogJ0lORk8nLFxyXG4gICAgICBtZXNzYWdlOiAnUGFydGlhbCBIVFRQJyxcclxuICAgICAgc2VydmljZU5hbWU6ICd0ZXN0JyxcclxuICAgICAgZW52aXJvbm1lbnQ6ICd0ZXN0JyxcclxuICAgICAgaHR0cDoge1xyXG4gICAgICAgIG1ldGhvZDogJ0dFVCcsXHJcbiAgICAgICAgZW5kcG9pbnQ6ICcvYXBpL3VzZXJzJyxcclxuICAgICAgICAvLyBvdXRyb3MgY2FtcG9zIG9wY2lvbmFpcyBvbWl0aWRvc1xyXG4gICAgICB9LFxyXG4gICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcclxuICAgIH07XHJcblxyXG4gICAgZXhwZWN0KHBhcnRpYWxIdHRwTG9nLmh0dHA/Lm1ldGhvZCkudG9CZSgnR0VUJyk7XHJcbiAgICBleHBlY3QocGFydGlhbEh0dHBMb2cuaHR0cD8uZW5kcG9pbnQpLnRvQmUoJy9hcGkvdXNlcnMnKTtcclxuICAgIGV4cGVjdChwYXJ0aWFsSHR0cExvZy5odHRwPy51cmwpLnRvQmVVbmRlZmluZWQoKTtcclxuICB9KTtcclxuXHJcbiAgaXQoJ2RldmUgYWNlaXRhciBjYW1wb3MgZGUgdXN1w6FyaW8gcGFyY2lhaXMnLCAoKSA9PiB7XHJcbiAgICBjb25zdCBwYXJ0aWFsVXNlckxvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICBzZXZlcml0eTogJ0lORk8nLFxyXG4gICAgICBtZXNzYWdlOiAnUGFydGlhbCB1c2VyJyxcclxuICAgICAgc2VydmljZU5hbWU6ICd0ZXN0JyxcclxuICAgICAgZW52aXJvbm1lbnQ6ICd0ZXN0JyxcclxuICAgICAgdXNlcjoge1xyXG4gICAgICAgIGFjY291bnRVc2VyVWlkOiAndXNlci0xMjMnLFxyXG4gICAgICAgIC8vIG91dHJvcyBjYW1wb3Mgb3BjaW9uYWlzIG9taXRpZG9zXHJcbiAgICAgIH0sXHJcbiAgICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxyXG4gICAgfTtcclxuXHJcbiAgICBleHBlY3QocGFydGlhbFVzZXJMb2cudXNlcj8uYWNjb3VudFVzZXJVaWQpLnRvQmUoJ3VzZXItMTIzJyk7XHJcbiAgICBleHBlY3QocGFydGlhbFVzZXJMb2cudXNlcj8uYWNjb3VudFVpZCkudG9CZVVuZGVmaW5lZCgpO1xyXG4gIH0pO1xyXG5cclxuICBpdCgnZGV2ZSBhY2VpdGFyIGNhbXBvcyBkZSBleGVjdcOnw6NvIHBhcmNpYWlzJywgKCkgPT4ge1xyXG4gICAgY29uc3QgcGFydGlhbEV4ZWNMb2c6IFN0YW5kYXJkTG9nRGF0YSA9IHtcclxuICAgICAgc2V2ZXJpdHk6ICdERUJVRycsXHJcbiAgICAgIG1lc3NhZ2U6ICdQYXJ0aWFsIGV4ZWN1dGlvbicsXHJcbiAgICAgIHNlcnZpY2VOYW1lOiAndGVzdCcsXHJcbiAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICAgIGV4ZWN1dGlvbjoge1xyXG4gICAgICAgIHJlcXVlc3RJZDogJ3JlcS0xMjMnLFxyXG4gICAgICAgIGNvbnRyb2xsZXI6ICdUZXN0Q29udHJvbGxlcicsXHJcbiAgICAgICAgLy8gb3V0cm9zIGNhbXBvcyBvcGNpb25haXMgb21pdGlkb3NcclxuICAgICAgfSxcclxuICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICB9O1xyXG5cclxuICAgIGV4cGVjdChwYXJ0aWFsRXhlY0xvZy5leGVjdXRpb24/LnJlcXVlc3RJZCkudG9CZSgncmVxLTEyMycpO1xyXG4gICAgZXhwZWN0KHBhcnRpYWxFeGVjTG9nLmV4ZWN1dGlvbj8uY29udHJvbGxlcikudG9CZSgnVGVzdENvbnRyb2xsZXInKTtcclxuICAgIGV4cGVjdChwYXJ0aWFsRXhlY0xvZy5leGVjdXRpb24/LmF3c1JlcXVlc3RJZCkudG9CZVVuZGVmaW5lZCgpO1xyXG4gIH0pO1xyXG5cclxuICBpdCgnZGV2ZSBhY2VpdGFyIHBlcmZvcm1hbmNlIGNvbSBhcGVuYXMgZHVyYXRpb25NcycsICgpID0+IHtcclxuICAgIGNvbnN0IGR1cmF0aW9uT25seUxvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICBzZXZlcml0eTogJ0lORk8nLFxyXG4gICAgICBtZXNzYWdlOiAnRHVyYXRpb24gb25seScsXHJcbiAgICAgIHNlcnZpY2VOYW1lOiAndGVzdCcsXHJcbiAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICAgIHBlcmZvcm1hbmNlOiB7XHJcbiAgICAgICAgZHVyYXRpb25NczogNTAwLFxyXG4gICAgICB9LFxyXG4gICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcclxuICAgIH07XHJcblxyXG4gICAgZXhwZWN0KGR1cmF0aW9uT25seUxvZy5wZXJmb3JtYW5jZT8uZHVyYXRpb25NcykudG9CZSg1MDApO1xyXG4gICAgZXhwZWN0KGR1cmF0aW9uT25seUxvZy5wZXJmb3JtYW5jZT8uc3VjY2VzcykudG9CZVVuZGVmaW5lZCgpO1xyXG4gIH0pO1xyXG5cclxuICBpdCgnZGV2ZSBhY2VpdGFyIHBlcmZvcm1hbmNlIGNvbSBhcGVuYXMgc3VjY2VzcycsICgpID0+IHtcclxuICAgIGNvbnN0IHN1Y2Nlc3NPbmx5TG9nOiBTdGFuZGFyZExvZ0RhdGEgPSB7XHJcbiAgICAgIHNldmVyaXR5OiAnSU5GTycsXHJcbiAgICAgIG1lc3NhZ2U6ICdTdWNjZXNzIG9ubHknLFxyXG4gICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3QnLFxyXG4gICAgICBlbnZpcm9ubWVudDogJ3Rlc3QnLFxyXG4gICAgICBwZXJmb3JtYW5jZToge1xyXG4gICAgICAgIHN1Y2Nlc3M6IHRydWUsXHJcbiAgICAgIH0sXHJcbiAgICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxyXG4gICAgfTtcclxuXHJcbiAgICBleHBlY3Qoc3VjY2Vzc09ubHlMb2cucGVyZm9ybWFuY2U/LnN1Y2Nlc3MpLnRvQmUodHJ1ZSk7XHJcbiAgICBleHBlY3Qoc3VjY2Vzc09ubHlMb2cucGVyZm9ybWFuY2U/LmR1cmF0aW9uTXMpLnRvQmVVbmRlZmluZWQoKTtcclxuICB9KTtcclxuXHJcbiAgaXQoJ2RldmUgYWNlaXRhciBjb250ZXh0byBjb20gZXN0cnV0dXJhcyBhbmluaGFkYXMgY29tcGxleGFzJywgKCkgPT4ge1xyXG4gICAgY29uc3QgY29tcGxleENvbnRleHRMb2c6IFN0YW5kYXJkTG9nRGF0YSA9IHtcclxuICAgICAgc2V2ZXJpdHk6ICdFUlJPUicsXHJcbiAgICAgIG1lc3NhZ2U6ICdDb21wbGV4IGNvbnRleHQnLFxyXG4gICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3QnLFxyXG4gICAgICBlbnZpcm9ubWVudDogJ3Rlc3QnLFxyXG4gICAgICBjb250ZXh0OiB7XHJcbiAgICAgICAgbGV2ZWwxOiB7XHJcbiAgICAgICAgICBsZXZlbDI6IHtcclxuICAgICAgICAgICAgbGV2ZWwzOiB7XHJcbiAgICAgICAgICAgICAgdmFsdWU6ICdkZWVwJyxcclxuICAgICAgICAgICAgICBhcnJheTogWzEsIDIsIDNdLFxyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgICAgfSxcclxuICAgICAgICB9LFxyXG4gICAgICAgIHNpbXBsZVZhbHVlOiAndGVzdCcsXHJcbiAgICAgICAgbnVtZXJpY1ZhbHVlOiAxMjMsXHJcbiAgICAgICAgYm9vbGVhblZhbHVlOiB0cnVlLFxyXG4gICAgICB9LFxyXG4gICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcclxuICAgIH07XHJcblxyXG4gICAgZXhwZWN0KGNvbXBsZXhDb250ZXh0TG9nLmNvbnRleHQ/LmxldmVsMSkudG9CZURlZmluZWQoKTtcclxuICAgIGV4cGVjdChjb21wbGV4Q29udGV4dExvZy5jb250ZXh0Py5zaW1wbGVWYWx1ZSkudG9CZSgndGVzdCcpO1xyXG4gIH0pO1xyXG59KTtcclxuXHJcbmRlc2NyaWJlKCdUeXBlcyAtIElTdGFuZGFyZExvZ2dlcicsICgpID0+IHtcclxuICBpdCgnZGV2ZSBkZWZpbmlyIGludGVyZmFjZSBjb20gb3MgNCBtw6l0b2RvcyBkZSBsb2cnLCAoKSA9PiB7XHJcbiAgICAvLyBFc3RlIMOpIHVtIHRlc3RlIGRlIHRpcG8sIHPDsyBwYXJhIGdhcmFudGlyIHF1ZSBhIGludGVyZmFjZSBlc3TDoSBjb3JyZXRhXHJcbiAgICBjb25zdCBtb2NrTG9nZ2VyOiBJU3RhbmRhcmRMb2dnZXIgPSB7XHJcbiAgICAgIGxvZ0Vycm9yOiBhc3luYyAoKSA9PiB7fSxcclxuICAgICAgbG9nSW5mbzogYXN5bmMgKCkgPT4ge30sXHJcbiAgICAgIGxvZ1dhcm46IGFzeW5jICgpID0+IHt9LFxyXG4gICAgICBsb2dEZWJ1ZzogYXN5bmMgKCkgPT4ge30sXHJcbiAgICB9O1xyXG5cclxuICAgIGV4cGVjdChtb2NrTG9nZ2VyLmxvZ0Vycm9yKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgZXhwZWN0KG1vY2tMb2dnZXIubG9nSW5mbykudG9CZURlZmluZWQoKTtcclxuICAgIGV4cGVjdChtb2NrTG9nZ2VyLmxvZ1dhcm4pLnRvQmVEZWZpbmVkKCk7XHJcbiAgICBleHBlY3QobW9ja0xvZ2dlci5sb2dEZWJ1ZykudG9CZURlZmluZWQoKTtcclxuICB9KTtcclxuXHJcbiAgaXQoJ2RldmUgYWNlaXRhciBkYWRvcyBzZW0gc2V2ZXJpdHkgZSB0aW1lc3RhbXAgbm9zIG3DqXRvZG9zJywgYXN5bmMgKCkgPT4ge1xyXG4gICAgY29uc3QgbW9ja0xvZ2dlcjogSVN0YW5kYXJkTG9nZ2VyID0ge1xyXG4gICAgICBsb2dFcnJvcjogYXN5bmMgKGRhdGEpID0+IHtcclxuICAgICAgICBleHBlY3QoZGF0YS5tZXNzYWdlKS50b0JlKCdFcnJvciBtZXNzYWdlJyk7XHJcbiAgICAgICAgZXhwZWN0KGRhdGEuc2VydmljZU5hbWUpLnRvQmUoJ3Rlc3QnKTtcclxuICAgICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIC0gc2V2ZXJpdHkgbsOjbyBkZXZlIGV4aXN0aXJcclxuICAgICAgICBleHBlY3QoZGF0YS5zZXZlcml0eSkudG9CZVVuZGVmaW5lZCgpO1xyXG4gICAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgLSB0aW1lc3RhbXAgbsOjbyBkZXZlIGV4aXN0aXJcclxuICAgICAgICBleHBlY3QoZGF0YS50aW1lc3RhbXApLnRvQmVVbmRlZmluZWQoKTtcclxuICAgICAgfSxcclxuICAgICAgbG9nSW5mbzogYXN5bmMgKCkgPT4ge30sXHJcbiAgICAgIGxvZ1dhcm46IGFzeW5jICgpID0+IHt9LFxyXG4gICAgICBsb2dEZWJ1ZzogYXN5bmMgKCkgPT4ge30sXHJcbiAgICB9O1xyXG5cclxuICAgIGF3YWl0IG1vY2tMb2dnZXIubG9nRXJyb3Ioe1xyXG4gICAgICBtZXNzYWdlOiAnRXJyb3IgbWVzc2FnZScsXHJcbiAgICAgIHNlcnZpY2VOYW1lOiAndGVzdCcsXHJcbiAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICB9KTtcclxuICB9KTtcclxufSk7XHJcblxyXG5kZXNjcmliZSgnVHlwZXMgLSBWYWxpZGHDp8OjbyBkZSBjYW1wb3MnLCAoKSA9PiB7XHJcbiAgZGVzY3JpYmUoJ3NldmVyaXR5JywgKCkgPT4ge1xyXG4gICAgaXQoJ2RldmUgYWNlaXRhciBhcGVuYXMgdmFsb3JlcyB2w6FsaWRvcycsICgpID0+IHtcclxuICAgICAgY29uc3QgdmFsaWRTZXZlcml0aWVzID0gWydFUlJPUicsICdXQVJOJywgJ0lORk8nLCAnREVCVUcnXSBhcyBjb25zdDtcclxuXHJcbiAgICAgIHZhbGlkU2V2ZXJpdGllcy5mb3JFYWNoKChzZXZlcml0eSkgPT4ge1xyXG4gICAgICAgIGNvbnN0IGxvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICAgICAgc2V2ZXJpdHksXHJcbiAgICAgICAgICBtZXNzYWdlOiAndGVzdCcsXHJcbiAgICAgICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3QnLFxyXG4gICAgICAgICAgZW52aXJvbm1lbnQ6ICd0ZXN0JyxcclxuICAgICAgICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxyXG4gICAgICAgIH07XHJcbiAgICAgICAgZXhwZWN0KGxvZy5zZXZlcml0eSkudG9CZShzZXZlcml0eSk7XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGRlc2NyaWJlKCdlbnZpcm9ubWVudCcsICgpID0+IHtcclxuICAgIGl0KCdkZXZlIGFjZWl0YXIgYW1iaWVudGVzIGNvbXVucycsICgpID0+IHtcclxuICAgICAgY29uc3QgZW52aXJvbm1lbnRzID0gWydkZXZlbG9wbWVudCcsICdzdGFnaW5nJywgJ3Byb2R1Y3Rpb24nLCAndGVzdCddO1xyXG5cclxuICAgICAgZW52aXJvbm1lbnRzLmZvckVhY2goKGVudikgPT4ge1xyXG4gICAgICAgIGNvbnN0IGxvZzogU3RhbmRhcmRMb2dEYXRhID0ge1xyXG4gICAgICAgICAgc2V2ZXJpdHk6ICdJTkZPJyxcclxuICAgICAgICAgIG1lc3NhZ2U6ICd0ZXN0JyxcclxuICAgICAgICAgIHNlcnZpY2VOYW1lOiAndGVzdCcsXHJcbiAgICAgICAgICBlbnZpcm9ubWVudDogZW52LFxyXG4gICAgICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICAgICAgfTtcclxuICAgICAgICBleHBlY3QobG9nLmVudmlyb25tZW50KS50b0JlKGVudik7XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGRlc2NyaWJlKCd0aW1lc3RhbXAnLCAoKSA9PiB7XHJcbiAgICBpdCgnZGV2ZSBhY2VpdGFyIGZvcm1hdG8gSVNPIDg2MDEnLCAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IGlzb1RpbWVzdGFtcCA9IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKTtcclxuICAgICAgY29uc3QgbG9nOiBTdGFuZGFyZExvZ0RhdGEgPSB7XHJcbiAgICAgICAgc2V2ZXJpdHk6ICdJTkZPJyxcclxuICAgICAgICBtZXNzYWdlOiAndGVzdCcsXHJcbiAgICAgICAgc2VydmljZU5hbWU6ICd0ZXN0JyxcclxuICAgICAgICBlbnZpcm9ubWVudDogJ3Rlc3QnLFxyXG4gICAgICAgIHRpbWVzdGFtcDogaXNvVGltZXN0YW1wLFxyXG4gICAgICB9O1xyXG5cclxuICAgICAgZXhwZWN0KGxvZy50aW1lc3RhbXApLnRvTWF0Y2goXHJcbiAgICAgICAgL15cXGR7NH0tXFxkezJ9LVxcZHsyfVRcXGR7Mn06XFxkezJ9OlxcZHsyfVxcLlxcZHszfVokL1xyXG4gICAgICApO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGRlc2NyaWJlKCdodHRwLnN0YXR1c0NvZGUnLCAoKSA9PiB7XHJcbiAgICBpdCgnZGV2ZSBhY2VpdGFyIGPDs2RpZ29zIEhUVFAgdsOhbGlkb3MnLCAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHN0YXR1c0NvZGVzID0gWzIwMCwgMjAxLCA0MDAsIDQwMSwgNDA0LCA1MDAsIDUwMiwgNTAzXTtcclxuXHJcbiAgICAgIHN0YXR1c0NvZGVzLmZvckVhY2goKHN0YXR1c0NvZGUpID0+IHtcclxuICAgICAgICBjb25zdCBsb2c6IFN0YW5kYXJkTG9nRGF0YSA9IHtcclxuICAgICAgICAgIHNldmVyaXR5OiAnSU5GTycsXHJcbiAgICAgICAgICBtZXNzYWdlOiAndGVzdCcsXHJcbiAgICAgICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3QnLFxyXG4gICAgICAgICAgZW52aXJvbm1lbnQ6ICd0ZXN0JyxcclxuICAgICAgICAgIGh0dHA6IHsgc3RhdHVzQ29kZSB9LFxyXG4gICAgICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXHJcbiAgICAgICAgfTtcclxuICAgICAgICBleHBlY3QobG9nLmh0dHA/LnN0YXR1c0NvZGUpLnRvQmUoc3RhdHVzQ29kZSk7XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGRlc2NyaWJlKCdwZXJmb3JtYW5jZS5kdXJhdGlvbk1zJywgKCkgPT4ge1xyXG4gICAgaXQoJ2RldmUgYWNlaXRhciB2YWxvcmVzIG51bcOpcmljb3MgcG9zaXRpdm9zJywgKCkgPT4ge1xyXG4gICAgICBjb25zdCBkdXJhdGlvbnMgPSBbMCwgMTAwLCA1MDAsIDEwMDAsIDUwMDAsIDEwMDAwXTtcclxuXHJcbiAgICAgIGR1cmF0aW9ucy5mb3JFYWNoKChkdXJhdGlvbk1zKSA9PiB7XHJcbiAgICAgICAgY29uc3QgbG9nOiBTdGFuZGFyZExvZ0RhdGEgPSB7XHJcbiAgICAgICAgICBzZXZlcml0eTogJ0lORk8nLFxyXG4gICAgICAgICAgbWVzc2FnZTogJ3Rlc3QnLFxyXG4gICAgICAgICAgc2VydmljZU5hbWU6ICd0ZXN0JyxcclxuICAgICAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICAgICAgICBwZXJmb3JtYW5jZTogeyBkdXJhdGlvbk1zIH0sXHJcbiAgICAgICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcclxuICAgICAgICB9O1xyXG4gICAgICAgIGV4cGVjdChsb2cucGVyZm9ybWFuY2U/LmR1cmF0aW9uTXMpLnRvQmUoZHVyYXRpb25Ncyk7XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcblxyXG4gIGRlc2NyaWJlKCdwZXJmb3JtYW5jZS5zdWNjZXNzJywgKCkgPT4ge1xyXG4gICAgaXQoJ2RldmUgYWNlaXRhciB2YWxvcmVzIGJvb2xlYW5vcycsICgpID0+IHtcclxuICAgICAgW3RydWUsIGZhbHNlXS5mb3JFYWNoKChzdWNjZXNzKSA9PiB7XHJcbiAgICAgICAgY29uc3QgbG9nOiBTdGFuZGFyZExvZ0RhdGEgPSB7XHJcbiAgICAgICAgICBzZXZlcml0eTogJ0lORk8nLFxyXG4gICAgICAgICAgbWVzc2FnZTogJ3Rlc3QnLFxyXG4gICAgICAgICAgc2VydmljZU5hbWU6ICd0ZXN0JyxcclxuICAgICAgICAgIGVudmlyb25tZW50OiAndGVzdCcsXHJcbiAgICAgICAgICBwZXJmb3JtYW5jZTogeyBzdWNjZXNzIH0sXHJcbiAgICAgICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcclxuICAgICAgICB9O1xyXG4gICAgICAgIGV4cGVjdChsb2cucGVyZm9ybWFuY2U/LnN1Y2Nlc3MpLnRvQmUoc3VjY2Vzcyk7XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfSk7XHJcbn0pO1xyXG4iXX0=
@@ -1 +0,0 @@
1
- export {};