k6-perf-reporter 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. package/.claude/settings.local.json +54 -0
  2. package/.config.example.json +8 -0
  3. package/.config.json +8 -0
  4. package/.eslintrc.json +18 -0
  5. package/.github/workflows/build.yml +30 -0
  6. package/.github/workflows/release.yml +44 -0
  7. package/README.md +449 -0
  8. package/dist/cli-reporter.d.ts +5 -0
  9. package/dist/cli-reporter.d.ts.map +1 -0
  10. package/dist/cli-reporter.js +71 -0
  11. package/dist/cli-reporter.js.map +1 -0
  12. package/dist/cli.d.ts +2 -0
  13. package/dist/cli.d.ts.map +1 -0
  14. package/dist/cli.js +43 -0
  15. package/dist/cli.js.map +1 -0
  16. package/dist/config.d.ts +14 -0
  17. package/dist/config.d.ts.map +1 -0
  18. package/dist/config.js +26 -0
  19. package/dist/config.js.map +1 -0
  20. package/dist/data-collector.d.ts +14 -0
  21. package/dist/data-collector.d.ts.map +1 -0
  22. package/dist/data-collector.js +51 -0
  23. package/dist/data-collector.js.map +1 -0
  24. package/dist/data-extractor.d.ts +31 -0
  25. package/dist/data-extractor.d.ts.map +1 -0
  26. package/dist/data-extractor.js +250 -0
  27. package/dist/data-extractor.js.map +1 -0
  28. package/dist/explore.d.ts +2 -0
  29. package/dist/explore.d.ts.map +1 -0
  30. package/dist/explore.js +27 -0
  31. package/dist/explore.js.map +1 -0
  32. package/dist/index.d.ts +7 -0
  33. package/dist/index.d.ts.map +1 -0
  34. package/dist/index.js +43 -0
  35. package/dist/index.js.map +1 -0
  36. package/dist/influx-client.d.ts +16 -0
  37. package/dist/influx-client.d.ts.map +1 -0
  38. package/dist/influx-client.interface.d.ts +21 -0
  39. package/dist/influx-client.interface.d.ts.map +1 -0
  40. package/dist/influx-client.interface.js +3 -0
  41. package/dist/influx-client.interface.js.map +1 -0
  42. package/dist/influx-client.js +35 -0
  43. package/dist/influx-client.js.map +1 -0
  44. package/dist/influx-data-extractor.d.ts +112 -0
  45. package/dist/influx-data-extractor.d.ts.map +1 -0
  46. package/dist/influx-data-extractor.interface.d.ts +21 -0
  47. package/dist/influx-data-extractor.interface.d.ts.map +1 -0
  48. package/dist/influx-data-extractor.interface.js +3 -0
  49. package/dist/influx-data-extractor.interface.js.map +1 -0
  50. package/dist/influx-data-extractor.js +445 -0
  51. package/dist/influx-data-extractor.js.map +1 -0
  52. package/dist/influx.d.ts +122 -0
  53. package/dist/influx.d.ts.map +1 -0
  54. package/dist/influx.js +899 -0
  55. package/dist/influx.js.map +1 -0
  56. package/dist/logger.d.ts +7 -0
  57. package/dist/logger.d.ts.map +1 -0
  58. package/dist/logger.js +12 -0
  59. package/dist/logger.js.map +1 -0
  60. package/dist/metrics-collector.d.ts +10 -0
  61. package/dist/metrics-collector.d.ts.map +1 -0
  62. package/dist/metrics-collector.js +99 -0
  63. package/dist/metrics-collector.js.map +1 -0
  64. package/dist/metrics-collector.test.d.ts +2 -0
  65. package/dist/metrics-collector.test.d.ts.map +1 -0
  66. package/dist/metrics-collector.test.js +235 -0
  67. package/dist/metrics-collector.test.js.map +1 -0
  68. package/dist/reporters/cli-reporter.d.ts +9 -0
  69. package/dist/reporters/cli-reporter.d.ts.map +1 -0
  70. package/dist/reporters/cli-reporter.js +141 -0
  71. package/dist/reporters/cli-reporter.js.map +1 -0
  72. package/dist/reporters/cli.d.ts +5 -0
  73. package/dist/reporters/cli.d.ts.map +1 -0
  74. package/dist/reporters/cli.js +150 -0
  75. package/dist/reporters/cli.js.map +1 -0
  76. package/dist/reporters/index.d.ts +3 -0
  77. package/dist/reporters/index.d.ts.map +1 -0
  78. package/dist/reporters/index.js +8 -0
  79. package/dist/reporters/index.js.map +1 -0
  80. package/dist/reporters/json-reporter.d.ts +5 -0
  81. package/dist/reporters/json-reporter.d.ts.map +1 -0
  82. package/dist/reporters/json-reporter.js +18 -0
  83. package/dist/reporters/json-reporter.js.map +1 -0
  84. package/dist/reporters/json.d.ts +5 -0
  85. package/dist/reporters/json.d.ts.map +1 -0
  86. package/dist/reporters/json.js +70 -0
  87. package/dist/reporters/json.js.map +1 -0
  88. package/dist/reporters/markdown.d.ts +5 -0
  89. package/dist/reporters/markdown.d.ts.map +1 -0
  90. package/dist/reporters/markdown.js +87 -0
  91. package/dist/reporters/markdown.js.map +1 -0
  92. package/dist/reports.d.ts +11 -0
  93. package/dist/reports.d.ts.map +1 -0
  94. package/dist/reports.js +325 -0
  95. package/dist/reports.js.map +1 -0
  96. package/dist/types.d.ts +113 -0
  97. package/dist/types.d.ts.map +1 -0
  98. package/dist/types.js +4 -0
  99. package/dist/types.js.map +1 -0
  100. package/dist/utils.d.ts +2 -0
  101. package/dist/utils.d.ts.map +1 -0
  102. package/dist/utils.js +19 -0
  103. package/dist/utils.js.map +1 -0
  104. package/package.json +33 -0
  105. package/src/cli.ts +47 -0
  106. package/src/config.ts +31 -0
  107. package/src/data-collector.ts +66 -0
  108. package/src/influx-client.ts +48 -0
  109. package/src/influx-data-extractor.ts +722 -0
  110. package/src/reporters/cli-reporter.ts +169 -0
  111. package/src/reporters/index.ts +2 -0
  112. package/src/reporters/json-reporter.ts +15 -0
  113. package/tsconfig.json +20 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli-reporter.js","sourceRoot":"","sources":["../src/cli-reporter.ts"],"names":[],"mappings":"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"}
