@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.
- package/.github/workflows/pull_request.yml +32 -32
- package/.github/workflows/release.yml +129 -129
- package/.prettierignore +4 -4
- package/CHANGELOG.md +14 -0
- package/DOCS_GUIDE.md +151 -0
- package/README.md +248 -0
- package/dist/core/__tests__/logger-types.test.d.ts +1 -0
- package/dist/core/__tests__/logger-types.test.js +325 -0
- package/dist/core/__tests__/logger.test.d.ts +1 -0
- package/dist/core/__tests__/logger.test.js +337 -0
- package/dist/core/__tests__/tracer.test.d.ts +1 -0
- package/dist/core/__tests__/tracer.test.js +330 -0
- package/dist/core/index.d.ts +4 -0
- package/dist/core/index.js +8 -0
- package/dist/core/logger-types.d.ts +43 -0
- package/dist/core/logger-types.js +3 -0
- package/dist/core/logger.d.ts +13 -0
- package/dist/core/logger.js +123 -0
- package/dist/core/tracer-types.d.ts +50 -0
- package/dist/core/tracer-types.js +3 -0
- package/dist/core/tracer.d.ts +10 -0
- package/dist/core/tracer.js +114 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.js +4 -2
- package/dist/sst/__tests__/telemetry.test.d.ts +1 -0
- package/dist/sst/__tests__/telemetry.test.js +138 -0
- package/dist/sst/index.d.ts +1 -0
- package/dist/sst/index.js +18 -0
- package/dist/sst/middy/index.d.ts +1 -0
- package/dist/sst/middy/index.js +18 -0
- package/dist/sst/middy/middleware.d.ts +5 -0
- package/dist/sst/middy/middleware.js +157 -0
- package/dist/sst/telemetry.d.ts +4 -0
- package/dist/sst/telemetry.js +121 -0
- package/dist/telemetry/core/__tests__/logger-types.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/logger-types.test.js +325 -0
- package/dist/telemetry/core/__tests__/logger.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/logger.test.js +337 -0
- package/dist/telemetry/core/__tests__/tracer.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/tracer.test.js +330 -0
- package/dist/telemetry/core/index.d.ts +4 -0
- package/dist/telemetry/core/index.js +8 -0
- package/dist/telemetry/core/logger-types.d.ts +43 -0
- package/dist/telemetry/core/logger-types.js +3 -0
- package/dist/telemetry/core/logger.d.ts +13 -0
- package/dist/telemetry/core/logger.js +123 -0
- package/dist/telemetry/core/tracer-types.d.ts +50 -0
- package/dist/telemetry/core/tracer-types.js +3 -0
- package/dist/telemetry/core/tracer.d.ts +10 -0
- package/dist/telemetry/core/tracer.js +114 -0
- package/dist/telemetry/index.d.ts +3 -0
- package/dist/telemetry/index.js +20 -0
- package/dist/telemetry/sst/__tests__/telemetry.test.d.ts +1 -0
- package/dist/telemetry/sst/__tests__/telemetry.test.js +138 -0
- package/dist/telemetry/sst/index.d.ts +1 -0
- package/dist/telemetry/sst/index.js +18 -0
- package/dist/telemetry/sst/middy/index.d.ts +1 -0
- package/dist/telemetry/sst/middy/index.js +18 -0
- package/dist/telemetry/sst/middy/middleware.d.ts +5 -0
- package/dist/telemetry/sst/middy/middleware.js +157 -0
- package/dist/telemetry/sst/telemetry.d.ts +4 -0
- package/dist/telemetry/sst/telemetry.js +121 -0
- package/dist/telemetry/tsed/__tests__/config.test.d.ts +1 -0
- package/dist/telemetry/tsed/__tests__/config.test.js +146 -0
- package/dist/telemetry/tsed/__tests__/service.test.d.ts +1 -0
- package/dist/telemetry/tsed/__tests__/service.test.js +63 -0
- package/dist/telemetry/tsed/config.d.ts +26 -0
- package/dist/telemetry/tsed/config.js +166 -0
- package/dist/telemetry/tsed/index.d.ts +4 -0
- package/dist/telemetry/tsed/index.js +21 -0
- package/dist/telemetry/tsed/log-telemetry.d.ts +1 -0
- package/dist/telemetry/tsed/log-telemetry.js +196 -0
- package/dist/telemetry/tsed/service.d.ts +26 -0
- package/dist/telemetry/tsed/service.js +150 -0
- package/dist/telemetry/tsed/sync-log-record-processor.d.ts +11 -0
- package/dist/telemetry/tsed/sync-log-record-processor.js +74 -0
- package/dist/tsed/__tests__/config.test.d.ts +1 -0
- package/dist/tsed/__tests__/config.test.js +146 -0
- package/dist/tsed/__tests__/service.test.d.ts +1 -0
- package/dist/tsed/__tests__/service.test.js +63 -0
- package/dist/tsed/config.d.ts +26 -0
- package/dist/tsed/config.js +166 -0
- package/dist/tsed/index.d.ts +4 -0
- package/dist/tsed/index.js +21 -0
- package/dist/tsed/log-telemetry.d.ts +1 -0
- package/dist/tsed/log-telemetry.js +196 -0
- package/dist/tsed/service.d.ts +26 -0
- package/dist/tsed/service.js +150 -0
- package/dist/tsed/sync-log-record-processor.d.ts +11 -0
- package/dist/tsed/sync-log-record-processor.js +74 -0
- package/package.json +72 -56
- package/release.config.js +23 -23
- package/vitest.config.ts +22 -0
- package/dist/check-if-is-working.d.ts +0 -1
- package/dist/check-if-is-working.js +0 -8
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
36
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
37
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
38
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
39
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
40
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
41
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
+
exports.forceFlush = exports.getStandardTracer = exports.getStandardLogger = void 0;
|
|
46
|
+
const sdk_node_1 = require("@opentelemetry/sdk-node");
|
|
47
|
+
const exporter_trace_otlp_http_1 = require("@opentelemetry/exporter-trace-otlp-http");
|
|
48
|
+
const exporter_metrics_otlp_http_1 = require("@opentelemetry/exporter-metrics-otlp-http");
|
|
49
|
+
const exporter_logs_otlp_http_1 = require("@opentelemetry/exporter-logs-otlp-http");
|
|
50
|
+
const sdk_metrics_1 = require("@opentelemetry/sdk-metrics");
|
|
51
|
+
const logs = __importStar(require("@opentelemetry/sdk-logs"));
|
|
52
|
+
const resources = __importStar(require("@opentelemetry/resources"));
|
|
53
|
+
const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
|
|
54
|
+
const api_1 = require("@opentelemetry/api");
|
|
55
|
+
const core_1 = require("../core");
|
|
56
|
+
const user = process.env.OTEL_EXPORTER_OTLP_USER;
|
|
57
|
+
const password = process.env.OTEL_EXPORTER_OTLP_PASS;
|
|
58
|
+
const basicAuth = Buffer.from(`${user}:${password}`).toString('base64');
|
|
59
|
+
const baseUrl = `${process.env.OTEL_EXPORTER_OTLP_ENDPOINT}/v1`;
|
|
60
|
+
const traceExporter = new exporter_trace_otlp_http_1.OTLPTraceExporter({
|
|
61
|
+
url: `${baseUrl}/traces`,
|
|
62
|
+
headers: {
|
|
63
|
+
Authorization: `Basic ${basicAuth}`,
|
|
64
|
+
'Content-Type': 'application/json',
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
const metricExporter = new exporter_metrics_otlp_http_1.OTLPMetricExporter({
|
|
68
|
+
url: `${baseUrl}/metrics`,
|
|
69
|
+
headers: {
|
|
70
|
+
Authorization: `Basic ${basicAuth}`,
|
|
71
|
+
'Content-Type': 'application/json',
|
|
72
|
+
},
|
|
73
|
+
});
|
|
74
|
+
const logExporter = new exporter_logs_otlp_http_1.OTLPLogExporter({
|
|
75
|
+
url: `${baseUrl}/logs`,
|
|
76
|
+
headers: {
|
|
77
|
+
Authorization: `Basic ${basicAuth}`,
|
|
78
|
+
'Content-Type': 'application/json',
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
const metricReader = new sdk_metrics_1.PeriodicExportingMetricReader({
|
|
82
|
+
exporter: metricExporter,
|
|
83
|
+
exportIntervalMillis: 1000,
|
|
84
|
+
});
|
|
85
|
+
const serviceName = process.env.SERVICE_NAME || 'sst-service';
|
|
86
|
+
const resource = new resources.Resource({
|
|
87
|
+
[semantic_conventions_1.ATTR_SERVICE_NAME]: serviceName,
|
|
88
|
+
});
|
|
89
|
+
const loggerProvider = new logs.LoggerProvider({ resource });
|
|
90
|
+
const logRecordProcessor = new logs.BatchLogRecordProcessor(logExporter);
|
|
91
|
+
loggerProvider.addLogRecordProcessor(logRecordProcessor);
|
|
92
|
+
const sdk = new sdk_node_1.NodeSDK({
|
|
93
|
+
traceExporter,
|
|
94
|
+
metricReader: metricReader,
|
|
95
|
+
});
|
|
96
|
+
sdk.start();
|
|
97
|
+
let standardLogger = null;
|
|
98
|
+
let standardTracer = null;
|
|
99
|
+
const getStandardLogger = () => {
|
|
100
|
+
if (!standardLogger) {
|
|
101
|
+
const logger = loggerProvider.getLogger('sst-middleware-logger', '1.0.0');
|
|
102
|
+
standardLogger = new core_1.StandardLogger(logger, serviceName);
|
|
103
|
+
}
|
|
104
|
+
return standardLogger;
|
|
105
|
+
};
|
|
106
|
+
exports.getStandardLogger = getStandardLogger;
|
|
107
|
+
const getStandardTracer = () => {
|
|
108
|
+
if (!standardTracer) {
|
|
109
|
+
const tracer = api_1.trace.getTracer(serviceName, '1.0.0');
|
|
110
|
+
standardTracer = new core_1.StandardTracer(tracer, serviceName);
|
|
111
|
+
}
|
|
112
|
+
return standardTracer;
|
|
113
|
+
};
|
|
114
|
+
exports.getStandardTracer = getStandardTracer;
|
|
115
|
+
const forceFlush = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
116
|
+
yield metricReader.forceFlush();
|
|
117
|
+
yield traceExporter.forceFlush();
|
|
118
|
+
yield loggerProvider.forceFlush();
|
|
119
|
+
});
|
|
120
|
+
exports.forceFlush = forceFlush;
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsZW1ldHJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NzdC90ZWxlbWV0cnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0RBQWtEO0FBQ2xELHNGQUE0RTtBQUM1RSwwRkFBK0U7QUFDL0Usb0ZBQXlFO0FBQ3pFLDREQUEyRTtBQUMzRSw4REFBZ0Q7QUFDaEQsb0VBQXNEO0FBQ3RELDhFQUF3RTtBQUN4RSw0Q0FBMkM7QUFDM0Msa0NBQXlEO0FBRXpELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUM7QUFDakQsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQztBQUVyRCxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLFFBQVEsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRXhFLE1BQU0sT0FBTyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsS0FBSyxDQUFDO0FBRWhFLE1BQU0sYUFBYSxHQUFHLElBQUksNENBQWlCLENBQUM7SUFDMUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxTQUFTO0lBQ3hCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSwrQ0FBa0IsQ0FBQztJQUM1QyxHQUFHLEVBQUUsR0FBRyxPQUFPLFVBQVU7SUFDekIsT0FBTyxFQUFFO1FBQ1AsYUFBYSxFQUFFLFNBQVMsU0FBUyxFQUFFO1FBQ25DLGNBQWMsRUFBRSxrQkFBa0I7S0FDbkM7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLFdBQVcsR0FBRyxJQUFJLHlDQUFlLENBQUM7SUFDdEMsR0FBRyxFQUFFLEdBQUcsT0FBTyxPQUFPO0lBQ3RCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSwyQ0FBNkIsQ0FBQztJQUNyRCxRQUFRLEVBQUUsY0FBYztJQUN4QixvQkFBb0IsRUFBRSxJQUFJO0NBQzNCLENBQUMsQ0FBQztBQUdILE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxJQUFJLGFBQWEsQ0FBQztBQUM5RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUM7SUFDdEMsQ0FBQyx3Q0FBaUIsQ0FBQyxFQUFFLFdBQVc7Q0FDakMsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUM3RCxNQUFNLGtCQUFrQixHQUFHLElBQUksSUFBSSxDQUFDLHVCQUF1QixDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3pFLGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBRXpELE1BQU0sR0FBRyxHQUFHLElBQUksa0JBQU8sQ0FBQztJQUN0QixhQUFhO0lBQ2IsWUFBWSxFQUFFLFlBQW1CO0NBQ2xDLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUdaLElBQUksY0FBYyxHQUEwQixJQUFJLENBQUM7QUFDakQsSUFBSSxjQUFjLEdBQTBCLElBQUksQ0FBQztBQUUxQyxNQUFNLGlCQUFpQixHQUFHLEdBQW1CLEVBQUU7SUFDcEQsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3BCLE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxTQUFTLENBQUMsdUJBQXVCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDMUUsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQU5XLFFBQUEsaUJBQWlCLHFCQU01QjtBQUVLLE1BQU0saUJBQWlCLEdBQUcsR0FBbUIsRUFBRTtJQUNwRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDcEIsTUFBTSxNQUFNLEdBQUcsV0FBSyxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDckQsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQU5XLFFBQUEsaUJBQWlCLHFCQU01QjtBQUVLLE1BQU0sVUFBVSxHQUFHLEdBQVMsRUFBRTtJQUNuQyxNQUFNLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNoQyxNQUFNLGFBQWEsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNqQyxNQUFNLGNBQWMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUNwQyxDQUFDLENBQUEsQ0FBQztBQUpXLFFBQUEsVUFBVSxjQUlyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vZGVTREsgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbm9kZSc7XHJcbmltcG9ydCB7IE9UTFBUcmFjZUV4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItdHJhY2Utb3RscC1odHRwJztcclxuaW1wb3J0IHsgT1RMUE1ldHJpY0V4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItbWV0cmljcy1vdGxwLWh0dHAnO1xyXG5pbXBvcnQgeyBPVExQTG9nRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1sb2dzLW90bHAtaHR0cCc7XHJcbmltcG9ydCB7IFBlcmlvZGljRXhwb3J0aW5nTWV0cmljUmVhZGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2RrLW1ldHJpY3MnO1xyXG5pbXBvcnQgKiBhcyBsb2dzIGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Nkay1sb2dzJztcclxuaW1wb3J0ICogYXMgcmVzb3VyY2VzIGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Jlc291cmNlcyc7XHJcbmltcG9ydCB7IEFUVFJfU0VSVklDRV9OQU1FIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2VtYW50aWMtY29udmVudGlvbnMnO1xyXG5pbXBvcnQgeyB0cmFjZSB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L2FwaSc7XHJcbmltcG9ydCB7IFN0YW5kYXJkTG9nZ2VyLCBTdGFuZGFyZFRyYWNlciB9IGZyb20gJy4uL2NvcmUnO1xyXG5cclxuY29uc3QgdXNlciA9IHByb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9VU0VSO1xyXG5jb25zdCBwYXNzd29yZCA9IHByb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9QQVNTO1xyXG5cclxuY29uc3QgYmFzaWNBdXRoID0gQnVmZmVyLmZyb20oYCR7dXNlcn06JHtwYXNzd29yZH1gKS50b1N0cmluZygnYmFzZTY0Jyk7XHJcblxyXG5jb25zdCBiYXNlVXJsID0gYCR7cHJvY2Vzcy5lbnYuT1RFTF9FWFBPUlRFUl9PVExQX0VORFBPSU5UfS92MWA7XHJcblxyXG5jb25zdCB0cmFjZUV4cG9ydGVyID0gbmV3IE9UTFBUcmFjZUV4cG9ydGVyKHtcclxuICB1cmw6IGAke2Jhc2VVcmx9L3RyYWNlc2AsXHJcbiAgaGVhZGVyczoge1xyXG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXHJcbiAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxyXG4gIH0sXHJcbn0pO1xyXG5cclxuY29uc3QgbWV0cmljRXhwb3J0ZXIgPSBuZXcgT1RMUE1ldHJpY0V4cG9ydGVyKHtcclxuICB1cmw6IGAke2Jhc2VVcmx9L21ldHJpY3NgLFxyXG4gIGhlYWRlcnM6IHtcclxuICAgIEF1dGhvcml6YXRpb246IGBCYXNpYyAke2Jhc2ljQXV0aH1gLFxyXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICB9LFxyXG59KTtcclxuXHJcbmNvbnN0IGxvZ0V4cG9ydGVyID0gbmV3IE9UTFBMb2dFeHBvcnRlcih7XHJcbiAgdXJsOiBgJHtiYXNlVXJsfS9sb2dzYCxcclxuICBoZWFkZXJzOiB7XHJcbiAgICBBdXRob3JpemF0aW9uOiBgQmFzaWMgJHtiYXNpY0F1dGh9YCxcclxuICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXHJcbiAgfSxcclxufSk7XHJcblxyXG5jb25zdCBtZXRyaWNSZWFkZXIgPSBuZXcgUGVyaW9kaWNFeHBvcnRpbmdNZXRyaWNSZWFkZXIoe1xyXG4gIGV4cG9ydGVyOiBtZXRyaWNFeHBvcnRlcixcclxuICBleHBvcnRJbnRlcnZhbE1pbGxpczogMTAwMCxcclxufSk7XHJcblxyXG4vLyBDb25maWd1cmFyIExvZ2dlclByb3ZpZGVyXHJcbmNvbnN0IHNlcnZpY2VOYW1lID0gcHJvY2Vzcy5lbnYuU0VSVklDRV9OQU1FIHx8ICdzc3Qtc2VydmljZSc7XHJcbmNvbnN0IHJlc291cmNlID0gbmV3IHJlc291cmNlcy5SZXNvdXJjZSh7XHJcbiAgW0FUVFJfU0VSVklDRV9OQU1FXTogc2VydmljZU5hbWUsXHJcbn0pO1xyXG5cclxuY29uc3QgbG9nZ2VyUHJvdmlkZXIgPSBuZXcgbG9ncy5Mb2dnZXJQcm92aWRlcih7IHJlc291cmNlIH0pO1xyXG5jb25zdCBsb2dSZWNvcmRQcm9jZXNzb3IgPSBuZXcgbG9ncy5CYXRjaExvZ1JlY29yZFByb2Nlc3Nvcihsb2dFeHBvcnRlcik7XHJcbmxvZ2dlclByb3ZpZGVyLmFkZExvZ1JlY29yZFByb2Nlc3Nvcihsb2dSZWNvcmRQcm9jZXNzb3IpO1xyXG5cclxuY29uc3Qgc2RrID0gbmV3IE5vZGVTREsoe1xyXG4gIHRyYWNlRXhwb3J0ZXIsXHJcbiAgbWV0cmljUmVhZGVyOiBtZXRyaWNSZWFkZXIgYXMgYW55LCAvLyBUeXBlIGNvbXBhdGliaWxpdHkgd29ya2Fyb3VuZFxyXG59KTtcclxuXHJcbnNkay5zdGFydCgpO1xyXG5cclxuLy8gQ3JpYXIgU3RhbmRhcmRMb2dnZXIgcGFyYSBzZXIgdXNhZG8gbm9zIG1pZGRsZXdhcmVzXHJcbmxldCBzdGFuZGFyZExvZ2dlcjogU3RhbmRhcmRMb2dnZXIgfCBudWxsID0gbnVsbDtcclxubGV0IHN0YW5kYXJkVHJhY2VyOiBTdGFuZGFyZFRyYWNlciB8IG51bGwgPSBudWxsO1xyXG5cclxuZXhwb3J0IGNvbnN0IGdldFN0YW5kYXJkTG9nZ2VyID0gKCk6IFN0YW5kYXJkTG9nZ2VyID0+IHtcclxuICBpZiAoIXN0YW5kYXJkTG9nZ2VyKSB7XHJcbiAgICBjb25zdCBsb2dnZXIgPSBsb2dnZXJQcm92aWRlci5nZXRMb2dnZXIoJ3NzdC1taWRkbGV3YXJlLWxvZ2dlcicsICcxLjAuMCcpO1xyXG4gICAgc3RhbmRhcmRMb2dnZXIgPSBuZXcgU3RhbmRhcmRMb2dnZXIobG9nZ2VyLCBzZXJ2aWNlTmFtZSk7XHJcbiAgfVxyXG4gIHJldHVybiBzdGFuZGFyZExvZ2dlcjtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRTdGFuZGFyZFRyYWNlciA9ICgpOiBTdGFuZGFyZFRyYWNlciA9PiB7XHJcbiAgaWYgKCFzdGFuZGFyZFRyYWNlcikge1xyXG4gICAgY29uc3QgdHJhY2VyID0gdHJhY2UuZ2V0VHJhY2VyKHNlcnZpY2VOYW1lLCAnMS4wLjAnKTtcclxuICAgIHN0YW5kYXJkVHJhY2VyID0gbmV3IFN0YW5kYXJkVHJhY2VyKHRyYWNlciwgc2VydmljZU5hbWUpO1xyXG4gIH1cclxuICByZXR1cm4gc3RhbmRhcmRUcmFjZXI7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgZm9yY2VGbHVzaCA9IGFzeW5jICgpID0+IHtcclxuICBhd2FpdCBtZXRyaWNSZWFkZXIuZm9yY2VGbHVzaCgpO1xyXG4gIGF3YWl0IHRyYWNlRXhwb3J0ZXIuZm9yY2VGbHVzaCgpO1xyXG4gIGF3YWl0IGxvZ2dlclByb3ZpZGVyLmZvcmNlRmx1c2goKTtcclxufTtcclxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,325 @@
|
|
|
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=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|