rl-rockcli 0.0.2 → 0.0.3

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 (75) hide show
  1. package/README.md +400 -0
  2. package/index.js +51 -21
  3. package/package.json +1 -1
  4. package/commands/log/core/constants.js +0 -237
  5. package/commands/log/core/display.js +0 -370
  6. package/commands/log/core/search.js +0 -330
  7. package/commands/log/core/tail.js +0 -216
  8. package/commands/log/core/utils.js +0 -424
  9. package/commands/log.js +0 -298
  10. package/commands/sandbox/core/log-bridge.js +0 -119
  11. package/commands/sandbox/core/replay/analyzer.js +0 -311
  12. package/commands/sandbox/core/replay/batch-orchestrator.js +0 -536
  13. package/commands/sandbox/core/replay/batch-task.js +0 -369
  14. package/commands/sandbox/core/replay/concurrent-display.js +0 -70
  15. package/commands/sandbox/core/replay/concurrent-orchestrator.js +0 -170
  16. package/commands/sandbox/core/replay/data-source.js +0 -86
  17. package/commands/sandbox/core/replay/display.js +0 -231
  18. package/commands/sandbox/core/replay/executor.js +0 -634
  19. package/commands/sandbox/core/replay/history-fetcher.js +0 -124
  20. package/commands/sandbox/core/replay/index.js +0 -338
  21. package/commands/sandbox/core/replay/loghouse-data-source.js +0 -177
  22. package/commands/sandbox/core/replay/pid-mapping.js +0 -26
  23. package/commands/sandbox/core/replay/request.js +0 -109
  24. package/commands/sandbox/core/replay/worker.js +0 -166
  25. package/commands/sandbox/core/session.js +0 -346
  26. package/commands/sandbox/log-bridge.js +0 -2
  27. package/commands/sandbox/ray.js +0 -2
  28. package/commands/sandbox/replay/analyzer.js +0 -311
  29. package/commands/sandbox/replay/batch-orchestrator.js +0 -536
  30. package/commands/sandbox/replay/batch-task.js +0 -369
  31. package/commands/sandbox/replay/concurrent-display.js +0 -70
  32. package/commands/sandbox/replay/concurrent-orchestrator.js +0 -170
  33. package/commands/sandbox/replay/display.js +0 -231
  34. package/commands/sandbox/replay/executor.js +0 -634
  35. package/commands/sandbox/replay/history-fetcher.js +0 -118
  36. package/commands/sandbox/replay/index.js +0 -338
  37. package/commands/sandbox/replay/pid-mapping.js +0 -26
  38. package/commands/sandbox/replay/request.js +0 -109
  39. package/commands/sandbox/replay/worker.js +0 -166
  40. package/commands/sandbox/replay.js +0 -2
  41. package/commands/sandbox/session.js +0 -2
  42. package/commands/sandbox-original.js +0 -1393
  43. package/commands/sandbox.js +0 -499
  44. package/help/help.json +0 -1071
  45. package/help/middleware.js +0 -71
  46. package/help/renderer.js +0 -800
  47. package/lib/plugin-context.js +0 -40
  48. package/sdks/sandbox/core/client.js +0 -845
  49. package/sdks/sandbox/core/config.js +0 -70
  50. package/sdks/sandbox/core/types.js +0 -74
  51. package/sdks/sandbox/httpLogger.js +0 -251
  52. package/sdks/sandbox/index.js +0 -9
  53. package/utils/asciiArt.js +0 -138
  54. package/utils/bun-compat.js +0 -59
  55. package/utils/ciPipelines.js +0 -138
  56. package/utils/cli.js +0 -17
  57. package/utils/command-router.js +0 -79
  58. package/utils/configManager.js +0 -503
  59. package/utils/dependency-resolver.js +0 -135
  60. package/utils/eagleeye_traceid.js +0 -151
  61. package/utils/envDetector.js +0 -78
  62. package/utils/execution_logger.js +0 -415
  63. package/utils/featureManager.js +0 -68
  64. package/utils/firstTimeTip.js +0 -44
  65. package/utils/hook-manager.js +0 -125
  66. package/utils/http-logger.js +0 -264
  67. package/utils/i18n.js +0 -139
  68. package/utils/image-progress.js +0 -159
  69. package/utils/logger.js +0 -154
  70. package/utils/plugin-loader.js +0 -124
  71. package/utils/plugin-manager.js +0 -348
  72. package/utils/ray_cli_wrapper.js +0 -746
  73. package/utils/sandbox-client.js +0 -419
  74. package/utils/terminal.js +0 -32
  75. package/utils/tips.js +0 -106
