@skillsmith/core 0.4.16 → 0.5.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.
- package/CHANGELOG.md +34 -0
- package/README.md +57 -2
- package/dist/.tsbuildinfo +1 -1
- package/dist/src/api/client.d.ts +21 -21
- package/dist/src/api/client.d.ts.map +1 -1
- package/dist/src/api/client.events.d.ts +39 -0
- package/dist/src/api/client.events.d.ts.map +1 -0
- package/dist/src/api/client.events.js +77 -0
- package/dist/src/api/client.events.js.map +1 -0
- package/dist/src/api/client.js +39 -33
- package/dist/src/api/client.js.map +1 -1
- package/dist/src/api/event-batcher.d.ts +81 -0
- package/dist/src/api/event-batcher.d.ts.map +1 -0
- package/dist/src/api/event-batcher.js +191 -0
- package/dist/src/api/event-batcher.js.map +1 -0
- package/dist/src/api/index.d.ts +1 -0
- package/dist/src/api/index.d.ts.map +1 -1
- package/dist/src/api/index.js +2 -0
- package/dist/src/api/index.js.map +1 -1
- package/dist/src/api/schemas.d.ts +62 -4
- package/dist/src/api/schemas.d.ts.map +1 -1
- package/dist/src/api/schemas.js +45 -0
- package/dist/src/api/schemas.js.map +1 -1
- package/dist/src/db/migration-runner.d.ts +44 -0
- package/dist/src/db/migration-runner.d.ts.map +1 -0
- package/dist/src/db/migration-runner.js +175 -0
- package/dist/src/db/migration-runner.js.map +1 -0
- package/dist/src/db/migration.d.ts.map +1 -1
- package/dist/src/db/migration.js +2 -1
- package/dist/src/db/migration.js.map +1 -1
- package/dist/src/db/migrations/v12-risk-score-history.d.ts +10 -0
- package/dist/src/db/migrations/v12-risk-score-history.d.ts.map +1 -0
- package/dist/src/db/migrations/v12-risk-score-history.js +25 -0
- package/dist/src/db/migrations/v12-risk-score-history.js.map +1 -0
- package/dist/src/db/migrations/v13-team-tables.d.ts +11 -0
- package/dist/src/db/migrations/v13-team-tables.d.ts.map +1 -0
- package/dist/src/db/migrations/v13-team-tables.js +14 -0
- package/dist/src/db/migrations/v13-team-tables.js.map +1 -0
- package/dist/src/db/schema-sql.d.ts +16 -0
- package/dist/src/db/schema-sql.d.ts.map +1 -0
- package/dist/src/db/schema-sql.js +161 -0
- package/dist/src/db/schema-sql.js.map +1 -0
- package/dist/src/db/schema.d.ts +7 -32
- package/dist/src/db/schema.d.ts.map +1 -1
- package/dist/src/db/schema.js +14 -298
- package/dist/src/db/schema.js.map +1 -1
- package/dist/src/embeddings/hnsw-store.d.ts +1 -1
- package/dist/src/embeddings/hnsw-store.d.ts.map +1 -1
- package/dist/src/embeddings/hnsw-store.js +4 -34
- package/dist/src/embeddings/hnsw-store.js.map +1 -1
- package/dist/src/embeddings/hnsw-store.types.d.ts +18 -0
- package/dist/src/embeddings/hnsw-store.types.d.ts.map +1 -1
- package/dist/src/embeddings/hnsw-store.types.js.map +1 -1
- package/dist/src/exports/repositories.d.ts +1 -0
- package/dist/src/exports/repositories.d.ts.map +1 -1
- package/dist/src/exports/repositories.js +4 -0
- package/dist/src/exports/repositories.js.map +1 -1
- package/dist/src/exports/services.d.ts +4 -0
- package/dist/src/exports/services.d.ts.map +1 -1
- package/dist/src/exports/services.js +7 -0
- package/dist/src/exports/services.js.map +1 -1
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.js +1 -1
- package/dist/src/learning/PatternStore.d.ts.map +1 -1
- package/dist/src/learning/PatternStore.js +2 -9
- package/dist/src/learning/PatternStore.js.map +1 -1
- package/dist/src/repositories/RiskScoreHistoryRepository.d.ts +37 -0
- package/dist/src/repositories/RiskScoreHistoryRepository.d.ts.map +1 -0
- package/dist/src/repositories/RiskScoreHistoryRepository.js +66 -0
- package/dist/src/repositories/RiskScoreHistoryRepository.js.map +1 -0
- package/dist/src/routing/SONARouter.d.ts.map +1 -1
- package/dist/src/routing/SONARouter.js +4 -15
- package/dist/src/routing/SONARouter.js.map +1 -1
- package/dist/src/scoring/index.d.ts +1 -0
- package/dist/src/scoring/index.d.ts.map +1 -1
- package/dist/src/scoring/index.js +1 -0
- package/dist/src/scoring/index.js.map +1 -1
- package/dist/src/scoring/quality-score.d.ts +49 -0
- package/dist/src/scoring/quality-score.d.ts.map +1 -0
- package/dist/src/scoring/quality-score.js +73 -0
- package/dist/src/scoring/quality-score.js.map +1 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.js +10 -0
- package/dist/src/scripts/__tests__/scan-imported-skills.test.js.map +1 -1
- package/dist/src/scripts/validation/types.d.ts +2 -2
- package/dist/src/security/index.d.ts +2 -0
- package/dist/src/security/index.d.ts.map +1 -1
- package/dist/src/security/index.js +2 -0
- package/dist/src/security/index.js.map +1 -1
- package/dist/src/security/risk-trend.d.ts +21 -0
- package/dist/src/security/risk-trend.d.ts.map +1 -0
- package/dist/src/security/risk-trend.js +81 -0
- package/dist/src/security/risk-trend.js.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.d.ts +6 -2
- package/dist/src/security/scanner/SecurityScanner.d.ts.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.helpers.d.ts +24 -2
- package/dist/src/security/scanner/SecurityScanner.helpers.d.ts.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.helpers.js +111 -9
- package/dist/src/security/scanner/SecurityScanner.helpers.js.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.js +64 -71
- package/dist/src/security/scanner/SecurityScanner.js.map +1 -1
- package/dist/src/security/scanner/SecurityScanner.ssrf.d.ts +15 -0
- package/dist/src/security/scanner/SecurityScanner.ssrf.d.ts.map +1 -0
- package/dist/src/security/scanner/SecurityScanner.ssrf.js +76 -0
- package/dist/src/security/scanner/SecurityScanner.ssrf.js.map +1 -0
- package/dist/src/security/scanner/index.d.ts +1 -1
- package/dist/src/security/scanner/index.d.ts.map +1 -1
- package/dist/src/security/scanner/index.js +1 -1
- package/dist/src/security/scanner/index.js.map +1 -1
- package/dist/src/security/scanner/patterns.d.ts +12 -0
- package/dist/src/security/scanner/patterns.d.ts.map +1 -1
- package/dist/src/security/scanner/patterns.js +57 -0
- package/dist/src/security/scanner/patterns.js.map +1 -1
- package/dist/src/security/scanner/types.d.ts +3 -1
- package/dist/src/security/scanner/types.d.ts.map +1 -1
- package/dist/src/security/scanner/weights.d.ts.map +1 -1
- package/dist/src/security/scanner/weights.js +2 -0
- package/dist/src/security/scanner/weights.js.map +1 -1
- package/dist/src/services/skill-config-schema.d.ts +36 -0
- package/dist/src/services/skill-config-schema.d.ts.map +1 -0
- package/dist/src/services/skill-config-schema.js +76 -0
- package/dist/src/services/skill-config-schema.js.map +1 -0
- package/dist/src/services/skill-installation.feedback.d.ts +24 -0
- package/dist/src/services/skill-installation.feedback.d.ts.map +1 -0
- package/dist/src/services/skill-installation.feedback.js +37 -0
- package/dist/src/services/skill-installation.feedback.js.map +1 -0
- package/dist/src/services/skill-installation.helpers.d.ts +88 -0
- package/dist/src/services/skill-installation.helpers.d.ts.map +1 -0
- package/dist/src/services/skill-installation.helpers.js +377 -0
- package/dist/src/services/skill-installation.helpers.js.map +1 -0
- package/dist/src/services/skill-installation.service.d.ts +37 -0
- package/dist/src/services/skill-installation.service.d.ts.map +1 -0
- package/dist/src/services/skill-installation.service.js +432 -0
- package/dist/src/services/skill-installation.service.js.map +1 -0
- package/dist/src/services/skill-installation.types.d.ts +166 -0
- package/dist/src/services/skill-installation.types.d.ts.map +1 -0
- package/dist/src/services/skill-installation.types.js +38 -0
- package/dist/src/services/skill-installation.types.js.map +1 -0
- package/dist/src/services/skill-manifest.d.ts +20 -0
- package/dist/src/services/skill-manifest.d.ts.map +1 -0
- package/dist/src/services/skill-manifest.js +84 -0
- package/dist/src/services/skill-manifest.js.map +1 -0
- package/dist/src/session/SessionManager.helpers.d.ts +1 -27
- package/dist/src/session/SessionManager.helpers.d.ts.map +1 -1
- package/dist/src/session/SessionManager.helpers.js +0 -64
- package/dist/src/session/SessionManager.helpers.js.map +1 -1
- package/dist/src/session/SessionManager.memory.d.ts +12 -11
- package/dist/src/session/SessionManager.memory.d.ts.map +1 -1
- package/dist/src/session/SessionManager.memory.js +23 -115
- package/dist/src/session/SessionManager.memory.js.map +1 -1
- package/dist/src/session/SessionManager.types.d.ts +0 -37
- package/dist/src/session/SessionManager.types.d.ts.map +1 -1
- package/dist/src/session/SessionManager.types.js.map +1 -1
- package/dist/src/session/SessionRecovery.js +4 -4
- package/dist/src/session/SessionRecovery.js.map +1 -1
- package/dist/src/testing/MultiLLMProvider.d.ts.map +1 -1
- package/dist/src/testing/MultiLLMProvider.js +5 -19
- package/dist/src/testing/MultiLLMProvider.js.map +1 -1
- package/dist/src/types.d.ts +2 -0
- package/dist/src/types.d.ts.map +1 -1
- package/dist/tests/SecurityScanner.ai-defence.test.d.ts +6 -0
- package/dist/tests/SecurityScanner.ai-defence.test.d.ts.map +1 -0
- package/dist/tests/SecurityScanner.ai-defence.test.js +221 -0
- package/dist/tests/SecurityScanner.ai-defence.test.js.map +1 -0
- package/dist/tests/SecurityScanner.performance.test.d.ts +6 -0
- package/dist/tests/SecurityScanner.performance.test.d.ts.map +1 -0
- package/dist/tests/SecurityScanner.performance.test.js +132 -0
- package/dist/tests/SecurityScanner.performance.test.js.map +1 -0
- package/dist/tests/SecurityScanner.scoring.test.d.ts +6 -0
- package/dist/tests/SecurityScanner.scoring.test.d.ts.map +1 -0
- package/dist/tests/SecurityScanner.scoring.test.js +197 -0
- package/dist/tests/SecurityScanner.scoring.test.js.map +1 -0
- package/dist/tests/SecurityScanner.test.d.ts +2 -2
- package/dist/tests/SecurityScanner.test.js +2 -520
- package/dist/tests/SecurityScanner.test.js.map +1 -1
- package/dist/tests/SkillMatcher.test.js +5 -5
- package/dist/tests/SkillMatcher.test.js.map +1 -1
- package/dist/tests/billing/StripeClient.test.d.ts +18 -0
- package/dist/tests/billing/StripeClient.test.d.ts.map +1 -0
- package/dist/tests/billing/StripeClient.test.js +566 -0
- package/dist/tests/billing/StripeClient.test.js.map +1 -0
- package/dist/tests/billing/StripeWebhookHandler.test.d.ts +16 -0
- package/dist/tests/billing/StripeWebhookHandler.test.d.ts.map +1 -0
- package/dist/tests/billing/StripeWebhookHandler.test.js +240 -0
- package/dist/tests/billing/StripeWebhookHandler.test.js.map +1 -0
- package/dist/tests/billing/stripe-helpers.test.d.ts +7 -0
- package/dist/tests/billing/stripe-helpers.test.d.ts.map +1 -0
- package/dist/tests/billing/stripe-helpers.test.js +91 -0
- package/dist/tests/billing/stripe-helpers.test.js.map +1 -0
- package/dist/tests/billing/webhook-handlers.test.d.ts +16 -0
- package/dist/tests/billing/webhook-handlers.test.d.ts.map +1 -0
- package/dist/tests/billing/webhook-handlers.test.js +519 -0
- package/dist/tests/billing/webhook-handlers.test.js.map +1 -0
- package/dist/tests/db/migration.test.d.ts +11 -0
- package/dist/tests/db/migration.test.d.ts.map +1 -0
- package/dist/tests/db/migration.test.js +265 -0
- package/dist/tests/db/migration.test.js.map +1 -0
- package/dist/tests/db/schema-migrations.test.js +8 -6
- package/dist/tests/db/schema-migrations.test.js.map +1 -1
- package/dist/tests/integration/events-batch-contract.test.d.ts +12 -0
- package/dist/tests/integration/events-batch-contract.test.d.ts.map +1 -0
- package/dist/tests/integration/events-batch-contract.test.js +69 -0
- package/dist/tests/integration/events-batch-contract.test.js.map +1 -0
- package/dist/tests/scoring/quality-score.test.d.ts +7 -0
- package/dist/tests/scoring/quality-score.test.d.ts.map +1 -0
- package/dist/tests/scoring/quality-score.test.js +78 -0
- package/dist/tests/scoring/quality-score.test.js.map +1 -0
- package/dist/tests/security/ContinuousSecurity.false-positives.test.d.ts +6 -0
- package/dist/tests/security/ContinuousSecurity.false-positives.test.d.ts.map +1 -0
- package/dist/tests/security/ContinuousSecurity.false-positives.test.js +89 -0
- package/dist/tests/security/ContinuousSecurity.false-positives.test.js.map +1 -0
- package/dist/tests/security/ContinuousSecurity.performance.test.d.ts +6 -0
- package/dist/tests/security/ContinuousSecurity.performance.test.d.ts.map +1 -0
- package/dist/tests/security/ContinuousSecurity.performance.test.js +177 -0
- package/dist/tests/security/ContinuousSecurity.performance.test.js.map +1 -0
- package/dist/tests/security/ContinuousSecurity.reporting.test.d.ts +6 -0
- package/dist/tests/security/ContinuousSecurity.reporting.test.d.ts.map +1 -0
- package/dist/tests/security/ContinuousSecurity.reporting.test.js +106 -0
- package/dist/tests/security/ContinuousSecurity.reporting.test.js.map +1 -0
- package/dist/tests/security/ContinuousSecurity.test.d.ts +9 -2
- package/dist/tests/security/ContinuousSecurity.test.d.ts.map +1 -1
- package/dist/tests/security/ContinuousSecurity.test.js +9 -336
- package/dist/tests/security/ContinuousSecurity.test.js.map +1 -1
- package/dist/tests/security/pii-detection.test.d.ts +7 -0
- package/dist/tests/security/pii-detection.test.d.ts.map +1 -0
- package/dist/tests/security/pii-detection.test.js +91 -0
- package/dist/tests/security/pii-detection.test.js.map +1 -0
- package/dist/tests/security/risk-trend.test.d.ts +6 -0
- package/dist/tests/security/risk-trend.test.d.ts.map +1 -0
- package/dist/tests/security/risk-trend.test.js +68 -0
- package/dist/tests/security/risk-trend.test.js.map +1 -0
- package/dist/tests/security/scanner-regression-guard.test.d.ts +12 -0
- package/dist/tests/security/scanner-regression-guard.test.d.ts.map +1 -0
- package/dist/tests/security/scanner-regression-guard.test.js +111 -0
- package/dist/tests/security/scanner-regression-guard.test.js.map +1 -0
- package/dist/tests/security.test.js +200 -0
- package/dist/tests/security.test.js.map +1 -1
- package/dist/tests/services/aidefence-feedback.test.d.ts +6 -0
- package/dist/tests/services/aidefence-feedback.test.d.ts.map +1 -0
- package/dist/tests/services/aidefence-feedback.test.js +115 -0
- package/dist/tests/services/aidefence-feedback.test.js.map +1 -0
- package/dist/tests/services/dep-quarantine-check.test.d.ts +5 -0
- package/dist/tests/services/dep-quarantine-check.test.d.ts.map +1 -0
- package/dist/tests/services/dep-quarantine-check.test.js +92 -0
- package/dist/tests/services/dep-quarantine-check.test.js.map +1 -0
- package/dist/tests/services/skill-config-schema.test.d.ts +5 -0
- package/dist/tests/services/skill-config-schema.test.d.ts.map +1 -0
- package/dist/tests/services/skill-config-schema.test.js +98 -0
- package/dist/tests/services/skill-config-schema.test.js.map +1 -0
- package/dist/tests/session/SessionManager.helpers.test.js +1 -9
- package/dist/tests/session/SessionManager.helpers.test.js.map +1 -1
- package/dist/tests/session/SessionManager.memory.test.d.ts +3 -4
- package/dist/tests/session/SessionManager.memory.test.d.ts.map +1 -1
- package/dist/tests/session/SessionManager.memory.test.js +41 -123
- package/dist/tests/session/SessionManager.memory.test.js.map +1 -1
- package/dist/tests/sync/BackgroundSyncService.test.d.ts +13 -0
- package/dist/tests/sync/BackgroundSyncService.test.d.ts.map +1 -0
- package/dist/tests/sync/BackgroundSyncService.test.js +259 -0
- package/dist/tests/sync/BackgroundSyncService.test.js.map +1 -0
- package/dist/tests/testkit.d.ts +14 -0
- package/dist/tests/testkit.d.ts.map +1 -0
- package/dist/tests/testkit.js +14 -0
- package/dist/tests/testkit.js.map +1 -0
- package/dist/tests/unit/api-client-events.test.d.ts +10 -0
- package/dist/tests/unit/api-client-events.test.d.ts.map +1 -0
- package/dist/tests/unit/api-client-events.test.js +73 -0
- package/dist/tests/unit/api-client-events.test.js.map +1 -0
- package/dist/tests/unit/event-batcher.test.d.ts +13 -0
- package/dist/tests/unit/event-batcher.test.d.ts.map +1 -0
- package/dist/tests/unit/event-batcher.test.js +155 -0
- package/dist/tests/unit/event-batcher.test.js.map +1 -0
- package/dist/tests/unit/migrations/v10-dependencies.test.js +3 -3
- package/dist/tests/unit/migrations/v10-dependencies.test.js.map +1 -1
- package/dist/tests/unit/services/skill-installation-extended.test.d.ts +8 -0
- package/dist/tests/unit/services/skill-installation-extended.test.d.ts.map +1 -0
- package/dist/tests/unit/services/skill-installation-extended.test.js +423 -0
- package/dist/tests/unit/services/skill-installation-extended.test.js.map +1 -0
- package/dist/tests/unit/services/skill-installation.service.test.d.ts +8 -0
- package/dist/tests/unit/services/skill-installation.service.test.d.ts.map +1 -0
- package/dist/tests/unit/services/skill-installation.service.test.js +342 -0
- package/dist/tests/unit/services/skill-installation.service.test.js.map +1 -0
- package/package.json +22 -10
- package/dist/vitest.config.d.ts +0 -3
- package/dist/vitest.config.d.ts.map +0 -1
- package/dist/vitest.config.js +0 -13
- package/dist/vitest.config.js.map +0 -1
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Dependency Quarantine Cross-Check Tests - SMI-3871
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect } from 'vitest';
|
|
5
|
+
import { checkDepsAgainstQuarantine } from '../../src/services/skill-installation.helpers.js';
|
|
6
|
+
function makeDepIntel(overrides = {}) {
|
|
7
|
+
return {
|
|
8
|
+
dep_inferred_servers: [],
|
|
9
|
+
dep_declared: undefined,
|
|
10
|
+
dep_warnings: [],
|
|
11
|
+
...overrides,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
describe('checkDepsAgainstQuarantine', () => {
|
|
15
|
+
it('returns no warnings when there are no deps', () => {
|
|
16
|
+
const result = checkDepsAgainstQuarantine(makeDepIntel(), () => null);
|
|
17
|
+
expect(result.warnings).toEqual([]);
|
|
18
|
+
expect(result.quarantinedDeps).toEqual([]);
|
|
19
|
+
});
|
|
20
|
+
it('returns no warnings when deps are not quarantined', () => {
|
|
21
|
+
const depIntel = makeDepIntel({ dep_inferred_servers: ['server-a', 'server-b'] });
|
|
22
|
+
const result = checkDepsAgainstQuarantine(depIntel, () => null);
|
|
23
|
+
expect(result.warnings).toEqual([]);
|
|
24
|
+
expect(result.quarantinedDeps).toEqual([]);
|
|
25
|
+
});
|
|
26
|
+
it('warns about inferred server that is pending review', () => {
|
|
27
|
+
const depIntel = makeDepIntel({ dep_inferred_servers: ['suspicious-server'] });
|
|
28
|
+
const getStatus = (id) => id === 'suspicious-server' ? 'pending' : null;
|
|
29
|
+
const result = checkDepsAgainstQuarantine(depIntel, getStatus);
|
|
30
|
+
expect(result.warnings).toHaveLength(1);
|
|
31
|
+
expect(result.warnings[0]).toContain('under review');
|
|
32
|
+
expect(result.quarantinedDeps).toEqual(['suspicious-server']);
|
|
33
|
+
});
|
|
34
|
+
it('warns about inferred server that is confirmed malicious', () => {
|
|
35
|
+
const depIntel = makeDepIntel({ dep_inferred_servers: ['malicious-server'] });
|
|
36
|
+
const getStatus = (id) => id === 'malicious-server' ? 'rejected' : null;
|
|
37
|
+
const result = checkDepsAgainstQuarantine(depIntel, getStatus);
|
|
38
|
+
expect(result.warnings).toHaveLength(1);
|
|
39
|
+
expect(result.warnings[0]).toContain('confirmed malicious');
|
|
40
|
+
expect(result.quarantinedDeps).toEqual(['malicious-server']);
|
|
41
|
+
});
|
|
42
|
+
it('warns about declared MCP server dependencies', () => {
|
|
43
|
+
const depIntel = makeDepIntel({
|
|
44
|
+
dep_declared: {
|
|
45
|
+
platform: {
|
|
46
|
+
mcp_servers: [
|
|
47
|
+
{ name: 'bad-mcp', required: true },
|
|
48
|
+
{ name: 'good-mcp', required: false },
|
|
49
|
+
],
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
const getStatus = (id) => id === 'bad-mcp' ? 'rejected' : null;
|
|
54
|
+
const result = checkDepsAgainstQuarantine(depIntel, getStatus);
|
|
55
|
+
expect(result.warnings).toHaveLength(1);
|
|
56
|
+
expect(result.warnings[0]).toContain('bad-mcp');
|
|
57
|
+
expect(result.quarantinedDeps).toEqual(['bad-mcp']);
|
|
58
|
+
});
|
|
59
|
+
it('deduplicates when same dep appears in both inferred and declared', () => {
|
|
60
|
+
const depIntel = makeDepIntel({
|
|
61
|
+
dep_inferred_servers: ['overlap-server'],
|
|
62
|
+
dep_declared: {
|
|
63
|
+
platform: {
|
|
64
|
+
mcp_servers: [{ name: 'overlap-server', required: true }],
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
});
|
|
68
|
+
const getStatus = () => 'pending';
|
|
69
|
+
const result = checkDepsAgainstQuarantine(depIntel, getStatus);
|
|
70
|
+
expect(result.warnings).toHaveLength(1);
|
|
71
|
+
expect(result.quarantinedDeps).toEqual(['overlap-server']);
|
|
72
|
+
});
|
|
73
|
+
it('handles multiple quarantined deps', () => {
|
|
74
|
+
const depIntel = makeDepIntel({
|
|
75
|
+
dep_inferred_servers: ['bad-a', 'good-b', 'bad-c'],
|
|
76
|
+
});
|
|
77
|
+
const quarantined = new Set(['bad-a', 'bad-c']);
|
|
78
|
+
const getStatus = (id) => quarantined.has(id) ? 'rejected' : null;
|
|
79
|
+
const result = checkDepsAgainstQuarantine(depIntel, getStatus);
|
|
80
|
+
expect(result.warnings).toHaveLength(2);
|
|
81
|
+
expect(result.quarantinedDeps).toEqual(['bad-a', 'bad-c']);
|
|
82
|
+
});
|
|
83
|
+
it('handles dep_declared without platform', () => {
|
|
84
|
+
const depIntel = makeDepIntel({
|
|
85
|
+
dep_inferred_servers: ['safe'],
|
|
86
|
+
dep_declared: { skills: [{ name: 'some-skill', type: 'soft' }] },
|
|
87
|
+
});
|
|
88
|
+
const result = checkDepsAgainstQuarantine(depIntel, () => null);
|
|
89
|
+
expect(result.warnings).toEqual([]);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
//# sourceMappingURL=dep-quarantine-check.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dep-quarantine-check.test.js","sourceRoot":"","sources":["../../../tests/services/dep-quarantine-check.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-config-schema.test.d.ts","sourceRoot":"","sources":["../../../tests/services/skill-config-schema.test.ts"],"names":[],"mappings":"AAAA;;GAEG"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Config.json Schema Validation Tests - SMI-3870
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect } from 'vitest';
|
|
5
|
+
import { validateSkillConfig, SkillConfigSchema } from '../../src/services/skill-config-schema.js';
|
|
6
|
+
describe('validateSkillConfig', () => {
|
|
7
|
+
it('accepts valid config with all fields', () => {
|
|
8
|
+
const config = JSON.stringify({
|
|
9
|
+
displayName: 'My Skill',
|
|
10
|
+
version: '1.0.0',
|
|
11
|
+
presets: { theme: 'dark', maxRetries: 3, verbose: true },
|
|
12
|
+
settings: { timeout: 5000, debug: false },
|
|
13
|
+
mcpServers: ['server-a', 'server-b'],
|
|
14
|
+
minClaudeCodeVersion: '1.2.0',
|
|
15
|
+
});
|
|
16
|
+
const result = validateSkillConfig(config);
|
|
17
|
+
expect(result.valid).toBe(true);
|
|
18
|
+
expect(result.errors).toEqual([]);
|
|
19
|
+
expect(result.warnings).toEqual([]);
|
|
20
|
+
expect(result.config).toBeDefined();
|
|
21
|
+
});
|
|
22
|
+
it('accepts empty object (all fields optional)', () => {
|
|
23
|
+
const result = validateSkillConfig('{}');
|
|
24
|
+
expect(result.valid).toBe(true);
|
|
25
|
+
expect(result.errors).toEqual([]);
|
|
26
|
+
});
|
|
27
|
+
it('rejects invalid JSON', () => {
|
|
28
|
+
const result = validateSkillConfig('not json at all');
|
|
29
|
+
expect(result.valid).toBe(false);
|
|
30
|
+
expect(result.errors[0]).toContain('Invalid JSON');
|
|
31
|
+
});
|
|
32
|
+
it('rejects oversized displayName', () => {
|
|
33
|
+
const config = JSON.stringify({ displayName: 'x'.repeat(101) });
|
|
34
|
+
const result = validateSkillConfig(config);
|
|
35
|
+
expect(result.valid).toBe(false);
|
|
36
|
+
expect(result.errors.length).toBeGreaterThan(0);
|
|
37
|
+
});
|
|
38
|
+
it('rejects oversized version', () => {
|
|
39
|
+
const config = JSON.stringify({ version: 'v'.repeat(21) });
|
|
40
|
+
const result = validateSkillConfig(config);
|
|
41
|
+
expect(result.valid).toBe(false);
|
|
42
|
+
expect(result.errors.length).toBeGreaterThan(0);
|
|
43
|
+
});
|
|
44
|
+
it('rejects too many mcpServers', () => {
|
|
45
|
+
const servers = Array.from({ length: 11 }, (_, i) => 'server-' + i);
|
|
46
|
+
const config = JSON.stringify({ mcpServers: servers });
|
|
47
|
+
const result = validateSkillConfig(config);
|
|
48
|
+
expect(result.valid).toBe(false);
|
|
49
|
+
expect(result.errors.length).toBeGreaterThan(0);
|
|
50
|
+
});
|
|
51
|
+
it('rejects non-primitive preset values', () => {
|
|
52
|
+
const config = JSON.stringify({ presets: { nested: { a: 1 } } });
|
|
53
|
+
const result = validateSkillConfig(config);
|
|
54
|
+
expect(result.valid).toBe(false);
|
|
55
|
+
});
|
|
56
|
+
it('rejects non-primitive settings values', () => {
|
|
57
|
+
const config = JSON.stringify({ settings: { arr: [1, 2, 3] } });
|
|
58
|
+
const result = validateSkillConfig(config);
|
|
59
|
+
expect(result.valid).toBe(false);
|
|
60
|
+
});
|
|
61
|
+
it('warns about unknown keys (passthrough mode)', () => {
|
|
62
|
+
const config = JSON.stringify({
|
|
63
|
+
displayName: 'Test',
|
|
64
|
+
customField: 'hello',
|
|
65
|
+
anotherUnknown: 42,
|
|
66
|
+
});
|
|
67
|
+
const result = validateSkillConfig(config);
|
|
68
|
+
expect(result.valid).toBe(true);
|
|
69
|
+
expect(result.warnings.length).toBe(1);
|
|
70
|
+
expect(result.warnings[0]).toContain('unknown keys');
|
|
71
|
+
expect(result.warnings[0]).toContain('customField');
|
|
72
|
+
expect(result.warnings[0]).toContain('anotherUnknown');
|
|
73
|
+
});
|
|
74
|
+
it('returns no warnings when only known keys are present', () => {
|
|
75
|
+
const config = JSON.stringify({ displayName: 'Test', version: '1.0' });
|
|
76
|
+
const result = validateSkillConfig(config);
|
|
77
|
+
expect(result.valid).toBe(true);
|
|
78
|
+
expect(result.warnings).toEqual([]);
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
describe('SkillConfigSchema', () => {
|
|
82
|
+
it('accepts primitive preset values (string, number, boolean)', () => {
|
|
83
|
+
const data = { presets: { name: 'foo', count: 42, enabled: true } };
|
|
84
|
+
const result = SkillConfigSchema.safeParse(data);
|
|
85
|
+
expect(result.success).toBe(true);
|
|
86
|
+
});
|
|
87
|
+
it('rejects array preset values', () => {
|
|
88
|
+
const data = { presets: { items: [1, 2, 3] } };
|
|
89
|
+
const result = SkillConfigSchema.safeParse(data);
|
|
90
|
+
expect(result.success).toBe(false);
|
|
91
|
+
});
|
|
92
|
+
it('rejects object preset values', () => {
|
|
93
|
+
const data = { presets: { nested: { key: 'val' } } };
|
|
94
|
+
const result = SkillConfigSchema.safeParse(data);
|
|
95
|
+
expect(result.success).toBe(false);
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
//# sourceMappingURL=skill-config-schema.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-config-schema.test.js","sourceRoot":"","sources":["../../../tests/services/skill-config-schema.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
* SMI-1719: Unit tests for extracted helper functions from Wave 3 refactor
|
|
6
6
|
*/
|
|
7
7
|
import { describe, it, expect } from 'vitest';
|
|
8
|
-
import { validateMemoryKey, MEMORY_KEYS
|
|
8
|
+
import { validateMemoryKey, MEMORY_KEYS } from '../../src/session/SessionManager.helpers.js';
|
|
9
9
|
describe('SessionManager.helpers', () => {
|
|
10
10
|
describe('validateMemoryKey', () => {
|
|
11
11
|
it('accepts valid alphanumeric keys', () => {
|
|
@@ -93,13 +93,5 @@ describe('SessionManager.helpers', () => {
|
|
|
93
93
|
expect(validateMemoryKey(MEMORY_KEYS.CHECKPOINT_PREFIX + '123')).toBe(true);
|
|
94
94
|
});
|
|
95
95
|
});
|
|
96
|
-
describe('MEMORY_NAMESPACE', () => {
|
|
97
|
-
it('exports namespace constant', () => {
|
|
98
|
-
expect(MEMORY_NAMESPACE).toBe('skillsmith-sessions');
|
|
99
|
-
});
|
|
100
|
-
it('namespace passes validation', () => {
|
|
101
|
-
expect(validateMemoryKey(MEMORY_NAMESPACE)).toBe(true);
|
|
102
|
-
});
|
|
103
|
-
});
|
|
104
96
|
});
|
|
105
97
|
//# sourceMappingURL=SessionManager.helpers.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SessionManager.helpers.test.js","sourceRoot":"","sources":["../../../tests/session/SessionManager.helpers.test.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,
|
|
1
|
+
{"version":3,"file":"SessionManager.helpers.test.js","sourceRoot":"","sources":["../../../tests/session/SessionManager.helpers.test.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,6CAA6C,CAAA;AAE5F,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;IACtC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAClD,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAC3C,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC9C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;YACnC,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAClD,MAAM,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACrD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;YACvC,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAClD,MAAM,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACrD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACvD,MAAM,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACtD,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACjD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACzD,MAAM,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC1D,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YAClC,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACnD,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACjD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACnD,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAClD,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC/C,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC5C,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC5C,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC5C,MAAM,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC9C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;YACvC,MAAM,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACpD,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAClD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;YAChC,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACnD,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACpD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,oBAAoB,EAAE,GAAG,EAAE;YAC5B,MAAM,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC3C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;YAC/B,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAChD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;YAChD,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;YAC9B,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC9C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,MAAM,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACpD,MAAM,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACvD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;YAC1D,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC/C,MAAM,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACvD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACpD,MAAM,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC9D,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAClD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE;YAC7B,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;QACrD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;YAChC,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QACrD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;YACnC,MAAM,CAAC,WAAW,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAC3D,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YAClC,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACzD,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,cAAc,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACzE,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,iBAAiB,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC7E,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* SMI-2754: SessionManager Memory Operation Tests
|
|
3
|
+
* SMI-3600: V3 dynamic import tests removed (dead code after claude-flow → ruflo rename)
|
|
4
|
+
* SMI-3601: CLI calls migrated from claude-flow to ruflo
|
|
3
5
|
*
|
|
4
6
|
* Tests for storeMemoryEntry, retrieveMemoryEntry, deleteMemoryEntry,
|
|
5
|
-
* runPreTaskHook, and runPostTaskHook.
|
|
6
|
-
*
|
|
7
|
-
* Since USE_V3_API is evaluated at module load time, we mock the helpers
|
|
8
|
-
* module to control getClaudeFlowMemory / getClaudeFlowMcp / USE_V3_API.
|
|
7
|
+
* runPreTaskHook, and runPostTaskHook — spawn-based CLI path only.
|
|
9
8
|
*/
|
|
10
9
|
export {};
|
|
11
10
|
//# sourceMappingURL=SessionManager.memory.test.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SessionManager.memory.test.d.ts","sourceRoot":"","sources":["../../../tests/session/SessionManager.memory.test.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"SessionManager.memory.test.d.ts","sourceRoot":"","sources":["../../../tests/session/SessionManager.memory.test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG"}
|
|
@@ -1,28 +1,19 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* SMI-2754: SessionManager Memory Operation Tests
|
|
3
|
+
* SMI-3600: V3 dynamic import tests removed (dead code after claude-flow → ruflo rename)
|
|
4
|
+
* SMI-3601: CLI calls migrated from claude-flow to ruflo
|
|
3
5
|
*
|
|
4
6
|
* Tests for storeMemoryEntry, retrieveMemoryEntry, deleteMemoryEntry,
|
|
5
|
-
* runPreTaskHook, and runPostTaskHook.
|
|
6
|
-
*
|
|
7
|
-
* Since USE_V3_API is evaluated at module load time, we mock the helpers
|
|
8
|
-
* module to control getClaudeFlowMemory / getClaudeFlowMcp / USE_V3_API.
|
|
7
|
+
* runPreTaskHook, and runPostTaskHook — spawn-based CLI path only.
|
|
9
8
|
*/
|
|
10
|
-
import { describe, it, expect, vi,
|
|
11
|
-
// ============================================================================
|
|
12
|
-
// We mock the helpers module to control USE_V3_API and module loading
|
|
13
|
-
// ============================================================================
|
|
9
|
+
import { describe, it, expect, vi, afterEach } from 'vitest';
|
|
14
10
|
vi.mock('../../src/session/SessionManager.helpers.js', () => {
|
|
15
11
|
return {
|
|
16
12
|
validateMemoryKey: (key) => /^[a-zA-Z0-9/_-]+$/.test(key) && key.length <= 256,
|
|
17
13
|
MEMORY_KEYS: { CURRENT: 'session/current' },
|
|
18
|
-
MEMORY_NAMESPACE: 'skillsmith-sessions',
|
|
19
|
-
USE_V3_API: false, // Start with spawn path; override per test
|
|
20
|
-
getClaudeFlowMemory: vi.fn(),
|
|
21
|
-
getClaudeFlowMcp: vi.fn(),
|
|
22
14
|
};
|
|
23
15
|
});
|
|
24
16
|
import { storeMemoryEntry, retrieveMemoryEntry, deleteMemoryEntry, runPreTaskHook, runPostTaskHook, } from '../../src/session/SessionManager.memory.js';
|
|
25
|
-
import * as helpers from '../../src/session/SessionManager.helpers.js';
|
|
26
17
|
// ============================================================================
|
|
27
18
|
// Helpers
|
|
28
19
|
// ============================================================================
|
|
@@ -32,16 +23,6 @@ function makeSpawnExecutor(overrides = {}) {
|
|
|
32
23
|
spawn: vi.fn().mockResolvedValue({ stdout: overrides.stdout ?? '', stderr: '' }),
|
|
33
24
|
};
|
|
34
25
|
}
|
|
35
|
-
function enableV3(enabled) {
|
|
36
|
-
// Override the USE_V3_API value in the mocked module
|
|
37
|
-
// @ts-expect-error - overriding readonly for testing
|
|
38
|
-
helpers.USE_V3_API = enabled;
|
|
39
|
-
}
|
|
40
|
-
beforeEach(() => {
|
|
41
|
-
enableV3(false);
|
|
42
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockReset();
|
|
43
|
-
vi.mocked(helpers.getClaudeFlowMcp).mockReset();
|
|
44
|
-
});
|
|
45
26
|
afterEach(() => {
|
|
46
27
|
vi.clearAllMocks();
|
|
47
28
|
});
|
|
@@ -55,36 +36,19 @@ describe('storeMemoryEntry', () => {
|
|
|
55
36
|
expect(result).toEqual({ success: false, error: 'Invalid memory key' });
|
|
56
37
|
expect(executor.spawn).not.toHaveBeenCalled();
|
|
57
38
|
});
|
|
58
|
-
it('uses
|
|
59
|
-
enableV3(true);
|
|
60
|
-
const storeEntry = vi.fn().mockResolvedValue({ success: true });
|
|
61
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockResolvedValue({ storeEntry });
|
|
62
|
-
const executor = makeSpawnExecutor();
|
|
63
|
-
const result = await storeMemoryEntry('session/test', 'my-value', executor);
|
|
64
|
-
expect(result).toEqual({ success: true });
|
|
65
|
-
expect(storeEntry).toHaveBeenCalledWith({
|
|
66
|
-
key: 'session/test',
|
|
67
|
-
value: 'my-value',
|
|
68
|
-
namespace: 'skillsmith-sessions',
|
|
69
|
-
});
|
|
70
|
-
expect(executor.spawn).not.toHaveBeenCalled();
|
|
71
|
-
});
|
|
72
|
-
it('falls back to spawn when V3 storeEntry returns success:false', async () => {
|
|
73
|
-
enableV3(true);
|
|
74
|
-
const storeEntry = vi.fn().mockResolvedValue({ success: false, error: 'V3 error' });
|
|
75
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockResolvedValue({ storeEntry });
|
|
39
|
+
it('uses spawn with ruflo CLI args', async () => {
|
|
76
40
|
const executor = makeSpawnExecutor();
|
|
77
|
-
const result = await storeMemoryEntry('session/
|
|
41
|
+
const result = await storeMemoryEntry('session/key', 'val', executor);
|
|
78
42
|
expect(result).toEqual({ success: true });
|
|
79
|
-
expect(executor.spawn).
|
|
43
|
+
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['ruflo', 'memory', 'store', '--key', 'session/key']));
|
|
80
44
|
});
|
|
81
|
-
it('
|
|
82
|
-
|
|
83
|
-
|
|
45
|
+
it('returns error when spawn fails', async () => {
|
|
46
|
+
const executor = {
|
|
47
|
+
execute: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
48
|
+
spawn: vi.fn().mockRejectedValue(new Error('spawn failed')),
|
|
49
|
+
};
|
|
84
50
|
const result = await storeMemoryEntry('session/key', 'val', executor);
|
|
85
|
-
expect(result).toEqual({ success:
|
|
86
|
-
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['claude-flow', 'memory', 'store', '--key', 'session/key']));
|
|
87
|
-
expect(helpers.getClaudeFlowMemory).not.toHaveBeenCalled();
|
|
51
|
+
expect(result).toEqual({ success: false, error: 'spawn failed' });
|
|
88
52
|
});
|
|
89
53
|
});
|
|
90
54
|
// ============================================================================
|
|
@@ -96,45 +60,19 @@ describe('retrieveMemoryEntry', () => {
|
|
|
96
60
|
const result = await retrieveMemoryEntry('bad key!', executor);
|
|
97
61
|
expect(result).toEqual({ success: false, error: 'Invalid memory key' });
|
|
98
62
|
});
|
|
99
|
-
it('returns data from
|
|
100
|
-
enableV3(true);
|
|
101
|
-
const getEntry = vi.fn().mockResolvedValue({
|
|
102
|
-
success: true,
|
|
103
|
-
found: true,
|
|
104
|
-
entry: { content: 'stored-value' },
|
|
105
|
-
});
|
|
106
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockResolvedValue({ getEntry });
|
|
107
|
-
const executor = makeSpawnExecutor();
|
|
108
|
-
const result = await retrieveMemoryEntry('session/found', executor);
|
|
109
|
-
expect(result).toEqual({ success: true, data: 'stored-value' });
|
|
110
|
-
expect(executor.spawn).not.toHaveBeenCalled();
|
|
111
|
-
});
|
|
112
|
-
it('returns not-found error from V3 when key does not exist', async () => {
|
|
113
|
-
enableV3(true);
|
|
114
|
-
const getEntry = vi.fn().mockResolvedValue({
|
|
115
|
-
success: true,
|
|
116
|
-
found: false,
|
|
117
|
-
});
|
|
118
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockResolvedValue({ getEntry });
|
|
119
|
-
const executor = makeSpawnExecutor();
|
|
120
|
-
const result = await retrieveMemoryEntry('session/missing', executor);
|
|
121
|
-
expect(result).toEqual({ success: false, error: 'Key not found' });
|
|
122
|
-
expect(executor.spawn).not.toHaveBeenCalled();
|
|
123
|
-
});
|
|
124
|
-
it('falls back to spawn when V3 getEntry throws an exception', async () => {
|
|
125
|
-
enableV3(true);
|
|
126
|
-
vi.mocked(helpers.getClaudeFlowMemory).mockRejectedValue(new Error('module load error'));
|
|
127
|
-
const executor = makeSpawnExecutor({ stdout: 'spawned-data' });
|
|
128
|
-
const result = await retrieveMemoryEntry('session/key', executor);
|
|
129
|
-
expect(result).toEqual({ success: true, data: 'spawned-data' });
|
|
130
|
-
expect(executor.spawn).toHaveBeenCalled();
|
|
131
|
-
});
|
|
132
|
-
it('uses spawn directly when USE_V3_API is false', async () => {
|
|
133
|
-
enableV3(false);
|
|
63
|
+
it('returns data from spawn stdout', async () => {
|
|
134
64
|
const executor = makeSpawnExecutor({ stdout: 'value-from-spawn\n' });
|
|
135
65
|
const result = await retrieveMemoryEntry('session/key', executor);
|
|
136
66
|
expect(result).toEqual({ success: true, data: 'value-from-spawn' });
|
|
137
|
-
expect(
|
|
67
|
+
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['ruflo', 'memory', 'get', '--key', 'session/key']));
|
|
68
|
+
});
|
|
69
|
+
it('returns error when spawn fails', async () => {
|
|
70
|
+
const executor = {
|
|
71
|
+
execute: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
72
|
+
spawn: vi.fn().mockRejectedValue(new Error('get failed')),
|
|
73
|
+
};
|
|
74
|
+
const result = await retrieveMemoryEntry('session/key', executor);
|
|
75
|
+
expect(result).toEqual({ success: false, error: 'get failed' });
|
|
138
76
|
});
|
|
139
77
|
});
|
|
140
78
|
// ============================================================================
|
|
@@ -146,48 +84,31 @@ describe('deleteMemoryEntry', () => {
|
|
|
146
84
|
const result = await deleteMemoryEntry('bad key!', executor);
|
|
147
85
|
expect(result).toEqual({ success: false, error: 'Invalid memory key' });
|
|
148
86
|
});
|
|
149
|
-
it('
|
|
150
|
-
enableV3(true);
|
|
151
|
-
const callMCPTool = vi.fn().mockResolvedValue({ success: true, deleted: true });
|
|
152
|
-
vi.mocked(helpers.getClaudeFlowMcp).mockResolvedValue({ callMCPTool });
|
|
87
|
+
it('uses spawn with ruflo CLI args', async () => {
|
|
153
88
|
const executor = makeSpawnExecutor();
|
|
154
89
|
const result = await deleteMemoryEntry('session/to-delete', executor);
|
|
155
90
|
expect(result).toEqual({ success: true });
|
|
156
|
-
expect(
|
|
91
|
+
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['ruflo', 'memory', 'delete', '--key', 'session/to-delete']));
|
|
157
92
|
});
|
|
158
|
-
it('
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
93
|
+
it('returns success even when spawn throws (delete is best-effort)', async () => {
|
|
94
|
+
const executor = {
|
|
95
|
+
execute: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
96
|
+
spawn: vi.fn().mockRejectedValue(new Error('delete error')),
|
|
97
|
+
};
|
|
163
98
|
const result = await deleteMemoryEntry('session/key', executor);
|
|
164
99
|
expect(result).toEqual({ success: true });
|
|
165
|
-
expect(executor.spawn).toHaveBeenCalled();
|
|
166
100
|
});
|
|
167
101
|
});
|
|
168
102
|
// ============================================================================
|
|
169
103
|
// runPreTaskHook
|
|
170
104
|
// ============================================================================
|
|
171
105
|
describe('runPreTaskHook', () => {
|
|
172
|
-
it('
|
|
173
|
-
enableV3(true);
|
|
174
|
-
const callMCPTool = vi.fn().mockResolvedValue({});
|
|
175
|
-
vi.mocked(helpers.getClaudeFlowMcp).mockResolvedValue({ callMCPTool });
|
|
176
|
-
const executor = makeSpawnExecutor();
|
|
177
|
-
await runPreTaskHook('test description', executor);
|
|
178
|
-
expect(callMCPTool).toHaveBeenCalledWith('hooks/pre-task', expect.objectContaining({
|
|
179
|
-
description: 'test description',
|
|
180
|
-
}));
|
|
181
|
-
expect(executor.spawn).not.toHaveBeenCalled();
|
|
182
|
-
});
|
|
183
|
-
it('uses spawn when USE_V3_API is false', async () => {
|
|
184
|
-
enableV3(false);
|
|
106
|
+
it('uses spawn with ruflo hooks pre-task args', async () => {
|
|
185
107
|
const executor = makeSpawnExecutor();
|
|
186
108
|
await runPreTaskHook('test description', executor);
|
|
187
|
-
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['pre-task', '--description', 'test description']));
|
|
109
|
+
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['ruflo', 'hooks', 'pre-task', '--description', 'test description']));
|
|
188
110
|
});
|
|
189
111
|
it('swallows errors and does not throw', async () => {
|
|
190
|
-
enableV3(false);
|
|
191
112
|
const executor = {
|
|
192
113
|
execute: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
193
114
|
spawn: vi.fn().mockRejectedValue(new Error('hook failed')),
|
|
@@ -200,20 +121,17 @@ describe('runPreTaskHook', () => {
|
|
|
200
121
|
// runPostTaskHook
|
|
201
122
|
// ============================================================================
|
|
202
123
|
describe('runPostTaskHook', () => {
|
|
203
|
-
it('
|
|
204
|
-
enableV3(true);
|
|
205
|
-
const callMCPTool = vi.fn().mockResolvedValue({});
|
|
206
|
-
vi.mocked(helpers.getClaudeFlowMcp).mockResolvedValue({ callMCPTool });
|
|
207
|
-
const executor = makeSpawnExecutor();
|
|
208
|
-
await runPostTaskHook('task-123', executor);
|
|
209
|
-
expect(callMCPTool).toHaveBeenCalledWith('hooks/post-task', { taskId: 'task-123' });
|
|
210
|
-
expect(executor.spawn).not.toHaveBeenCalled();
|
|
211
|
-
});
|
|
212
|
-
it('uses spawn when USE_V3_API is false', async () => {
|
|
213
|
-
enableV3(false);
|
|
124
|
+
it('uses spawn with ruflo hooks post-task args', async () => {
|
|
214
125
|
const executor = makeSpawnExecutor();
|
|
215
126
|
await runPostTaskHook('task-456', executor);
|
|
216
|
-
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['post-task', '--task-id', 'task-456']));
|
|
127
|
+
expect(executor.spawn).toHaveBeenCalledWith('npx', expect.arrayContaining(['ruflo', 'hooks', 'post-task', '--task-id', 'task-456']));
|
|
128
|
+
});
|
|
129
|
+
it('swallows errors and does not throw', async () => {
|
|
130
|
+
const executor = {
|
|
131
|
+
execute: vi.fn().mockResolvedValue({ stdout: '', stderr: '' }),
|
|
132
|
+
spawn: vi.fn().mockRejectedValue(new Error('hook failed')),
|
|
133
|
+
};
|
|
134
|
+
await expect(runPostTaskHook('task-789', executor)).resolves.toBeUndefined();
|
|
217
135
|
});
|
|
218
136
|
});
|
|
219
137
|
//# sourceMappingURL=SessionManager.memory.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SessionManager.memory.test.js","sourceRoot":"","sources":["../../../tests/session/SessionManager.memory.test.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"SessionManager.memory.test.js","sourceRoot":"","sources":["../../../tests/session/SessionManager.memory.test.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AAE5D,EAAE,CAAC,IAAI,CAAC,6CAA6C,EAAE,GAAG,EAAE;IAC1D,OAAO;QACL,iBAAiB,EAAE,CAAC,GAAW,EAAE,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG;QACtF,WAAW,EAAE,EAAE,OAAO,EAAE,iBAAiB,EAAE;KAC5C,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,cAAc,EACd,eAAe,GAChB,MAAM,4CAA4C,CAAA;AAGnD,+EAA+E;AAC/E,UAAU;AACV,+EAA+E;AAE/E,SAAS,iBAAiB,CAAC,YAAyC,EAAE;IACpE,OAAO;QACL,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;QAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,MAAM,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;KACjF,CAAA;AACH,CAAC;AAED,SAAS,CAAC,GAAG,EAAE;IACb,EAAE,CAAC,aAAa,EAAE,CAAA;AACpB,CAAC,CAAC,CAAA;AAEF,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,UAAU,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAA;QACpE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC,CAAA;QACvE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;IAC/C,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAA;QAErE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QACzC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,oBAAoB,CACzC,KAAK,EACL,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAC7E,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAoB;YAChC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;SAC5D,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,aAAa,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAA;QACrE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAA;IACnE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,MAAM,mBAAmB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC9D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAG,iBAAiB,CAAC,EAAE,MAAM,EAAE,oBAAoB,EAAE,CAAC,CAAA;QACpE,MAAM,MAAM,GAAG,MAAM,mBAAmB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QAEjE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,kBAAkB,EAAE,CAAC,CAAA;QACnE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,oBAAoB,CACzC,KAAK,EACL,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAC3E,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAoB;YAChC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;SAC1D,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,mBAAmB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QACjE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAA;IACjE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAC5D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAA;QAErE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QACzC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,oBAAoB,CACzC,KAAK,EACL,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,mBAAmB,CAAC,CAAC,CACpF,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,gEAAgE,EAAE,KAAK,IAAI,EAAE;QAC9E,MAAM,QAAQ,GAAoB;YAChC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;SAC5D,CAAA;QACD,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QAC/D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;IAC3C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,cAAc,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;QAElD,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,oBAAoB,CACzC,KAAK,EACL,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,kBAAkB,CAAC,CAAC,CAC5F,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,QAAQ,GAAoB;YAChC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,aAAa,CAAC,CAAC;SAC3D,CAAA;QACD,mBAAmB;QACnB,MAAM,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAA;IACzE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,+EAA+E;AAC/E,kBAAkB;AAClB,+EAA+E;AAE/E,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,QAAQ,GAAG,iBAAiB,EAAE,CAAA;QACpC,MAAM,eAAe,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAE3C,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,oBAAoB,CACzC,KAAK,EACL,MAAM,CAAC,eAAe,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC,CACjF,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,QAAQ,GAAoB;YAChC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC9D,KAAK,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,aAAa,CAAC,CAAC;SAC3D,CAAA;QACD,MAAM,MAAM,CAAC,eAAe,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAA;IAC9E,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SMI-3416: BackgroundSyncService Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests for session-based automatic sync service:
|
|
5
|
+
* - Start/stop lifecycle
|
|
6
|
+
* - Sync-on-start behavior
|
|
7
|
+
* - Periodic check and sync triggering
|
|
8
|
+
* - Concurrent sync prevention
|
|
9
|
+
* - Manual sync
|
|
10
|
+
* - Error handling and callbacks
|
|
11
|
+
*/
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=BackgroundSyncService.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BackgroundSyncService.test.d.ts","sourceRoot":"","sources":["../../../tests/sync/BackgroundSyncService.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG"}
|