clawdoctor 0.2.0 → 0.3.1
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/dist/alerters/telegram.d.ts +19 -0
- package/dist/alerters/telegram.d.ts.map +1 -1
- package/dist/alerters/telegram.js +128 -1
- package/dist/alerters/telegram.js.map +1 -1
- package/dist/audit.d.ts +15 -0
- package/dist/audit.d.ts.map +1 -0
- package/dist/audit.js +38 -0
- package/dist/audit.js.map +1 -0
- package/dist/config.d.ts +5 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +17 -7
- package/dist/config.js.map +1 -1
- package/dist/daemon.d.ts +7 -0
- package/dist/daemon.d.ts.map +1 -1
- package/dist/daemon.js +120 -6
- package/dist/daemon.js.map +1 -1
- package/dist/healers/auth.d.ts +6 -0
- package/dist/healers/auth.d.ts.map +1 -0
- package/dist/healers/auth.js +55 -0
- package/dist/healers/auth.js.map +1 -0
- package/dist/healers/base.d.ts +11 -0
- package/dist/healers/base.d.ts.map +1 -1
- package/dist/healers/base.js +19 -0
- package/dist/healers/base.js.map +1 -1
- package/dist/healers/cron.d.ts.map +1 -1
- package/dist/healers/cron.js +88 -2
- package/dist/healers/cron.js.map +1 -1
- package/dist/healers/process.d.ts.map +1 -1
- package/dist/healers/process.js +19 -1
- package/dist/healers/process.js.map +1 -1
- package/dist/healers/session.d.ts +6 -0
- package/dist/healers/session.d.ts.map +1 -0
- package/dist/healers/session.js +112 -0
- package/dist/healers/session.js.map +1 -0
- package/dist/index.js +95 -6
- package/dist/index.js.map +1 -1
- package/dist/snapshots.d.ts +20 -0
- package/dist/snapshots.d.ts.map +1 -0
- package/dist/snapshots.js +97 -0
- package/dist/snapshots.js.map +1 -0
- package/dist/test/config.test.js +1 -1
- package/dist/test/healers.test.d.ts +2 -0
- package/dist/test/healers.test.d.ts.map +1 -0
- package/dist/test/healers.test.js +263 -0
- package/dist/test/healers.test.js.map +1 -0
- package/dist/watchers/auth.d.ts.map +1 -1
- package/dist/watchers/auth.js +2 -2
- package/dist/watchers/auth.js.map +1 -1
- package/dist/watchers/cost.js +1 -1
- package/dist/watchers/cost.js.map +1 -1
- package/dist/watchers/cron.d.ts.map +1 -1
- package/dist/watchers/cron.js +4 -3
- package/dist/watchers/cron.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,263 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
const node_test_1 = require("node:test");
|
|
40
|
+
const strict_1 = __importDefault(require("node:assert/strict"));
|
|
41
|
+
const fs_1 = __importDefault(require("fs"));
|
|
42
|
+
const path_1 = __importDefault(require("path"));
|
|
43
|
+
const os_1 = __importDefault(require("os"));
|
|
44
|
+
const config_js_1 = require("../config.js");
|
|
45
|
+
const cron_js_1 = require("../healers/cron.js");
|
|
46
|
+
const auth_js_1 = require("../healers/auth.js");
|
|
47
|
+
const session_js_1 = require("../healers/session.js");
|
|
48
|
+
const tmpDir = fs_1.default.mkdtempSync(path_1.default.join(os_1.default.tmpdir(), 'clawdoctor-healers-test-'));
|
|
49
|
+
function makeConfig(overrides = {}) {
|
|
50
|
+
return {
|
|
51
|
+
...config_js_1.DEFAULT_CONFIG,
|
|
52
|
+
openclawPath: tmpDir,
|
|
53
|
+
dryRun: true, // Always dry-run in tests
|
|
54
|
+
...overrides,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
// ── Snapshot tests ─────────────────────────────────────────────────────────────
|
|
58
|
+
(0, node_test_1.describe)('Snapshots', () => {
|
|
59
|
+
const snapshotsDir = path_1.default.join(tmpDir, 'snapshots-test');
|
|
60
|
+
(0, node_test_1.before)(() => {
|
|
61
|
+
fs_1.default.mkdirSync(snapshotsDir, { recursive: true });
|
|
62
|
+
});
|
|
63
|
+
(0, node_test_1.it)('creates and reads a snapshot file', async () => {
|
|
64
|
+
const { createSnapshot, getSnapshot, listSnapshots } = await Promise.resolve().then(() => __importStar(require('../snapshots.js')));
|
|
65
|
+
const id = createSnapshot('test-action', 'test-target', { key: 'value' }, 'echo rollback');
|
|
66
|
+
strict_1.default.ok(id.includes('test-action'), `Expected id to contain action, got: ${id}`);
|
|
67
|
+
const snap = getSnapshot(id);
|
|
68
|
+
strict_1.default.ok(snap, 'Snapshot should exist');
|
|
69
|
+
strict_1.default.equal(snap.action, 'test-action');
|
|
70
|
+
strict_1.default.equal(snap.target, 'test-target');
|
|
71
|
+
strict_1.default.equal(snap.rollbackCommand, 'echo rollback');
|
|
72
|
+
strict_1.default.deepEqual(snap.before, { key: 'value' });
|
|
73
|
+
const list = listSnapshots();
|
|
74
|
+
strict_1.default.ok(list.some(s => s.id === id), 'Snapshot should appear in list');
|
|
75
|
+
});
|
|
76
|
+
(0, node_test_1.it)('returns null for non-existent snapshot', async () => {
|
|
77
|
+
const { getSnapshot } = await Promise.resolve().then(() => __importStar(require('../snapshots.js')));
|
|
78
|
+
const snap = getSnapshot('non-existent-id-xyz');
|
|
79
|
+
strict_1.default.equal(snap, null);
|
|
80
|
+
});
|
|
81
|
+
(0, node_test_1.it)('executeRollback returns error for missing snapshot', async () => {
|
|
82
|
+
const { executeRollback } = await Promise.resolve().then(() => __importStar(require('../snapshots.js')));
|
|
83
|
+
const result = executeRollback('definitely-does-not-exist');
|
|
84
|
+
strict_1.default.equal(result.success, false);
|
|
85
|
+
strict_1.default.ok(result.message.includes('not found'));
|
|
86
|
+
});
|
|
87
|
+
(0, node_test_1.it)('executeRollback rejects non-allowlisted commands', async () => {
|
|
88
|
+
const { createSnapshot, executeRollback } = await Promise.resolve().then(() => __importStar(require('../snapshots.js')));
|
|
89
|
+
const id = createSnapshot('echo-test', 'test', {}, 'echo hello-rollback');
|
|
90
|
+
const result = executeRollback(id);
|
|
91
|
+
strict_1.default.equal(result.success, false, 'Non-allowlisted command should be rejected');
|
|
92
|
+
strict_1.default.ok(result.message.includes('allowlist'), `Expected allowlist rejection, got: ${result.message}`);
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
// ── Audit trail tests ──────────────────────────────────────────────────────────
|
|
96
|
+
(0, node_test_1.describe)('Audit Trail', () => {
|
|
97
|
+
(0, node_test_1.it)('writes and reads audit entries', async () => {
|
|
98
|
+
const { appendAudit, getRecentAudit } = await Promise.resolve().then(() => __importStar(require('../audit.js')));
|
|
99
|
+
appendAudit({
|
|
100
|
+
timestamp: new Date().toISOString(),
|
|
101
|
+
healer: 'CronHealer',
|
|
102
|
+
action: 'cron-retry',
|
|
103
|
+
target: 'test-cron',
|
|
104
|
+
tier: 'green',
|
|
105
|
+
result: 'success',
|
|
106
|
+
snapshotId: 'snap-001',
|
|
107
|
+
});
|
|
108
|
+
const entries = getRecentAudit(10);
|
|
109
|
+
const found = entries.find(e => e.healer === 'CronHealer' && e.target === 'test-cron');
|
|
110
|
+
strict_1.default.ok(found, 'Audit entry should be found');
|
|
111
|
+
strict_1.default.equal(found.action, 'cron-retry');
|
|
112
|
+
strict_1.default.equal(found.tier, 'green');
|
|
113
|
+
strict_1.default.equal(found.result, 'success');
|
|
114
|
+
strict_1.default.equal(found.snapshotId, 'snap-001');
|
|
115
|
+
});
|
|
116
|
+
(0, node_test_1.it)('returns empty array when no audit file', async () => {
|
|
117
|
+
const { getRecentAudit } = await Promise.resolve().then(() => __importStar(require('../audit.js')));
|
|
118
|
+
// If audit path does not exist, should return []
|
|
119
|
+
const entries = getRecentAudit(1);
|
|
120
|
+
strict_1.default.ok(Array.isArray(entries));
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
// ── CronHealer tests ───────────────────────────────────────────────────────────
|
|
124
|
+
(0, node_test_1.describe)('CronHealer', () => {
|
|
125
|
+
(0, node_test_1.it)('returns dry-run result in dry-run mode (low errors)', async () => {
|
|
126
|
+
const healer = new cron_js_1.CronHealer(makeConfig());
|
|
127
|
+
const result = await healer.heal({
|
|
128
|
+
cronName: 'my-cron',
|
|
129
|
+
consecutiveErrors: 2,
|
|
130
|
+
lastError: 'some error',
|
|
131
|
+
lastRun: new Date().toISOString(),
|
|
132
|
+
});
|
|
133
|
+
strict_1.default.ok(result.success);
|
|
134
|
+
strict_1.default.ok(result.message.includes('my-cron'));
|
|
135
|
+
});
|
|
136
|
+
(0, node_test_1.it)('requests approval for 5+ consecutive errors (dry-run)', async () => {
|
|
137
|
+
const healer = new cron_js_1.CronHealer(makeConfig());
|
|
138
|
+
const result = await healer.heal({
|
|
139
|
+
cronName: 'bad-cron',
|
|
140
|
+
consecutiveErrors: 6,
|
|
141
|
+
lastError: 'persistent failure',
|
|
142
|
+
});
|
|
143
|
+
strict_1.default.ok(result.success);
|
|
144
|
+
strict_1.default.equal(result.tier, 'yellow');
|
|
145
|
+
strict_1.default.ok(result.message.includes('[DRY RUN]'));
|
|
146
|
+
});
|
|
147
|
+
(0, node_test_1.it)('requests approval with approvalOptions when not dry-run', async () => {
|
|
148
|
+
const config = makeConfig({ dryRun: false });
|
|
149
|
+
config.healers.cronRetry.dryRun = false;
|
|
150
|
+
const healer = new cron_js_1.CronHealer(config);
|
|
151
|
+
const result = await healer.heal({
|
|
152
|
+
cronName: 'bad-cron',
|
|
153
|
+
consecutiveErrors: 7,
|
|
154
|
+
lastError: 'network error',
|
|
155
|
+
});
|
|
156
|
+
strict_1.default.equal(result.tier, 'yellow');
|
|
157
|
+
strict_1.default.equal(result.requiresApproval, true);
|
|
158
|
+
strict_1.default.ok(Array.isArray(result.approvalOptions));
|
|
159
|
+
strict_1.default.ok(result.approvalOptions.length >= 3);
|
|
160
|
+
const cbDatas = result.approvalOptions.map(o => o.callbackData);
|
|
161
|
+
strict_1.default.ok(cbDatas.some(d => d.startsWith('cron:retry')));
|
|
162
|
+
strict_1.default.ok(cbDatas.some(d => d.startsWith('cron:disable')));
|
|
163
|
+
strict_1.default.ok(cbDatas.some(d => d.startsWith('cron:ignore')));
|
|
164
|
+
});
|
|
165
|
+
(0, node_test_1.it)('uses green tier for transient errors below threshold (dry-run)', async () => {
|
|
166
|
+
const healer = new cron_js_1.CronHealer(makeConfig());
|
|
167
|
+
const result = await healer.heal({
|
|
168
|
+
cronName: 'network-cron',
|
|
169
|
+
consecutiveErrors: 4,
|
|
170
|
+
lastError: 'network timeout',
|
|
171
|
+
});
|
|
172
|
+
strict_1.default.equal(result.tier, 'green');
|
|
173
|
+
strict_1.default.ok(result.message.includes('[DRY RUN]'));
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
// ── AuthHealer tests ───────────────────────────────────────────────────────────
|
|
177
|
+
(0, node_test_1.describe)('AuthHealer', () => {
|
|
178
|
+
(0, node_test_1.it)('returns dry-run result in dry-run mode', async () => {
|
|
179
|
+
const healer = new auth_js_1.AuthHealer(makeConfig());
|
|
180
|
+
const result = await healer.heal({ provider: 'anthropic', count: 3 });
|
|
181
|
+
strict_1.default.ok(result.success);
|
|
182
|
+
strict_1.default.equal(result.tier, 'green');
|
|
183
|
+
strict_1.default.ok(result.message.includes('[DRY RUN]'));
|
|
184
|
+
});
|
|
185
|
+
(0, node_test_1.it)('has correct healer name', () => {
|
|
186
|
+
const healer = new auth_js_1.AuthHealer(makeConfig());
|
|
187
|
+
strict_1.default.equal(healer.name, 'AuthHealer');
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
// ── SessionHealer tests ────────────────────────────────────────────────────────
|
|
191
|
+
(0, node_test_1.describe)('SessionHealer', () => {
|
|
192
|
+
(0, node_test_1.it)('returns dry-run result for stuck session', async () => {
|
|
193
|
+
const healer = new session_js_1.SessionHealer(makeConfig());
|
|
194
|
+
const result = await healer.heal({
|
|
195
|
+
agent: 'test-agent',
|
|
196
|
+
session: 'session-001.jsonl',
|
|
197
|
+
ageSec: 3 * 3600, // 3 hours = stuck
|
|
198
|
+
sessionPath: '',
|
|
199
|
+
});
|
|
200
|
+
strict_1.default.ok(result.success);
|
|
201
|
+
strict_1.default.equal(result.tier, 'green');
|
|
202
|
+
strict_1.default.ok(result.message.includes('[DRY RUN]'));
|
|
203
|
+
strict_1.default.ok(result.message.includes('stuck') || result.message.includes('180m') || result.message.includes('kill'));
|
|
204
|
+
});
|
|
205
|
+
(0, node_test_1.it)('requests approval for high-cost session (dry-run)', async () => {
|
|
206
|
+
const healer = new session_js_1.SessionHealer(makeConfig());
|
|
207
|
+
const result = await healer.heal({
|
|
208
|
+
agent: 'expensive-agent',
|
|
209
|
+
session: 'session-big.jsonl',
|
|
210
|
+
ageSec: 1800,
|
|
211
|
+
costUsd: 15.50,
|
|
212
|
+
});
|
|
213
|
+
strict_1.default.ok(result.success);
|
|
214
|
+
strict_1.default.equal(result.tier, 'yellow');
|
|
215
|
+
strict_1.default.ok(result.message.includes('[DRY RUN]'));
|
|
216
|
+
strict_1.default.ok(result.message.includes('$15.50'));
|
|
217
|
+
});
|
|
218
|
+
(0, node_test_1.it)('requests approval with buttons when not dry-run for high cost', async () => {
|
|
219
|
+
const config = makeConfig({ dryRun: false });
|
|
220
|
+
config.healers.session.dryRun = false;
|
|
221
|
+
const healer = new session_js_1.SessionHealer(config);
|
|
222
|
+
const result = await healer.heal({
|
|
223
|
+
agent: 'costly-agent',
|
|
224
|
+
session: 'session-x.jsonl',
|
|
225
|
+
ageSec: 600,
|
|
226
|
+
costUsd: 12.00,
|
|
227
|
+
});
|
|
228
|
+
strict_1.default.equal(result.tier, 'yellow');
|
|
229
|
+
strict_1.default.equal(result.requiresApproval, true);
|
|
230
|
+
strict_1.default.ok(Array.isArray(result.approvalOptions));
|
|
231
|
+
const cbDatas = result.approvalOptions.map(o => o.callbackData);
|
|
232
|
+
strict_1.default.ok(cbDatas.some(d => d.startsWith('session:kill')));
|
|
233
|
+
strict_1.default.ok(cbDatas.some(d => d.startsWith('session:ignore')));
|
|
234
|
+
});
|
|
235
|
+
(0, node_test_1.it)('has correct healer name', () => {
|
|
236
|
+
const healer = new session_js_1.SessionHealer(makeConfig());
|
|
237
|
+
strict_1.default.equal(healer.name, 'SessionHealer');
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
// ── TelegramAlerter inline keyboard tests ─────────────────────────────────────
|
|
241
|
+
(0, node_test_1.describe)('TelegramAlerter inline keyboard', () => {
|
|
242
|
+
(0, node_test_1.it)('formatApprovalMessage returns correct structure', async () => {
|
|
243
|
+
const { TelegramAlerter } = await Promise.resolve().then(() => __importStar(require('../alerters/telegram.js')));
|
|
244
|
+
const config = makeConfig();
|
|
245
|
+
const alerter = new TelegramAlerter(config);
|
|
246
|
+
const options = [
|
|
247
|
+
{ text: 'Retry', callbackData: 'cron:retry:test' },
|
|
248
|
+
{ text: 'Disable', callbackData: 'cron:disable:test' },
|
|
249
|
+
];
|
|
250
|
+
const { text, buttons } = alerter.formatApprovalMessage('CronWatcher', 'test issue', options);
|
|
251
|
+
strict_1.default.ok(text.includes('CronWatcher'));
|
|
252
|
+
strict_1.default.ok(text.includes('test issue'));
|
|
253
|
+
strict_1.default.ok(Array.isArray(buttons));
|
|
254
|
+
strict_1.default.equal(buttons.length, 1);
|
|
255
|
+
strict_1.default.equal(buttons[0].length, 2);
|
|
256
|
+
strict_1.default.equal(buttons[0][0].text, 'Retry');
|
|
257
|
+
strict_1.default.equal(buttons[0][0].callback_data, 'cron:retry:test');
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
(0, node_test_1.after)(() => {
|
|
261
|
+
fs_1.default.rmSync(tmpDir, { recursive: true, force: true });
|
|
262
|
+
});
|
|
263
|
+
//# sourceMappingURL=healers.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"healers.test.js","sourceRoot":"","sources":["../../src/test/healers.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/watchers/auth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAerD,qBAAa,WAAY,SAAQ,WAAW;IAC1C,QAAQ,CAAC,IAAI,iBAAiB;IAC9B,QAAQ,CAAC,eAAe,MAAM;IAExB,KAAK,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAmBrC,OAAO,CAAC,eAAe;
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/watchers/auth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAerD,qBAAa,WAAY,SAAQ,WAAW;IAC1C,QAAQ,CAAC,IAAI,iBAAiB;IAC9B,QAAQ,CAAC,eAAe,MAAM;IAExB,KAAK,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAmBrC,OAAO,CAAC,eAAe;IAavB,OAAO,CAAC,YAAY;IAoBpB,OAAO,CAAC,YAAY;CAqBrB"}
|
package/dist/watchers/auth.js
CHANGED
|
@@ -34,7 +34,7 @@ class AuthWatcher extends base_js_1.BaseWatcher {
|
|
|
34
34
|
}
|
|
35
35
|
readJournalLogs() {
|
|
36
36
|
try {
|
|
37
|
-
const output = (0, child_process_1.
|
|
37
|
+
const output = (0, child_process_1.execFileSync)('journalctl', ['-u', 'openclaw-gateway', '--since', '5 minutes ago', '--no-pager', '-q'], { encoding: 'utf-8', timeout: 5000 });
|
|
38
38
|
return output.split('\n').slice(-MAX_LOG_LINES);
|
|
39
39
|
}
|
|
40
40
|
catch {
|
|
@@ -48,7 +48,7 @@ class AuthWatcher extends base_js_1.BaseWatcher {
|
|
|
48
48
|
];
|
|
49
49
|
for (const logPath of logPaths) {
|
|
50
50
|
try {
|
|
51
|
-
const output = (0, child_process_1.
|
|
51
|
+
const output = (0, child_process_1.execFileSync)('tail', ['-n', String(MAX_LOG_LINES), logPath], {
|
|
52
52
|
encoding: 'utf-8',
|
|
53
53
|
timeout: 3000,
|
|
54
54
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/watchers/auth.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/watchers/auth.ts"],"names":[],"mappings":"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"}
|
package/dist/watchers/cost.js
CHANGED
|
@@ -47,7 +47,7 @@ class CostWatcher extends base_js_1.BaseWatcher {
|
|
|
47
47
|
const threshold = avgCost * ANOMALY_MULTIPLIER;
|
|
48
48
|
const anomalies = recentSessions.filter(s => s.cost > threshold && s.cost > 0.01);
|
|
49
49
|
if (anomalies.length === 0) {
|
|
50
|
-
results.push(this.ok(`Cost normal
|
|
50
|
+
results.push(this.ok(`Cost normal, avg $${avgCost.toFixed(4)}/session, ${recentSessions.length} recent session(s) checked`, 'cost_ok'));
|
|
51
51
|
}
|
|
52
52
|
else {
|
|
53
53
|
for (const anomaly of anomalies) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cost.js","sourceRoot":"","sources":["../../src/watchers/cost.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAoB;AACpB,gDAAwB;AACxB,uCAAqD;AACrD,0CAA6C;AAoB7C,MAAM,cAAc,GAAG,EAAE,CAAC;AAC1B,MAAM,kBAAkB,GAAG,CAAC,CAAC;AAC7B,MAAM,YAAY,GAAG,CAAC,CAAC;AAEvB,MAAa,WAAY,SAAQ,qBAAW;IACjC,IAAI,GAAG,aAAa,CAAC;IACrB,eAAe,GAAG,GAAG,CAAC;IAE/B,KAAK,CAAC,KAAK;QACT,MAAM,SAAS,GAAG,cAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAChE,MAAM,OAAO,GAAkB,EAAE,CAAC;QAElC,IAAI,CAAC,YAAE,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,2BAA2B,EAAE,oBAAoB,CAAC,CAAC,CAAC;YACzE,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC;QAEzD,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,gDAAgD,EAAE,kBAAkB,CAAC,CAAC,CAAC;YAC5F,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,iCAAiC;QACjC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC;QAE3E,gDAAgD;QAChD,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,YAAY,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC;QACvE,MAAM,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,GAAG,YAAY,CAAC,CAAC;QAE5E,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,gDAAgD,EAAE,SAAS,CAAC,CAAC,CAAC;YACnF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,sFAAsF;QACtF,MAAM,kBAAkB,GAAG,YAAY;aACpC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,IAAI,YAAY,CAAC;aACxC,KAAK,CAAC,CAAC,cAAc,CAAC,CAAC;QAE1B,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,8CAA8C,EAAE,kBAAkB,CAAC,CAAC,CAAC;YAC1F,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,MAAM,OAAO,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,kBAAkB,CAAC,MAAM,CAAC;QACnG,MAAM,SAAS,GAAG,OAAO,GAAG,kBAAkB,CAAC;QAE/C,MAAM,SAAS,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,SAAS,IAAI,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAElF,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC3B,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,EAAE,CACL,
|
|
1
|
+
{"version":3,"file":"cost.js","sourceRoot":"","sources":["../../src/watchers/cost.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cron.d.ts","sourceRoot":"","sources":["../../src/watchers/cron.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"cron.d.ts","sourceRoot":"","sources":["../../src/watchers/cron.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AA4BrD,qBAAa,WAAY,SAAQ,WAAW;IAC1C,QAAQ,CAAC,IAAI,iBAAiB;IAC9B,QAAQ,CAAC,eAAe,MAAM;IAExB,KAAK,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;CAqGtC"}
|
package/dist/watchers/cron.js
CHANGED
|
@@ -56,13 +56,14 @@ class CronWatcher extends base_js_1.BaseWatcher {
|
|
|
56
56
|
const overdueMs = now - state.nextRunAtMs;
|
|
57
57
|
// Consider overdue if more than 30 minutes past expected next run
|
|
58
58
|
if (overdueMs > 30 * 60 * 1000) {
|
|
59
|
-
results.push(this.warn(`Cron '${name}' overdue
|
|
59
|
+
results.push(this.warn(`Cron '${name}' overdue, was expected ${Math.round(overdueMs / 60000)}m ago`, 'cron_overdue', { cronName: name, jobId: job.id, nextRunAtMs: state.nextRunAtMs, overdueMs }));
|
|
60
60
|
overdue++;
|
|
61
61
|
continue;
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
|
-
// Check delivery status
|
|
65
|
-
|
|
64
|
+
// Check delivery status (skip if delivery mode is "none" — not-delivered is expected)
|
|
65
|
+
const deliveryMode = job.delivery?.mode ?? 'announce';
|
|
66
|
+
if (deliveryMode !== 'none' && state.lastDeliveryStatus && state.lastDeliveryStatus !== 'delivered') {
|
|
66
67
|
results.push(this.warn(`Cron '${name}' last delivery failed: ${state.lastDeliveryStatus}`, 'cron_delivery_failed', { cronName: name, jobId: job.id, lastDeliveryStatus: state.lastDeliveryStatus }));
|
|
67
68
|
continue;
|
|
68
69
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cron.js","sourceRoot":"","sources":["../../src/watchers/cron.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAoB;AACpB,gDAAwB;AACxB,uCAAqD;
|
|
1
|
+
{"version":3,"file":"cron.js","sourceRoot":"","sources":["../../src/watchers/cron.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED