@timmeck/brain-core 2.36.57 → 2.36.59
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/README.md +6 -0
- package/command-center.html +133 -2
- package/dist/action/__tests__/adjust-parameter-handler.test.d.ts +1 -0
- package/dist/action/__tests__/adjust-parameter-handler.test.js +138 -0
- package/dist/action/__tests__/adjust-parameter-handler.test.js.map +1 -0
- package/dist/action/__tests__/content-handler.test.d.ts +1 -0
- package/dist/action/__tests__/content-handler.test.js +100 -0
- package/dist/action/__tests__/content-handler.test.js.map +1 -0
- package/dist/action/__tests__/creative-seed-handler.test.d.ts +1 -0
- package/dist/action/__tests__/creative-seed-handler.test.js +96 -0
- package/dist/action/__tests__/creative-seed-handler.test.js.map +1 -0
- package/dist/action/__tests__/trade-handler.test.d.ts +1 -0
- package/dist/action/__tests__/trade-handler.test.js +165 -0
- package/dist/action/__tests__/trade-handler.test.js.map +1 -0
- package/dist/action/action-bridge.d.ts +2 -2
- package/dist/action/action-bridge.js +1 -0
- package/dist/action/action-bridge.js.map +1 -1
- package/dist/action/handlers/adjust-parameter-handler.d.ts +28 -0
- package/dist/action/handlers/adjust-parameter-handler.js +44 -0
- package/dist/action/handlers/adjust-parameter-handler.js.map +1 -0
- package/dist/action/handlers/content-handler.d.ts +23 -0
- package/dist/action/handlers/content-handler.js +30 -0
- package/dist/action/handlers/content-handler.js.map +1 -0
- package/dist/action/handlers/creative-seed-handler.d.ts +24 -0
- package/dist/action/handlers/creative-seed-handler.js +34 -0
- package/dist/action/handlers/creative-seed-handler.js.map +1 -0
- package/dist/action/handlers/index.d.ts +8 -0
- package/dist/action/handlers/index.js +5 -0
- package/dist/action/handlers/index.js.map +1 -0
- package/dist/action/handlers/trade-handler.d.ts +43 -0
- package/dist/action/handlers/trade-handler.js +43 -0
- package/dist/action/handlers/trade-handler.js.map +1 -0
- package/dist/action/index.d.ts +2 -0
- package/dist/action/index.js +1 -0
- package/dist/action/index.js.map +1 -1
- package/dist/agent-training/__tests__/agent-trainer.test.d.ts +1 -0
- package/dist/agent-training/__tests__/agent-trainer.test.js +158 -0
- package/dist/agent-training/__tests__/agent-trainer.test.js.map +1 -0
- package/dist/agent-training/__tests__/sub-agent-factory.test.d.ts +1 -0
- package/dist/agent-training/__tests__/sub-agent-factory.test.js +100 -0
- package/dist/agent-training/__tests__/sub-agent-factory.test.js.map +1 -0
- package/dist/agent-training/__tests__/sub-agent.test.d.ts +1 -0
- package/dist/agent-training/__tests__/sub-agent.test.js +102 -0
- package/dist/agent-training/__tests__/sub-agent.test.js.map +1 -0
- package/dist/agent-training/index.d.ts +4 -0
- package/dist/agent-training/index.js +2 -0
- package/dist/agent-training/index.js.map +1 -1
- package/dist/agent-training/sub-agent-factory.d.ts +36 -0
- package/dist/agent-training/sub-agent-factory.js +128 -0
- package/dist/agent-training/sub-agent-factory.js.map +1 -0
- package/dist/agent-training/sub-agent.d.ts +57 -0
- package/dist/agent-training/sub-agent.js +135 -0
- package/dist/agent-training/sub-agent.js.map +1 -0
- package/dist/chat/__tests__/chat-engine.test.d.ts +1 -0
- package/dist/chat/__tests__/chat-engine.test.js +209 -0
- package/dist/chat/__tests__/chat-engine.test.js.map +1 -0
- package/dist/chat/chat-engine.d.ts +55 -0
- package/dist/chat/chat-engine.js +222 -0
- package/dist/chat/chat-engine.js.map +1 -0
- package/dist/chat/index.d.ts +2 -0
- package/dist/chat/index.js +2 -0
- package/dist/chat/index.js.map +1 -0
- package/dist/codegen/codegen-server.js +2 -2
- package/dist/codegen/codegen-server.js.map +1 -1
- package/dist/content/__tests__/auto-publisher.test.d.ts +1 -0
- package/dist/content/__tests__/auto-publisher.test.js +125 -0
- package/dist/content/__tests__/auto-publisher.test.js.map +1 -0
- package/dist/content/auto-publisher.d.ts +51 -0
- package/dist/content/auto-publisher.js +147 -0
- package/dist/content/auto-publisher.js.map +1 -0
- package/dist/content/content-forge.d.ts +2 -0
- package/dist/content/content-forge.js +19 -0
- package/dist/content/content-forge.js.map +1 -1
- package/dist/content/index.d.ts +2 -0
- package/dist/content/index.js +1 -0
- package/dist/content/index.js.map +1 -1
- package/dist/creative/__tests__/creative-engine.test.d.ts +1 -0
- package/dist/creative/__tests__/creative-engine.test.js +151 -0
- package/dist/creative/__tests__/creative-engine.test.js.map +1 -0
- package/dist/cross-brain/__tests__/signal-router.test.d.ts +1 -0
- package/dist/cross-brain/__tests__/signal-router.test.js +218 -0
- package/dist/cross-brain/__tests__/signal-router.test.js.map +1 -0
- package/dist/cross-brain/signal-router.d.ts +57 -0
- package/dist/cross-brain/signal-router.js +148 -0
- package/dist/cross-brain/signal-router.js.map +1 -0
- package/dist/dashboard/__tests__/command-center-server.test.js +31 -0
- package/dist/dashboard/__tests__/command-center-server.test.js.map +1 -1
- package/dist/dashboard/command-center-server.d.ts +11 -0
- package/dist/dashboard/command-center-server.js +72 -0
- package/dist/dashboard/command-center-server.js.map +1 -1
- package/dist/dream/__tests__/dream-engine.test.d.ts +1 -0
- package/dist/dream/__tests__/dream-engine.test.js +184 -0
- package/dist/dream/__tests__/dream-engine.test.js.map +1 -0
- package/dist/feedback/__tests__/feedback-router.test.d.ts +1 -0
- package/dist/feedback/__tests__/feedback-router.test.js +173 -0
- package/dist/feedback/__tests__/feedback-router.test.js.map +1 -0
- package/dist/feedback/feedback-router.d.ts +53 -0
- package/dist/feedback/feedback-router.js +193 -0
- package/dist/feedback/feedback-router.js.map +1 -0
- package/dist/feedback/index.d.ts +2 -0
- package/dist/feedback/index.js +1 -0
- package/dist/feedback/index.js.map +1 -1
- package/dist/goals/__tests__/goal-engine.test.d.ts +1 -0
- package/dist/goals/__tests__/goal-engine.test.js +203 -0
- package/dist/goals/__tests__/goal-engine.test.js.map +1 -0
- package/dist/guardrails/__tests__/guardrail-engine.test.d.ts +1 -0
- package/dist/guardrails/__tests__/guardrail-engine.test.js +343 -0
- package/dist/guardrails/__tests__/guardrail-engine.test.js.map +1 -0
- package/dist/index.d.ts +14 -6
- package/dist/index.js +8 -3
- package/dist/index.js.map +1 -1
- package/dist/metacognition/__tests__/auto-experiment-engine.test.d.ts +1 -0
- package/dist/metacognition/__tests__/auto-experiment-engine.test.js +218 -0
- package/dist/metacognition/__tests__/auto-experiment-engine.test.js.map +1 -0
- package/dist/metacognition/__tests__/evolution-engine.test.d.ts +1 -0
- package/dist/metacognition/__tests__/evolution-engine.test.js +473 -0
- package/dist/metacognition/__tests__/evolution-engine.test.js.map +1 -0
- package/dist/metacognition/__tests__/parameter-registry.test.d.ts +1 -0
- package/dist/metacognition/__tests__/parameter-registry.test.js +223 -0
- package/dist/metacognition/__tests__/parameter-registry.test.js.map +1 -0
- package/dist/prediction/__tests__/prediction-engine.test.d.ts +1 -0
- package/dist/prediction/__tests__/prediction-engine.test.js +244 -0
- package/dist/prediction/__tests__/prediction-engine.test.js.map +1 -0
- package/dist/research/research-orchestrator.js +3 -2
- package/dist/research/research-orchestrator.js.map +1 -1
- package/dist/sandbox/__tests__/code-sandbox.test.d.ts +1 -0
- package/dist/sandbox/__tests__/code-sandbox.test.js +182 -0
- package/dist/sandbox/__tests__/code-sandbox.test.js.map +1 -0
- package/dist/scanner/__tests__/signal-scanner.test.d.ts +1 -0
- package/dist/scanner/__tests__/signal-scanner.test.js +142 -0
- package/dist/scanner/__tests__/signal-scanner.test.js.map +1 -0
- package/dist/self-modification/__tests__/self-modification-engine.test.d.ts +1 -0
- package/dist/self-modification/__tests__/self-modification-engine.test.js +313 -0
- package/dist/self-modification/__tests__/self-modification-engine.test.js.map +1 -0
- package/dist/self-modification/self-modification-engine.d.ts +4 -1
- package/dist/self-modification/self-modification-engine.js +41 -3
- package/dist/self-modification/self-modification-engine.js.map +1 -1
- package/dist/strategy/__tests__/strategy-forge.test.js +69 -0
- package/dist/strategy/__tests__/strategy-forge.test.js.map +1 -1
- package/dist/strategy/__tests__/strategy-mutator.test.d.ts +1 -0
- package/dist/strategy/__tests__/strategy-mutator.test.js +141 -0
- package/dist/strategy/__tests__/strategy-mutator.test.js.map +1 -0
- package/dist/strategy/index.d.ts +2 -0
- package/dist/strategy/index.js +1 -0
- package/dist/strategy/index.js.map +1 -1
- package/dist/strategy/strategy-forge.d.ts +4 -1
- package/dist/strategy/strategy-forge.js +34 -2
- package/dist/strategy/strategy-forge.js.map +1 -1
- package/dist/strategy/strategy-mutator.d.ts +42 -0
- package/dist/strategy/strategy-mutator.js +140 -0
- package/dist/strategy/strategy-mutator.js.map +1 -0
- package/dist/unified/unified-server.js +2 -2
- package/dist/unified/unified-server.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
|
+
import Database from 'better-sqlite3';
|
|
3
|
+
vi.mock('../../utils/logger.js', () => ({
|
|
4
|
+
getLogger: () => ({ info: vi.fn(), warn: vi.fn(), error: vi.fn(), debug: vi.fn() }),
|
|
5
|
+
}));
|
|
6
|
+
import { AutoExperimentEngine } from '../auto-experiment-engine.js';
|
|
7
|
+
import { ParameterRegistry, runParameterRegistryMigration } from '../parameter-registry.js';
|
|
8
|
+
import { ExperimentEngine, runExperimentMigration } from '../../research/experiment-engine.js';
|
|
9
|
+
describe('AutoExperimentEngine', () => {
|
|
10
|
+
let db;
|
|
11
|
+
let registry;
|
|
12
|
+
let experimentEngine;
|
|
13
|
+
let autoEngine;
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
db = new Database(':memory:');
|
|
16
|
+
runParameterRegistryMigration(db);
|
|
17
|
+
runExperimentMigration(db);
|
|
18
|
+
registry = new ParameterRegistry(db);
|
|
19
|
+
experimentEngine = new ExperimentEngine(db, { brainName: 'test' });
|
|
20
|
+
// Register a parameter for tests
|
|
21
|
+
registry.register({
|
|
22
|
+
engine: 'TestEngine',
|
|
23
|
+
name: 'learningRate',
|
|
24
|
+
value: 0.5,
|
|
25
|
+
min: 0.0,
|
|
26
|
+
max: 1.0,
|
|
27
|
+
description: 'How fast the engine learns',
|
|
28
|
+
});
|
|
29
|
+
autoEngine = new AutoExperimentEngine(db, registry, experimentEngine);
|
|
30
|
+
});
|
|
31
|
+
afterEach(() => {
|
|
32
|
+
db.close();
|
|
33
|
+
});
|
|
34
|
+
// ── 1. Construction ──────────────────────────────────────
|
|
35
|
+
it('should create instance and run migration', () => {
|
|
36
|
+
expect(autoEngine).toBeDefined();
|
|
37
|
+
// Verify the table exists by querying it
|
|
38
|
+
const row = db.prepare('SELECT COUNT(*) as c FROM auto_experiments').get();
|
|
39
|
+
expect(row.c).toBe(0);
|
|
40
|
+
});
|
|
41
|
+
// ── 2. getStatus (initial) ───────────────────────────────
|
|
42
|
+
it('should return zero counts in initial status', () => {
|
|
43
|
+
const status = autoEngine.getStatus(0);
|
|
44
|
+
expect(status.totalExperiments).toBe(0);
|
|
45
|
+
expect(status.running).toBe(0);
|
|
46
|
+
expect(status.adopted).toBe(0);
|
|
47
|
+
expect(status.rolledBack).toBe(0);
|
|
48
|
+
expect(status.cooldownUntilCycle).toBe(0);
|
|
49
|
+
});
|
|
50
|
+
// ── 3. discoverCandidates (stale parameter) ──────────────
|
|
51
|
+
it('should discover stale-parameter candidates when parameter was never changed', () => {
|
|
52
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
53
|
+
// "learningRate" has never been changed, so it should appear as a candidate
|
|
54
|
+
expect(candidates.length).toBeGreaterThanOrEqual(1);
|
|
55
|
+
const lr = candidates.find(c => c.name === 'learningRate');
|
|
56
|
+
expect(lr).toBeDefined();
|
|
57
|
+
expect(lr.engine).toBe('TestEngine');
|
|
58
|
+
expect(lr.reason).toContain('never changed');
|
|
59
|
+
expect(lr.priority).toBe(4);
|
|
60
|
+
expect(lr.proposedValue).not.toBe(lr.currentValue);
|
|
61
|
+
// Proposed value must stay within bounds
|
|
62
|
+
expect(lr.proposedValue).toBeGreaterThanOrEqual(0.0);
|
|
63
|
+
expect(lr.proposedValue).toBeLessThanOrEqual(1.0);
|
|
64
|
+
});
|
|
65
|
+
// ── 4. discoverCandidates respects cooldown ──────────────
|
|
66
|
+
it('should return empty candidates when in cooldown period', () => {
|
|
67
|
+
// Trigger a cooldown by manipulating the internal state via a full experiment lifecycle:
|
|
68
|
+
// Simply test discoverCandidates with a cycle < cooldownUntilCycle
|
|
69
|
+
// Start and complete an experiment to trigger cooldown
|
|
70
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
71
|
+
expect(candidates.length).toBeGreaterThanOrEqual(1);
|
|
72
|
+
// Start an experiment to get something running
|
|
73
|
+
const exp = autoEngine.startExperiment(candidates[0]);
|
|
74
|
+
expect(exp).not.toBeNull();
|
|
75
|
+
// Now manually complete the linked experiment with a positive conclusion
|
|
76
|
+
// so processCompleted sets cooldown
|
|
77
|
+
if (exp.experiment_id) {
|
|
78
|
+
// Feed enough measurements through control and treatment phases
|
|
79
|
+
const linkedExp = experimentEngine.get(exp.experiment_id);
|
|
80
|
+
if (linkedExp) {
|
|
81
|
+
const duration = linkedExp.duration_cycles;
|
|
82
|
+
// Control phase
|
|
83
|
+
for (let i = 0; i < duration; i++) {
|
|
84
|
+
experimentEngine.recordMeasurement(exp.experiment_id, 1.0);
|
|
85
|
+
}
|
|
86
|
+
// Treatment phase
|
|
87
|
+
for (let i = 0; i < duration; i++) {
|
|
88
|
+
experimentEngine.recordMeasurement(exp.experiment_id, 5.0);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
const results = autoEngine.processCompleted(10);
|
|
93
|
+
// After processing, cooldown is set
|
|
94
|
+
if (results.length > 0) {
|
|
95
|
+
// Now discover should return empty because we are in cooldown
|
|
96
|
+
const afterCooldown = autoEngine.discoverCandidates(11);
|
|
97
|
+
expect(afterCooldown).toEqual([]);
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
// ── 5. startExperiment creates a running auto-experiment ─
|
|
101
|
+
it('should start an experiment from a candidate', () => {
|
|
102
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
103
|
+
expect(candidates.length).toBeGreaterThanOrEqual(1);
|
|
104
|
+
const exp = autoEngine.startExperiment(candidates[0]);
|
|
105
|
+
expect(exp).not.toBeNull();
|
|
106
|
+
expect(exp.status).toBe('running');
|
|
107
|
+
expect(exp.parameter_engine).toBe(candidates[0].engine);
|
|
108
|
+
expect(exp.parameter_name).toBe(candidates[0].name);
|
|
109
|
+
expect(exp.old_value).toBe(candidates[0].currentValue);
|
|
110
|
+
expect(exp.new_value).toBe(candidates[0].proposedValue);
|
|
111
|
+
expect(exp.hypothesis).toBe(candidates[0].hypothesis);
|
|
112
|
+
expect(exp.id).toBeGreaterThan(0);
|
|
113
|
+
expect(exp.result_summary).toBeNull();
|
|
114
|
+
});
|
|
115
|
+
// ── 6. startExperiment respects maxConcurrent limit ──────
|
|
116
|
+
it('should return null when maxConcurrent reached', () => {
|
|
117
|
+
// Register a second parameter so we have two candidates
|
|
118
|
+
registry.register({
|
|
119
|
+
engine: 'TestEngine',
|
|
120
|
+
name: 'decayRate',
|
|
121
|
+
value: 0.3,
|
|
122
|
+
min: 0.0,
|
|
123
|
+
max: 1.0,
|
|
124
|
+
description: 'Decay rate for memory',
|
|
125
|
+
});
|
|
126
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
127
|
+
expect(candidates.length).toBeGreaterThanOrEqual(2);
|
|
128
|
+
// Start first — should succeed (maxConcurrent defaults to 1)
|
|
129
|
+
const first = autoEngine.startExperiment(candidates[0]);
|
|
130
|
+
expect(first).not.toBeNull();
|
|
131
|
+
// Start second — should be blocked
|
|
132
|
+
const second = autoEngine.startExperiment(candidates[1]);
|
|
133
|
+
expect(second).toBeNull();
|
|
134
|
+
});
|
|
135
|
+
// ── 7. startExperiment changes the parameter value ───────
|
|
136
|
+
it('should actually change the parameter value in the registry', () => {
|
|
137
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
138
|
+
const candidate = candidates[0];
|
|
139
|
+
const oldValue = registry.get(candidate.engine, candidate.name);
|
|
140
|
+
autoEngine.startExperiment(candidate);
|
|
141
|
+
const newValue = registry.get(candidate.engine, candidate.name);
|
|
142
|
+
expect(newValue).toBe(candidate.proposedValue);
|
|
143
|
+
expect(newValue).not.toBe(oldValue);
|
|
144
|
+
});
|
|
145
|
+
// ── 8. feedMeasurement routes to ExperimentEngine ────────
|
|
146
|
+
it('should feed measurements to linked running experiments', () => {
|
|
147
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
148
|
+
const exp = autoEngine.startExperiment(candidates[0]);
|
|
149
|
+
expect(exp).not.toBeNull();
|
|
150
|
+
expect(exp.experiment_id).not.toBeNull();
|
|
151
|
+
// Feed a measurement — should not throw
|
|
152
|
+
autoEngine.feedMeasurement('perf_score', 0.75);
|
|
153
|
+
// Verify it landed in the linked experiment
|
|
154
|
+
const linked = experimentEngine.get(exp.experiment_id);
|
|
155
|
+
expect(linked).not.toBeNull();
|
|
156
|
+
// The linked experiment should be in running_control and have received a measurement
|
|
157
|
+
expect(linked.control_results.length).toBe(1);
|
|
158
|
+
expect(linked.control_results[0]).toBe(0.75);
|
|
159
|
+
});
|
|
160
|
+
// ── 9. list returns empty initially ──────────────────────
|
|
161
|
+
it('should return empty list when no experiments exist', () => {
|
|
162
|
+
const all = autoEngine.list();
|
|
163
|
+
expect(all).toEqual([]);
|
|
164
|
+
});
|
|
165
|
+
// ── 10. list returns experiments after starting one ──────
|
|
166
|
+
it('should return experiments after creating one', () => {
|
|
167
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
168
|
+
autoEngine.startExperiment(candidates[0]);
|
|
169
|
+
const all = autoEngine.list();
|
|
170
|
+
expect(all.length).toBe(1);
|
|
171
|
+
expect(all[0].status).toBe('running');
|
|
172
|
+
// Filter by status
|
|
173
|
+
const running = autoEngine.list('running');
|
|
174
|
+
expect(running.length).toBe(1);
|
|
175
|
+
const adopted = autoEngine.list('adopted');
|
|
176
|
+
expect(adopted.length).toBe(0);
|
|
177
|
+
});
|
|
178
|
+
// ── 11. processCompleted with no running experiments ─────
|
|
179
|
+
it('should return empty array when no experiments are running', () => {
|
|
180
|
+
const results = autoEngine.processCompleted(0);
|
|
181
|
+
expect(results).toEqual([]);
|
|
182
|
+
});
|
|
183
|
+
// ── 12. processCompleted adopts positive results ─────────
|
|
184
|
+
it('should adopt experiment with significant positive result', () => {
|
|
185
|
+
const candidates = autoEngine.discoverCandidates(0);
|
|
186
|
+
const exp = autoEngine.startExperiment(candidates[0]);
|
|
187
|
+
expect(exp).not.toBeNull();
|
|
188
|
+
expect(exp.experiment_id).not.toBeNull();
|
|
189
|
+
const expId = exp.experiment_id;
|
|
190
|
+
const linked = experimentEngine.get(expId);
|
|
191
|
+
const duration = linked.duration_cycles;
|
|
192
|
+
// Control phase: low values
|
|
193
|
+
for (let i = 0; i < duration; i++) {
|
|
194
|
+
experimentEngine.recordMeasurement(expId, 1.0 + Math.random() * 0.1);
|
|
195
|
+
}
|
|
196
|
+
// Treatment phase: significantly higher values
|
|
197
|
+
for (let i = 0; i < duration; i++) {
|
|
198
|
+
experimentEngine.recordMeasurement(expId, 5.0 + Math.random() * 0.1);
|
|
199
|
+
}
|
|
200
|
+
// Now the linked experiment should be complete
|
|
201
|
+
const completed = experimentEngine.get(expId);
|
|
202
|
+
expect(completed.status).toBe('complete');
|
|
203
|
+
expect(completed.conclusion).not.toBeNull();
|
|
204
|
+
expect(completed.conclusion.direction).toBe('positive');
|
|
205
|
+
// processCompleted should adopt it
|
|
206
|
+
const results = autoEngine.processCompleted(10);
|
|
207
|
+
expect(results.length).toBe(1);
|
|
208
|
+
expect(results[0].action).toBe('adopted');
|
|
209
|
+
// Verify the auto_experiment status in DB
|
|
210
|
+
const autoExps = autoEngine.list('adopted');
|
|
211
|
+
expect(autoExps.length).toBe(1);
|
|
212
|
+
expect(autoExps[0].result_summary).toContain('Positive');
|
|
213
|
+
// Verify cooldown is set (discover at cycle 11 should return empty)
|
|
214
|
+
const afterCandidates = autoEngine.discoverCandidates(11);
|
|
215
|
+
expect(afterCandidates).toEqual([]);
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
//# sourceMappingURL=auto-experiment-engine.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auto-experiment-engine.test.js","sourceRoot":"","sources":["../../../src/metacognition/__tests__/auto-experiment-engine.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|