package/dist/cli.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}
package/dist/cli.js ADDED
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const commander_1 = require("commander");
4
+ const config_1 = require("./config");
5
+ const data_collector_1 = require("./data-collector");
6
+ const reporters_1 = require("./reporters");
7
+ function main() {
8
+ commander_1.program
9
+ .name("k6-reporter")
10
+ .description("Generate CLI reports from k6 tests stored in InfluxDB")
11
+ .version("1.0.0");
12
+ commander_1.program
13
+ .command("generate")
14
+ .description("Generate performance test report")
15
+ .requiredOption("--run-id <id>", "k6 test run ID")
16
+ .option("-st, --start-time <time>", "Start time in ISO 8601 format or relative like '-1h'")
17
+ .option("-et, --end-time <time>", "End time in ISO 8601 format (defaults to now)")
18
+ .option("-c, --config <path>", "Path to config file", ".config.json")
19
+ .option("-f, --format <format>", "Output format: 'json' or 'cli'", "cli")
20
+ .option("-o, --output <path>", "Output file path (for json format)")
21
+ .action(async (options) => {
22
+ try {
23
+ const config = config_1.Config.getInstance(options.config).getConfig();
24
+ const collector = new data_collector_1.DataCollector(config);
25
+ const report = await collector.collect(options.runId, options.startTime || "-1h", options.endTime || "now()");
26
+ if (options.format === "json") {
27
+ const jsonReporter = new reporters_1.JsonReporter();
28
+ jsonReporter.report(report, options.output);
29
+ }
30
+ else {
31
+ const cliReporter = new reporters_1.CliReporter();
32
+ cliReporter.report(report);
33
+ }
34
+ }
35
+ catch (error) {
36
+ console.error("Error:", error instanceof Error ? error.message : error);
37
+ process.exit(1);
38
+ }
39
+ });
40
+ commander_1.program.parse();
41
+ }
42
+ main();
43
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";;AAAA,yCAAoC;AACpC,qCAAkC;AAClC,qDAAiD;AACjD,2CAAwD;AAExD,SAAS,IAAI;IACX,mBAAO;SACJ,IAAI,CAAC,aAAa,CAAC;SACnB,WAAW,CAAC,uDAAuD,CAAC;SACpE,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpB,mBAAO;SACJ,OAAO,CAAC,UAAU,CAAC;SACnB,WAAW,CAAC,kCAAkC,CAAC;SAC/C,cAAc,CAAC,eAAe,EAAE,gBAAgB,CAAC;SACjD,MAAM,CAAC,0BAA0B,EAAE,sDAAsD,CAAC;SAC1F,MAAM,CAAC,wBAAwB,EAAE,+CAA+C,CAAC;SACjF,MAAM,CAAC,qBAAqB,EAAE,qBAAqB,EAAE,cAAc,CAAC;SACpE,MAAM,CAAC,uBAAuB,EAAE,gCAAgC,EAAE,KAAK,CAAC;SACxE,MAAM,CAAC,qBAAqB,EAAE,oCAAoC,CAAC;SACnE,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,eAAM,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC;YAC9D,MAAM,SAAS,GAAG,IAAI,8BAAa,CAAC,MAAM,CAAC,CAAC;YAC5C,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,OAAO,CACpC,OAAO,CAAC,KAAK,EACb,OAAO,CAAC,SAAS,IAAI,KAAK,EAC1B,OAAO,CAAC,OAAO,IAAI,OAAO,CAC3B,CAAC;YAEF,IAAI,OAAO,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;gBAC9B,MAAM,YAAY,GAAG,IAAI,wBAAY,EAAE,CAAC;gBACxC,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;YAC9C,CAAC;iBAAM,CAAC;gBACN,MAAM,WAAW,GAAG,IAAI,uBAAW,EAAE,CAAC;gBACtC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACxE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,mBAAO,CAAC,KAAK,EAAE,CAAC;AAClB,CAAC;AAED,IAAI,EAAE,CAAC"}
@@ -0,0 +1,14 @@
1
+ export interface InfluxConfig {
2
+ url: string;
3
+ token: string;
4
+ org: string;
5
+ bucket: string;
6
+ }
7
+ export declare class Config {
8
+ private static instance;
9
+ private config;
10
+ private constructor();
11
+ static getInstance(configPath?: string): Config;
12
+ getConfig(): InfluxConfig;
13
+ }
14
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,YAAY;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAS;IAChC,OAAO,CAAC,MAAM,CAAe;IAE7B,OAAO;IAMP,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM;IAO/C,SAAS,IAAI,YAAY;CAG1B"}
package/dist/config.js ADDED
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Config = void 0;
7
+ const fs_1 = __importDefault(require("fs"));
8
+ const path_1 = __importDefault(require("path"));
9
+ class Config {
10
+ constructor(configPath = ".config.json") {
11
+ const fullPath = path_1.default.resolve(configPath);
12
+ const data = JSON.parse(fs_1.default.readFileSync(fullPath, "utf-8"));
13
+ this.config = data.influx;
14
+ }
15
+ static getInstance(configPath) {
16
+ if (!Config.instance) {
17
+ Config.instance = new Config(configPath);
18
+ }
19
+ return Config.instance;
20
+ }
21
+ getConfig() {
22
+ return this.config;
23
+ }
24
+ }
25
+ exports.Config = Config;
26
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAoB;AACpB,gDAAwB;AASxB,MAAa,MAAM;IAIjB,YAAoB,aAAqB,cAAc;QACrD,MAAM,QAAQ,GAAG,cAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,UAAmB;QACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrB,MAAM,CAAC,QAAQ,GAAG,IAAI,MAAM,CAAC,UAAU,CAAC,CAAC;QAC3C,CAAC;QACD,OAAO,MAAM,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF;AApBD,wBAoBC"}
@@ -0,0 +1,14 @@
1
+ import { InfluxConfig } from "./config";
2
+ export interface ReporterResponse {
3
+ runId: string;
4
+ startTime: string;
5
+ endTime: string;
6
+ timestamp: string;
7
+ data: unknown;
8
+ }
9
+ export declare class DataCollector {
10
+ private extractor;
11
+ constructor(config: InfluxConfig);
12
+ collect(runId: string, startTime?: string, endTime?: string, data?: unknown): Promise<ReporterResponse>;
13
+ }
14
+ //# sourceMappingURL=data-collector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-collector.d.ts","sourceRoot":"","sources":["../src/data-collector.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,OAAO,CAAC;CACf;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,SAAS,CAAsB;gBAE3B,MAAM,EAAE,YAAY;IAI1B,OAAO,CACX,KAAK,EAAE,MAAM,EACb,SAAS,GAAE,MAAc,EACzB,OAAO,GAAE,MAAgB,EACzB,IAAI,GAAE,OAAY,GACjB,OAAO,CAAC,gBAAgB,CAAC;CA0C7B"}
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DataCollector = void 0;
4
+ const influx_data_extractor_1 = require("./influx-data-extractor");
5
+ class DataCollector {
6
+ constructor(config) {
7
+ this.extractor = new influx_data_extractor_1.InfluxDataExtractor(config);
8
+ }
9
+ async collect(runId, startTime = "-1h", endTime = "now()", data = {}) {
10
+ const httpReqs = await this.extractor.extractHttpReqs(runId, startTime, endTime);
11
+ const vus = await this.extractor.extractVus(runId, startTime, endTime);
12
+ const vusMax = await this.extractor.extractVusMax(runId, startTime, endTime);
13
+ const iterations = await this.extractor.extractIterations(runId, startTime, endTime);
14
+ const duration = await this.extractor.calculateTestDuration(runId, startTime, endTime);
15
+ const checks = await this.extractor.extractChecks(runId, startTime, endTime);
16
+ const httpReqFailed = await this.extractor.extractHttpReqFailed(runId, startTime, endTime);
17
+ const httpReqDuration = await this.extractor.extractHttpReqDuration(runId, startTime, endTime);
18
+ const iterationDuration = await this.extractor.extractIterationDuration(runId, startTime, endTime);
19
+ const errorResponses = await this.extractor.extractErrorResponses(runId, startTime, endTime);
20
+ const topSlowUrls = await this.extractor.extractTopSlowUrls(runId, startTime, endTime);
21
+ const errorRequests = await this.extractor.extractErrorRequests(runId, startTime, endTime);
22
+ const successRequests = await this.extractor.extractSuccessRequests(runId, startTime, endTime);
23
+ const errorResponsesText = await this.extractor.extractErrorResponsesText(runId, startTime, endTime);
24
+ const reportData = {
25
+ ...(typeof data === "object" && data !== null ? data : {}),
26
+ httpReqs,
27
+ vus,
28
+ vusMax,
29
+ iterations,
30
+ duration,
31
+ checks,
32
+ httpReqFailed,
33
+ httpReqDuration,
34
+ iterationDuration,
35
+ errorResponses,
36
+ topSlowUrls,
37
+ errorRequests,
38
+ successRequests,
39
+ errorResponsesText,
40
+ };
41
+ return {
42
+ runId,
43
+ startTime,
44
+ endTime,
45
+ timestamp: new Date().toISOString(),
46
+ data: reportData,
47
+ };
48
+ }
49
+ }
50
+ exports.DataCollector = DataCollector;
51
+ //# sourceMappingURL=data-collector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-collector.js","sourceRoot":"","sources":["../src/data-collector.ts"],"names":[],"mappings":";;;AAAA,mEAA8D;AAW9D,MAAa,aAAa;IAGxB,YAAY,MAAoB;QAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,2CAAmB,CAAC,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,OAAO,CACX,KAAa,EACb,YAAoB,KAAK,EACzB,UAAkB,OAAO,EACzB,OAAgB,EAAE;QAElB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACjF,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACvE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC7E,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACrF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACvF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC7E,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC3F,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,sBAAsB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC/F,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACnG,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC7F,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACvF,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC3F,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,sBAAsB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAC/F,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,yBAAyB,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAErG,MAAM,UAAU,GAAG;YACjB,GAAG,CAAC,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAC1D,QAAQ;YACR,GAAG;YACH,MAAM;YACN,UAAU;YACV,QAAQ;YACR,MAAM;YACN,aAAa;YACb,eAAe;YACf,iBAAiB;YACjB,cAAc;YACd,WAAW;YACX,aAAa;YACb,eAAe;YACf,kBAAkB;SACnB,CAAC;QAEF,OAAO;YACL,KAAK;YACL,SAAS;YACT,OAAO;YACP,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,IAAI,EAAE,UAAU;SACjB,CAAC;IACJ,CAAC;CACF;AAtDD,sCAsDC"}
@@ -0,0 +1,31 @@
1
+ import { InfluxDBClient, InfluxConfig } from "./influx-client";
2
+ export interface MetricsData {
3
+ timestamp: string;
4
+ value: number;
5
+ [key: string]: any;
6
+ }
7
+ export declare class DataExtractor {
8
+ private client;
9
+ private bucket;
10
+ constructor(client: InfluxDBClient, config: InfluxConfig);
11
+ getVus(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
12
+ getMaxVus(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
13
+ getPodsCount(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
14
+ getTotalErrors(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
15
+ getTotalRequests(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
16
+ getTotalIterations(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
17
+ getIterationDuration(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
18
+ getTop10SlowestRequests(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
19
+ getHttpRequestsStatsByUrl(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
20
+ getHttpRequestsCountByStatus(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
21
+ getHttpRequestsRpsByUrl(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
22
+ getHttpRequestsPercentiles(startTime: string, endTime: string, runId?: string): Promise<Map<string, {
23
+ p95: number;
24
+ p99: number;
25
+ }>>;
26
+ getTestDuration(startTime: string, endTime: string, runId?: string): Promise<number>;
27
+ getHttpReqsDuration(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
28
+ getRPS(startTime: string, endTime: string, runId?: string): Promise<MetricsData[]>;
29
+ private formatMetrics;
30
+ }
31
+ //# sourceMappingURL=data-extractor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-extractor.d.ts","sourceRoot":"","sources":["../src/data-extractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAe,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE5E,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IAEd,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB;AAED,qBAAa,aAAa;IAGZ,OAAO,CAAC,MAAM;IAF1B,OAAO,CAAC,MAAM,CAAS;gBAEH,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY;IAI1D,MAAM,CACV,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,SAAS,CACb,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,YAAY,CAChB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,cAAc,CAClB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,gBAAgB,CACpB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,kBAAkB,CACtB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAanB,oBAAoB,CACxB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAYnB,uBAAuB,CAC3B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAiBnB,yBAAyB,CAC7B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IA4BnB,4BAA4B,CAChC,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAenB,uBAAuB,CAC3B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAenB,0BAA0B,CAC9B,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IA2D/C,eAAe,CACnB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,CAAC;IAoBZ,mBAAmB,CACvB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAYnB,MAAM,CACV,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,EAAE,CAAC;IAazB,OAAO,CAAC,aAAa;CAQtB"}
@@ -0,0 +1,250 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DataExtractor = void 0;
4
+ class DataExtractor {
5
+ constructor(client, config) {
6
+ this.client = client;
7
+ this.bucket = config.bucket;
8
+ }
9
+ async getVus(startTime, endTime, runId) {
10
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
11
+ const fluxQuery = `
12
+ from(bucket: "${this.bucket}")
13
+ |> range(start: ${startTime}, stop: ${endTime})
14
+ |> filter(fn: (r) => r._measurement == "vus" ${runIdFilter})
15
+ |> aggregateWindow(every: 10s, fn: mean)
16
+ `;
17
+ const results = await this.client.query(fluxQuery);
18
+ return this.formatMetrics(results);
19
+ }
20
+ async getMaxVus(startTime, endTime, runId) {
21
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
22
+ const fluxQuery = `
23
+ from(bucket: "${this.bucket}")
24
+ |> range(start: ${startTime}, stop: ${endTime})
25
+ |> filter(fn: (r) => r._measurement == "vus_max" ${runIdFilter})
26
+ |> aggregateWindow(every: 10s, fn: max)
27
+ `;
28
+ const results = await this.client.query(fluxQuery);
29
+ return this.formatMetrics(results);
30
+ }
31
+ async getPodsCount(startTime, endTime, runId) {
32
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
33
+ const fluxQuery = `
34
+ from(bucket: "${this.bucket}")
35
+ |> range(start: ${startTime}, stop: ${endTime})
36
+ |> filter(fn: (r) => r._measurement == "pods_count" ${runIdFilter})
37
+ |> aggregateWindow(every: 10s, fn: mean)
38
+ `;
39
+ const results = await this.client.query(fluxQuery);
40
+ return this.formatMetrics(results);
41
+ }
42
+ async getTotalErrors(startTime, endTime, runId) {
43
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
44
+ const fluxQuery = `
45
+ from(bucket: "${this.bucket}")
46
+ |> range(start: ${startTime}, stop: ${endTime})
47
+ |> filter(fn: (r) => r._measurement == "http_req_failed" ${runIdFilter})
48
+ |> sum()
49
+ `;
50
+ const results = await this.client.query(fluxQuery);
51
+ return this.formatMetrics(results);
52
+ }
53
+ async getTotalRequests(startTime, endTime, runId) {
54
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
55
+ const fluxQuery = `
56
+ from(bucket: "${this.bucket}")
57
+ |> range(start: ${startTime}, stop: ${endTime})
58
+ |> filter(fn: (r) => r._measurement == "http_reqs" ${runIdFilter})
59
+ |> count()
60
+ `;
61
+ const results = await this.client.query(fluxQuery);
62
+ return this.formatMetrics(results);
63
+ }
64
+ async getTotalIterations(startTime, endTime, runId) {
65
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
66
+ const fluxQuery = `
67
+ from(bucket: "${this.bucket}")
68
+ |> range(start: ${startTime}, stop: ${endTime})
69
+ |> filter(fn: (r) => r._measurement == "iterations" ${runIdFilter})
70
+ |> count()
71
+ `;
72
+ const results = await this.client.query(fluxQuery);
73
+ return this.formatMetrics(results);
74
+ }
75
+ async getIterationDuration(startTime, endTime, runId) {
76
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
77
+ const fluxQuery = `
78
+ from(bucket: "${this.bucket}")
79
+ |> range(start: ${startTime}, stop: ${endTime})
80
+ |> filter(fn: (r) => r._measurement == "iteration_duration" ${runIdFilter})
81
+ `;
82
+ const results = await this.client.query(fluxQuery);
83
+ return this.formatMetrics(results);
84
+ }
85
+ async getTop10SlowestRequests(startTime, endTime, runId) {
86
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
87
+ const fluxQuery = `
88
+ from(bucket: "${this.bucket}")
89
+ |> range(start: ${startTime}, stop: ${endTime})
90
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
91
+ |> group(columns: ["url", "method"])
92
+ |> quantile(q: 0.95)
93
+ |> group()
94
+ |> sort(columns: ["_value"], desc: true)
95
+ |> limit(n: 10)
96
+ `;
97
+ const results = await this.client.query(fluxQuery);
98
+ return this.formatMetrics(results);
99
+ }
100
+ async getHttpRequestsStatsByUrl(startTime, endTime, runId) {
101
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
102
+ const fluxQuery = `
103
+ from(bucket: "${this.bucket}")
104
+ |> range(start: ${startTime}, stop: ${endTime})
105
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
106
+ |> group(columns: ["url", "method", "status"])
107
+ |> reduce(
108
+ identity: {count: 0, sum: 0.0, min: 999999.0, max: 0.0},
109
+ fn: (r, accumulator) => ({
110
+ count: accumulator.count + 1,
111
+ sum: accumulator.sum + r._value,
112
+ min: if accumulator.min > r._value then r._value else accumulator.min,
113
+ max: if accumulator.max < r._value then r._value else accumulator.max
114
+ })
115
+ )
116
+ |> map(fn: (r) => ({
117
+ r with
118
+ _value: r.count,
119
+ avg: r.sum / float(v: r.count),
120
+ statusCode: r.status
121
+ }))
122
+ `;
123
+ const results = await this.client.query(fluxQuery);
124
+ return this.formatMetrics(results);
125
+ }
126
+ async getHttpRequestsCountByStatus(startTime, endTime, runId) {
127
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
128
+ const fluxQuery = `
129
+ from(bucket: "${this.bucket}")
130
+ |> range(start: ${startTime}, stop: ${endTime})
131
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
132
+ |> group(columns: ["url", "method", "status"])
133
+ |> count()
134
+ |> group()
135
+ `;
136
+ const results = await this.client.query(fluxQuery);
137
+ return this.formatMetrics(results);
138
+ }
139
+ async getHttpRequestsRpsByUrl(startTime, endTime, runId) {
140
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
141
+ const fluxQuery = `
142
+ from(bucket: "${this.bucket}")
143
+ |> range(start: ${startTime}, stop: ${endTime})
144
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
145
+ |> group(columns: ["url"])
146
+ |> count()
147
+ |> group()
148
+ `;
149
+ const results = await this.client.query(fluxQuery);
150
+ return this.formatMetrics(results);
151
+ }
152
+ async getHttpRequestsPercentiles(startTime, endTime, runId) {
153
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
154
+ // Query for P95
155
+ const p95Query = `
156
+ from(bucket: "${this.bucket}")
157
+ |> range(start: ${startTime}, stop: ${endTime})
158
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
159
+ |> group(columns: ["url", "method", "status"])
160
+ |> quantile(q: 0.95)
161
+ |> group()
162
+ `;
163
+ // Query for P99
164
+ const p99Query = `
165
+ from(bucket: "${this.bucket}")
166
+ |> range(start: ${startTime}, stop: ${endTime})
167
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
168
+ |> group(columns: ["url", "method", "status"])
169
+ |> quantile(q: 0.99)
170
+ |> group()
171
+ `;
172
+ const [p95Results, p99Results] = await Promise.all([
173
+ this.client.query(p95Query),
174
+ this.client.query(p99Query),
175
+ ]);
176
+ const percentileMap = new Map();
177
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
178
+ p95Results.forEach((result) => {
179
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
180
+ const key = `${result.url}|${result.method}|${result.status}`;
181
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
182
+ const p95 = parseFloat(String(result._value || "0")) || 0;
183
+ if (!percentileMap.has(key)) {
184
+ percentileMap.set(key, { p95: 0, p99: 0 });
185
+ }
186
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
187
+ percentileMap.get(key).p95 = p95;
188
+ });
189
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
190
+ p99Results.forEach((result) => {
191
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
192
+ const key = `${result.url}|${result.method}|${result.status}`;
193
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
194
+ const p99 = parseFloat(String(result._value || "0")) || 0;
195
+ if (!percentileMap.has(key)) {
196
+ percentileMap.set(key, { p95: 0, p99: 0 });
197
+ }
198
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
199
+ percentileMap.get(key).p99 = p99;
200
+ });
201
+ return percentileMap;
202
+ }
203
+ async getTestDuration(startTime, endTime, runId) {
204
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
205
+ const fluxQuery = `
206
+ from(bucket: "${this.bucket}")
207
+ |> range(start: ${startTime}, stop: ${endTime})
208
+ |> filter(fn: (r) => r._measurement == "http_reqs" ${runIdFilter})
209
+ |> group()
210
+ `;
211
+ const results = await this.client.query(fluxQuery);
212
+ const timestamps = results.map((r) => new Date(r._time).getTime());
213
+ if (timestamps.length === 0)
214
+ return 0;
215
+ const minTime = Math.min(...timestamps);
216
+ const maxTime = Math.max(...timestamps);
217
+ return (maxTime - minTime) / 1000; // Return duration in seconds
218
+ }
219
+ async getHttpReqsDuration(startTime, endTime, runId) {
220
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
221
+ const fluxQuery = `
222
+ from(bucket: "${this.bucket}")
223
+ |> range(start: ${startTime}, stop: ${endTime})
224
+ |> filter(fn: (r) => r._measurement == "http_req_duration" ${runIdFilter})
225
+ `;
226
+ const results = await this.client.query(fluxQuery);
227
+ return this.formatMetrics(results);
228
+ }
229
+ async getRPS(startTime, endTime, runId) {
230
+ const runIdFilter = runId ? `and (r.runId == "${runId}")` : "";
231
+ const fluxQuery = `
232
+ from(bucket: "${this.bucket}")
233
+ |> range(start: ${startTime}, stop: ${endTime})
234
+ |> filter(fn: (r) => r._measurement == "http_reqs" ${runIdFilter})
235
+ |> aggregateWindow(every: 1s, fn: sum, createEmpty: false)
236
+ `;
237
+ const results = await this.client.query(fluxQuery);
238
+ return this.formatMetrics(results);
239
+ }
240
+ formatMetrics(results) {
241
+ return results.map((result) => ({
242
+ timestamp: result._time || new Date().toISOString(),
243
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
244
+ value: parseFloat(result._value) || 0,
245
+ ...result,
246
+ }));
247
+ }
248
+ }
249
+ exports.DataExtractor = DataExtractor;
250
+ //# sourceMappingURL=data-extractor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-extractor.js","sourceRoot":"","sources":["../src/data-extractor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=explore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"explore.d.ts","sourceRoot":"","sources":["../src/explore.ts"],"names":[],"mappings":""}
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const influxdb_client_1 = require("@influxdata/influxdb-client");
4
+ const influxDB = new influxdb_client_1.InfluxDB({
5
+ url: "https://influx.cmn.monomarket.tech",
6
+ token: "JFP9pZu3Sp134rkCZ6gT7FtSBmQRWgl8VmVhFMHTXrbkhKQ3LrvrM4FXECR7Lr8MsDGWLIsU7IJFcjL_QHwvqA==",
7
+ });
8
+ const queryApi = influxDB.getQueryApi("ced1cdfb28534a3e");
9
+ const flux = `
10
+ from(bucket: "jmeter")
11
+ |> range(start: 2026-04-02T21:17:28.487Z, stop: 2026-04-02T21:22:02.858Z)
12
+ |> group(columns: ["_measurement", "_field"])
13
+ |> first()
14
+ `;
15
+ queryApi.queryRows(flux, {
16
+ next: (row, tableMeta) => {
17
+ const o = tableMeta.toObject(row);
18
+ console.log(JSON.stringify(o, null, 2));
19
+ },
20
+ error: (error) => {
21
+ console.error("Error:", error);
22
+ },
23
+ complete: () => {
24
+ console.log("Query completed");
25
+ },
26
+ });
27
+ //# sourceMappingURL=explore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"explore.js","sourceRoot":"","sources":["../src/explore.ts"],"names":[],"mappings":";;AAAA,iEAAuD;AAEvD,MAAM,QAAQ,GAAG,IAAI,0BAAQ,CAAC;IAC5B,GAAG,EAAE,oCAAoC;IACzC,KAAK,EACH,0FAA0F;CAC7F,CAAC,CAAC;AAEH,MAAM,QAAQ,GAAG,QAAQ,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC;AAE1D,MAAM,IAAI,GAAG;;;;;CAKZ,CAAC;AAEF,QAAQ,CAAC,SAAS,CAAC,IAAI,EAAE;IACvB,IAAI,EAAE,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE;QACvB,MAAM,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1C,CAAC;IACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;QACf,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IACjC,CAAC;IACD,QAAQ,EAAE,GAAG,EAAE;QACb,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IACjC,CAAC;CACF,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { InfluxQueryClient } from "./influx";
2
+ import { ReportGenerator } from "./reports";
3
+ import { CLIReporter } from "./cli-reporter";
4
+ import type { InfluxConfig, TestMetrics } from "./influx";
5
+ export { InfluxQueryClient, ReportGenerator, CLIReporter };
6
+ export type { InfluxConfig, TestMetrics };
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG1D,OAAO,EAAE,iBAAiB,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC;AAC3D,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CLIReporter = exports.ReportGenerator = exports.InfluxQueryClient = void 0;
4
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
5
+ const influx_1 = require("./influx");
6
+ Object.defineProperty(exports, "InfluxQueryClient", { enumerable: true, get: function () { return influx_1.InfluxQueryClient; } });
7
+ const reports_1 = require("./reports");
8
+ Object.defineProperty(exports, "ReportGenerator", { enumerable: true, get: function () { return reports_1.ReportGenerator; } });
9
+ const cli_reporter_1 = require("./cli-reporter");
10
+ Object.defineProperty(exports, "CLIReporter", { enumerable: true, get: function () { return cli_reporter_1.CLIReporter; } });
11
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
12
+ async function _exampleUsage() {
13
+ const influxConfig = {
14
+ url: process.env.INFLUX_URL || "http://localhost:8086",
15
+ token: process.env.INFLUX_TOKEN || "your-token",
16
+ org: process.env.INFLUX_ORG || "your-org",
17
+ bucket: process.env.INFLUX_BUCKET || "k6",
18
+ };
19
+ const influxClient = new influx_1.InfluxQueryClient(influxConfig);
20
+ const reportGenerator = new reports_1.ReportGenerator(influxClient);
21
+ // Generate metrics for a test
22
+ const scenario = "api-load-test";
23
+ const startTime = "-1h"; // Last hour
24
+ const endTime = "now()";
25
+ try {
26
+ const metrics = await reportGenerator.generateMetrics(scenario, startTime, endTime);
27
+ // Print to CLI
28
+ const cliReporter = new cli_reporter_1.CLIReporter();
29
+ cliReporter.printMetricsTable(metrics, scenario);
30
+ // Generate reports
31
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
32
+ const _htmlReport = reportGenerator.generateHTMLReport(metrics, scenario);
33
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
34
+ const _jsonReport = reportGenerator.generateJSONReport(metrics, scenario);
35
+ console.log("Reports generated successfully");
36
+ }
37
+ catch (error) {
38
+ console.error("Error:", error);
39
+ }
40
+ }
41
+ // Uncomment to run example
42
+ // _exampleUsage();
43
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,6DAA6D;AAC7D,qCAA6C;AAMpC,kGANA,0BAAiB,OAMA;AAL1B,uCAA4C;AAKhB,gGALnB,yBAAe,OAKmB;AAJ3C,iDAA6C;AAIA,4FAJpC,0BAAW,OAIoC;AAGxD,6DAA6D;AAC7D,KAAK,UAAU,aAAa;IAC1B,MAAM,YAAY,GAAiB;QACjC,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,uBAAuB;QACtD,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,YAAY;QAC/C,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,UAAU;QACzC,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,IAAI;KAC1C,CAAC;IAEF,MAAM,YAAY,GAAG,IAAI,0BAAiB,CAAC,YAAY,CAAC,CAAC;IACzD,MAAM,eAAe,GAAG,IAAI,yBAAe,CAAC,YAAY,CAAC,CAAC;IAE1D,8BAA8B;IAC9B,MAAM,QAAQ,GAAG,eAAe,CAAC;IACjC,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,YAAY;IACrC,MAAM,OAAO,GAAG,OAAO,CAAC;IAExB,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,eAAe,CAAC,eAAe,CACnD,QAAQ,EACR,SAAS,EACT,OAAO,CACR,CAAC;QAEF,eAAe;QACf,MAAM,WAAW,GAAG,IAAI,0BAAW,EAAE,CAAC;QACtC,WAAW,CAAC,iBAAiB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAEjD,mBAAmB;QACnB,6DAA6D;QAC7D,MAAM,WAAW,GAAG,eAAe,CAAC,kBAAkB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC1E,6DAA6D;QAC7D,MAAM,WAAW,GAAG,eAAe,CAAC,kBAAkB,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC1E,OAAO,CAAC,GAAG,CAAC,gCAAgC,CAAC,CAAC;IAChD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IACjC,CAAC;AACH,CAAC;AAED,2BAA2B;AAC3B,mBAAmB"}
@@ -0,0 +1,16 @@
1
+ import { InfluxConfig } from "./config";
2
+ export interface QueryRow {
3
+ values: (string | number | boolean | null)[];
4
+ tableMeta?: {
5
+ columns: Array<{
6
+ label: string;
7
+ }>;
8
+ };
9
+ }
10
+ export declare class InfluxClient {
11
+ private influxDB;
12
+ private queryApi;
13
+ constructor(config: InfluxConfig);
14
+ queryData(flux: string): Promise<Array<Record<string, string | number | boolean | null>>>;
15
+ }
16
+ //# sourceMappingURL=influx-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"influx-client.d.ts","sourceRoot":"","sources":["../src/influx-client.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,MAAM,WAAW,QAAQ;IACvB,MAAM,EAAE,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC;IAC7C,SAAS,CAAC,EAAE;QACV,OAAO,EAAE,KAAK,CAAC;YAAE,KAAK,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KACnC,CAAC;CACH;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,QAAQ,CAAW;gBAEf,MAAM,EAAE,YAAY;IAQ1B,SAAS,CACb,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC;CAuBpE"}