@@ -1,166 +0,0 @@
1
- const path = require('path');
2
- const { SandboxClient, SandboxConfig } = require('../../../utils/sandbox-client');
3
- const { ReplayExecutor } = require('./executor');
4
- const { ReplayRequest, ReplayPlan } = require('./request');
5
-
6
- /**
7
- * 单个沙箱回放工作者
8
- * 封装独立的 SandboxClient 和 ReplayExecutor
9
- */
10
- class ReplayWorker {
11
- /**
12
- * @param {number} workerId - 工作者 ID(1-based)
13
- * @param {SandboxConfig} config - 沙箱配置
14
- * @param {ReplayPlan} plan - 回放计划(会被深拷贝)
15
- * @param {Object} options - 回放选项
16
- * @param {string} options.timing - 时间控制
17
- * @param {number} options.interval - 固定间隔
18
- * @param {string} options.logFile - 日志文件基础路径
19
- */
20
- constructor(workerId, config, plan, options = {}) {
21
- this.workerId = workerId;
22
- this.config = config;
23
- this.plan = this.deepClonePlan(plan);
24
- this.options = options;
25
-
26
- // 独立的沙箱客户端和执行器
27
- this.client = null;
28
- this.executor = null;
29
-
30
- // 执行状态
31
- this.status = 'pending'; // pending | running | completed | failed
32
- this.error = null;
33
- this.results = null;
34
- this.startTime = null;
35
- this.endTime = null;
36
- }
37
-
38
- /**
39
- * 深拷贝回放计划
40
- * 确保每个 worker 有独立的请求对象(requestBody 可能被修改)
41
- * @param {ReplayPlan} plan
42
- * @returns {ReplayPlan}
43
- */
44
- deepClonePlan(plan) {
45
- const cloned = new ReplayPlan();
46
- cloned.originalCount = plan.originalCount;
47
- cloned.stats = { ...plan.stats };
48
- cloned.pidAssociations = new Map(plan.pidAssociations);
49
-
50
- // 深拷贝请求列表
51
- cloned.requests = plan.requests.map(req => this.cloneRequest(req));
52
- cloned.skippedRequests = plan.skippedRequests.map(req => this.cloneRequest(req));
53
- cloned.mergedRequests = plan.mergedRequests.map(req => this.cloneRequest(req));
54
-
55
- return cloned;
56
- }
57
-
58
- /**
59
- * 深拷贝单个请求
60
- * @param {ReplayRequest} req
61
- * @returns {ReplayRequest}
62
- */
63
- cloneRequest(req) {
64
- const cloned = new ReplayRequest({
65
- method: req.method,
66
- uri: req.uri,
67
- requestBody: JSON.parse(JSON.stringify(req.requestBody || {})),
68
- headers: JSON.parse(JSON.stringify(req.headers || {})),
69
- responseTime: req.responseTime
70
- }, req.index);
71
-
72
- cloned.category = req.category;
73
- cloned.action = req.action;
74
- cloned.originalPid = req.originalPid;
75
- cloned.skipReason = req.skipReason;
76
-
77
- return cloned;
78
- }
79
-
80
- /**
81
- * 获取 worker 专属的日志文件名
82
- * @returns {string}
83
- */
84
- getLogFileName() {
85
- const baseLogFile = this.options.logFile || 'replay.log';
86
- const ext = path.extname(baseLogFile);
87
- const base = path.basename(baseLogFile, ext);
88
- const dir = path.dirname(baseLogFile);
89
- return path.join(dir, `${base}-worker${this.workerId}${ext}`);
90
- }
91
-
92
- /**
93
- * 执行回放
94
- * @returns {Promise<WorkerResult>}
95
- */
96
- async execute() {
97
- this.status = 'running';
98
- this.startTime = Date.now();
99
-
100
- try {
101
- // 创建独立的 SandboxClient
102
- this.client = new SandboxClient(this.config);
103
-
104
- // 创建独立的 ReplayExecutor
105
- this.executor = new ReplayExecutor(this.client, {
106
- timing: this.options.timing,
107
- interval: this.options.interval,
108
- quiet: true, // 并发模式下强制静默,由 orchestrator 统一输出
109
- logFile: this.getLogFileName(),
110
- plan: this.plan,
111
- workerId: this.workerId
112
- });
113
-
114
- // 执行回放
115
- this.results = await this.executor.execute(this.plan);
116
- this.status = 'completed';
117
-
118
- } catch (error) {
119
- this.status = 'failed';
120
- this.error = error;
121
- this.results = {
122
- total: this.plan.requests.length,
123
- success: 0,
124
- failed: this.plan.requests.length,
125
- skipped: 0
126
- };
127
- } finally {
128
- this.endTime = Date.now();
129
- }
130
-
131
- return this.getWorkerResult();
132
- }
133
-
134
- /**
135
- * 获取工作者执行结果
136
- * @returns {WorkerResult}
137
- */
138
- getWorkerResult() {
139
- return {
140
- workerId: this.workerId,
141
- status: this.status,
142
- sandboxId: this.executor?.currentSandboxId || null,
143
- results: this.results,
144
- error: this.error?.message || null,
145
- duration: this.endTime - this.startTime,
146
- logFile: this.getLogFileName()
147
- };
148
- }
149
-
150
- /**
151
- * 获取当前进度
152
- * @returns {Object}
153
- */
154
- getProgress() {
155
- return {
156
- workerId: this.workerId,
157
- status: this.status,
158
- sandboxId: this.executor?.currentSandboxId?.substring(0, 8) || null,
159
- success: this.executor?.results?.success || 0,
160
- failed: this.executor?.results?.failed || 0,
161
- total: this.plan.requests.length
162
- };
163
- }
164
- }
165
-
166
- module.exports = { ReplayWorker };
@@ -1,2 +0,0 @@
1
- // Core replay - re-export from new location
2
- module.exports = require('./core/replay');
@@ -1,2 +0,0 @@
1
- // Compatibility wrapper - delegates to core implementation
2
- module.exports = require('./core/session');