groundswell 0.0.3 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +26 -9
- package/dist/cache/cache-key.d.ts +20 -0
- package/dist/cache/cache-key.d.ts.map +1 -1
- package/dist/cache/cache-key.js +9 -0
- package/dist/cache/cache-key.js.map +1 -1
- package/dist/core/agent.d.ts +120 -29
- package/dist/core/agent.d.ts.map +1 -1
- package/dist/core/agent.js +584 -177
- package/dist/core/agent.js.map +1 -1
- package/dist/core/mcp-handler.d.ts +63 -5
- package/dist/core/mcp-handler.d.ts.map +1 -1
- package/dist/core/mcp-handler.js +184 -4
- package/dist/core/mcp-handler.js.map +1 -1
- package/dist/core/workflow-context.d.ts +6 -2
- package/dist/core/workflow-context.d.ts.map +1 -1
- package/dist/core/workflow-context.js +99 -4
- package/dist/core/workflow-context.js.map +1 -1
- package/dist/core/workflow.d.ts +315 -13
- package/dist/core/workflow.d.ts.map +1 -1
- package/dist/core/workflow.js +552 -30
- package/dist/core/workflow.js.map +1 -1
- package/dist/debugger/event-replayer.d.ts +422 -0
- package/dist/debugger/event-replayer.d.ts.map +1 -0
- package/dist/debugger/event-replayer.js +639 -0
- package/dist/debugger/event-replayer.js.map +1 -0
- package/dist/debugger/tree-debugger.d.ts +170 -1
- package/dist/debugger/tree-debugger.d.ts.map +1 -1
- package/dist/debugger/tree-debugger.js +423 -1
- package/dist/debugger/tree-debugger.js.map +1 -1
- package/dist/decorators/step.d.ts.map +1 -1
- package/dist/decorators/step.js +129 -47
- package/dist/decorators/step.js.map +1 -1
- package/dist/harnesses/claude-code-harness.d.ts +391 -0
- package/dist/harnesses/claude-code-harness.d.ts.map +1 -0
- package/dist/harnesses/claude-code-harness.js +1076 -0
- package/dist/harnesses/claude-code-harness.js.map +1 -0
- package/dist/harnesses/harness-registry.d.ts +440 -0
- package/dist/harnesses/harness-registry.d.ts.map +1 -0
- package/dist/harnesses/harness-registry.js +543 -0
- package/dist/harnesses/harness-registry.js.map +1 -0
- package/dist/harnesses/index.d.ts +12 -0
- package/dist/harnesses/index.d.ts.map +1 -0
- package/dist/harnesses/index.js +11 -0
- package/dist/harnesses/index.js.map +1 -0
- package/dist/harnesses/pi-harness.d.ts +219 -0
- package/dist/harnesses/pi-harness.d.ts.map +1 -0
- package/dist/harnesses/pi-harness.js +676 -0
- package/dist/harnesses/pi-harness.js.map +1 -0
- package/dist/harnesses/pi-schema-converter.d.ts +24 -0
- package/dist/harnesses/pi-schema-converter.d.ts.map +1 -0
- package/dist/harnesses/pi-schema-converter.js +81 -0
- package/dist/harnesses/pi-schema-converter.js.map +1 -0
- package/dist/harnesses/register-defaults.d.ts +24 -0
- package/dist/harnesses/register-defaults.d.ts.map +1 -0
- package/dist/harnesses/register-defaults.js +40 -0
- package/dist/harnesses/register-defaults.js.map +1 -0
- package/dist/harnesses/session-store.d.ts +201 -0
- package/dist/harnesses/session-store.d.ts.map +1 -0
- package/dist/harnesses/session-store.js +254 -0
- package/dist/harnesses/session-store.js.map +1 -0
- package/dist/index.d.ts +12 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -1
- package/dist/reflection/reflection.d.ts.map +1 -1
- package/dist/reflection/reflection.js +19 -4
- package/dist/reflection/reflection.js.map +1 -1
- package/dist/types/agent.d.ts +1253 -2
- package/dist/types/agent.d.ts.map +1 -1
- package/dist/types/agent.js +418 -1
- package/dist/types/agent.js.map +1 -1
- package/dist/types/decorators.d.ts +10 -1
- package/dist/types/decorators.d.ts.map +1 -1
- package/dist/types/events.d.ts +26 -0
- package/dist/types/events.d.ts.map +1 -1
- package/dist/types/harnesses.d.ts +474 -0
- package/dist/types/harnesses.d.ts.map +1 -0
- package/dist/types/harnesses.js +2 -0
- package/dist/types/harnesses.js.map +1 -0
- package/dist/types/index.d.ts +9 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +6 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/providers.d.ts +691 -0
- package/dist/types/providers.d.ts.map +1 -0
- package/dist/types/providers.js +14 -0
- package/dist/types/providers.js.map +1 -0
- package/dist/types/restart.d.ts +132 -0
- package/dist/types/restart.d.ts.map +1 -0
- package/dist/types/restart.js +2 -0
- package/dist/types/restart.js.map +1 -0
- package/dist/types/streaming.d.ts +194 -0
- package/dist/types/streaming.d.ts.map +1 -0
- package/dist/types/streaming.js +67 -0
- package/dist/types/streaming.js.map +1 -0
- package/dist/types/workflow-context.d.ts +137 -1
- package/dist/types/workflow-context.d.ts.map +1 -1
- package/dist/utils/agent-validation.d.ts +88 -0
- package/dist/utils/agent-validation.d.ts.map +1 -0
- package/dist/utils/agent-validation.js +87 -0
- package/dist/utils/agent-validation.js.map +1 -0
- package/dist/utils/delay.d.ts +7 -0
- package/dist/utils/delay.d.ts.map +1 -0
- package/dist/utils/delay.js +9 -0
- package/dist/utils/delay.js.map +1 -0
- package/dist/utils/harness-config.d.ts +180 -0
- package/dist/utils/harness-config.d.ts.map +1 -0
- package/dist/utils/harness-config.js +311 -0
- package/dist/utils/harness-config.js.map +1 -0
- package/dist/utils/index.d.ts +9 -1
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +8 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/model-spec.d.ts +110 -0
- package/dist/utils/model-spec.d.ts.map +1 -0
- package/dist/utils/model-spec.js +149 -0
- package/dist/utils/model-spec.js.map +1 -0
- package/dist/utils/provider-config.d.ts +10 -0
- package/dist/utils/provider-config.d.ts.map +1 -0
- package/dist/utils/provider-config.js +10 -0
- package/dist/utils/provider-config.js.map +1 -0
- package/dist/utils/restart-analysis.d.ts +202 -0
- package/dist/utils/restart-analysis.d.ts.map +1 -0
- package/dist/utils/restart-analysis.js +426 -0
- package/dist/utils/restart-analysis.js.map +1 -0
- package/dist/utils/session-serialization.d.ts +118 -0
- package/dist/utils/session-serialization.d.ts.map +1 -0
- package/dist/utils/session-serialization.js +217 -0
- package/dist/utils/session-serialization.js.map +1 -0
- package/package.json +31 -5
- package/CHANGELOG.md +0 -188
- package/dist/__tests__/adversarial/attachChild-performance.test.d.ts +0 -16
- package/dist/__tests__/adversarial/attachChild-performance.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/attachChild-performance.test.js +0 -187
- package/dist/__tests__/adversarial/attachChild-performance.test.js.map +0 -1
- package/dist/__tests__/adversarial/circular-reference.test.d.ts +0 -13
- package/dist/__tests__/adversarial/circular-reference.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/circular-reference.test.js +0 -92
- package/dist/__tests__/adversarial/circular-reference.test.js.map +0 -1
- package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts +0 -16
- package/dist/__tests__/adversarial/complex-circular-reference.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/complex-circular-reference.test.js +0 -127
- package/dist/__tests__/adversarial/complex-circular-reference.test.js.map +0 -1
- package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts +0 -21
- package/dist/__tests__/adversarial/concurrent-task-failures.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/concurrent-task-failures.test.js +0 -667
- package/dist/__tests__/adversarial/concurrent-task-failures.test.js.map +0 -1
- package/dist/__tests__/adversarial/deep-analysis.test.d.ts +0 -6
- package/dist/__tests__/adversarial/deep-analysis.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/deep-analysis.test.js +0 -877
- package/dist/__tests__/adversarial/deep-analysis.test.js.map +0 -1
- package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts +0 -13
- package/dist/__tests__/adversarial/deep-hierarchy-stress.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js +0 -186
- package/dist/__tests__/adversarial/deep-hierarchy-stress.test.js.map +0 -1
- package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts +0 -6
- package/dist/__tests__/adversarial/e2e-prd-validation.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/e2e-prd-validation.test.js +0 -626
- package/dist/__tests__/adversarial/e2e-prd-validation.test.js.map +0 -1
- package/dist/__tests__/adversarial/edge-case.test.d.ts +0 -6
- package/dist/__tests__/adversarial/edge-case.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/edge-case.test.js +0 -857
- package/dist/__tests__/adversarial/edge-case.test.js.map +0 -1
- package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts +0 -20
- package/dist/__tests__/adversarial/error-merge-strategy.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/error-merge-strategy.test.js +0 -907
- package/dist/__tests__/adversarial/error-merge-strategy.test.js.map +0 -1
- package/dist/__tests__/adversarial/incremental-performance.test.d.ts +0 -2
- package/dist/__tests__/adversarial/incremental-performance.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/incremental-performance.test.js +0 -113
- package/dist/__tests__/adversarial/incremental-performance.test.js.map +0 -1
- package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts +0 -22
- package/dist/__tests__/adversarial/node-map-update-benchmarks.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js +0 -383
- package/dist/__tests__/adversarial/node-map-update-benchmarks.test.js.map +0 -1
- package/dist/__tests__/adversarial/observer-propagation.test.d.ts +0 -21
- package/dist/__tests__/adversarial/observer-propagation.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/observer-propagation.test.js +0 -404
- package/dist/__tests__/adversarial/observer-propagation.test.js.map +0 -1
- package/dist/__tests__/adversarial/parent-validation.test.d.ts +0 -13
- package/dist/__tests__/adversarial/parent-validation.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/parent-validation.test.js +0 -128
- package/dist/__tests__/adversarial/parent-validation.test.js.map +0 -1
- package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts +0 -20
- package/dist/__tests__/adversarial/prd-12-2-compliance.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/prd-12-2-compliance.test.js +0 -482
- package/dist/__tests__/adversarial/prd-12-2-compliance.test.js.map +0 -1
- package/dist/__tests__/adversarial/prd-compliance.test.d.ts +0 -6
- package/dist/__tests__/adversarial/prd-compliance.test.d.ts.map +0 -1
- package/dist/__tests__/adversarial/prd-compliance.test.js +0 -886
- package/dist/__tests__/adversarial/prd-compliance.test.js.map +0 -1
- package/dist/__tests__/compatibility/backward-compatibility.test.d.ts +0 -22
- package/dist/__tests__/compatibility/backward-compatibility.test.d.ts.map +0 -1
- package/dist/__tests__/compatibility/backward-compatibility.test.js +0 -1843
- package/dist/__tests__/compatibility/backward-compatibility.test.js.map +0 -1
- package/dist/__tests__/helpers/index.d.ts +0 -10
- package/dist/__tests__/helpers/index.d.ts.map +0 -1
- package/dist/__tests__/helpers/index.js +0 -10
- package/dist/__tests__/helpers/index.js.map +0 -1
- package/dist/__tests__/helpers/tree-verification.d.ts +0 -90
- package/dist/__tests__/helpers/tree-verification.d.ts.map +0 -1
- package/dist/__tests__/helpers/tree-verification.js +0 -202
- package/dist/__tests__/helpers/tree-verification.js.map +0 -1
- package/dist/__tests__/integration/agent-workflow.test.d.ts +0 -2
- package/dist/__tests__/integration/agent-workflow.test.d.ts.map +0 -1
- package/dist/__tests__/integration/agent-workflow.test.js +0 -256
- package/dist/__tests__/integration/agent-workflow.test.js.map +0 -1
- package/dist/__tests__/integration/bidirectional-consistency.test.d.ts +0 -14
- package/dist/__tests__/integration/bidirectional-consistency.test.d.ts.map +0 -1
- package/dist/__tests__/integration/bidirectional-consistency.test.js +0 -668
- package/dist/__tests__/integration/bidirectional-consistency.test.js.map +0 -1
- package/dist/__tests__/integration/observer-logging.test.d.ts +0 -2
- package/dist/__tests__/integration/observer-logging.test.d.ts.map +0 -1
- package/dist/__tests__/integration/observer-logging.test.js +0 -517
- package/dist/__tests__/integration/observer-logging.test.js.map +0 -1
- package/dist/__tests__/integration/tree-mirroring.test.d.ts +0 -2
- package/dist/__tests__/integration/tree-mirroring.test.d.ts.map +0 -1
- package/dist/__tests__/integration/tree-mirroring.test.js +0 -117
- package/dist/__tests__/integration/tree-mirroring.test.js.map +0 -1
- package/dist/__tests__/integration/workflow-reparenting.test.d.ts +0 -12
- package/dist/__tests__/integration/workflow-reparenting.test.d.ts.map +0 -1
- package/dist/__tests__/integration/workflow-reparenting.test.js +0 -239
- package/dist/__tests__/integration/workflow-reparenting.test.js.map +0 -1
- package/dist/__tests__/unit/agent.test.d.ts +0 -2
- package/dist/__tests__/unit/agent.test.d.ts.map +0 -1
- package/dist/__tests__/unit/agent.test.js +0 -143
- package/dist/__tests__/unit/agent.test.js.map +0 -1
- package/dist/__tests__/unit/cache-key.test.d.ts +0 -5
- package/dist/__tests__/unit/cache-key.test.d.ts.map +0 -1
- package/dist/__tests__/unit/cache-key.test.js +0 -145
- package/dist/__tests__/unit/cache-key.test.js.map +0 -1
- package/dist/__tests__/unit/cache.test.d.ts +0 -5
- package/dist/__tests__/unit/cache.test.d.ts.map +0 -1
- package/dist/__tests__/unit/cache.test.js +0 -132
- package/dist/__tests__/unit/cache.test.js.map +0 -1
- package/dist/__tests__/unit/context.test.d.ts +0 -2
- package/dist/__tests__/unit/context.test.d.ts.map +0 -1
- package/dist/__tests__/unit/context.test.js +0 -220
- package/dist/__tests__/unit/context.test.js.map +0 -1
- package/dist/__tests__/unit/decorators.test.d.ts +0 -2
- package/dist/__tests__/unit/decorators.test.d.ts.map +0 -1
- package/dist/__tests__/unit/decorators.test.js +0 -162
- package/dist/__tests__/unit/decorators.test.js.map +0 -1
- package/dist/__tests__/unit/introspection-tools.test.d.ts +0 -5
- package/dist/__tests__/unit/introspection-tools.test.d.ts.map +0 -1
- package/dist/__tests__/unit/introspection-tools.test.js +0 -191
- package/dist/__tests__/unit/introspection-tools.test.js.map +0 -1
- package/dist/__tests__/unit/logger.test.d.ts +0 -2
- package/dist/__tests__/unit/logger.test.d.ts.map +0 -1
- package/dist/__tests__/unit/logger.test.js +0 -241
- package/dist/__tests__/unit/logger.test.js.map +0 -1
- package/dist/__tests__/unit/observable.test.d.ts +0 -2
- package/dist/__tests__/unit/observable.test.d.ts.map +0 -1
- package/dist/__tests__/unit/observable.test.js +0 -251
- package/dist/__tests__/unit/observable.test.js.map +0 -1
- package/dist/__tests__/unit/prompt.test.d.ts +0 -2
- package/dist/__tests__/unit/prompt.test.d.ts.map +0 -1
- package/dist/__tests__/unit/prompt.test.js +0 -113
- package/dist/__tests__/unit/prompt.test.js.map +0 -1
- package/dist/__tests__/unit/reflection.test.d.ts +0 -5
- package/dist/__tests__/unit/reflection.test.d.ts.map +0 -1
- package/dist/__tests__/unit/reflection.test.js +0 -160
- package/dist/__tests__/unit/reflection.test.js.map +0 -1
- package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts +0 -2
- package/dist/__tests__/unit/tree-debugger-incremental.test.d.ts.map +0 -1
- package/dist/__tests__/unit/tree-debugger-incremental.test.js +0 -136
- package/dist/__tests__/unit/tree-debugger-incremental.test.js.map +0 -1
- package/dist/__tests__/unit/tree-debugger.test.d.ts +0 -2
- package/dist/__tests__/unit/tree-debugger.test.d.ts.map +0 -1
- package/dist/__tests__/unit/tree-debugger.test.js +0 -69
- package/dist/__tests__/unit/tree-debugger.test.js.map +0 -1
- package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts +0 -2
- package/dist/__tests__/unit/utils/workflow-error-utils.test.d.ts.map +0 -1
- package/dist/__tests__/unit/utils/workflow-error-utils.test.js +0 -154
- package/dist/__tests__/unit/utils/workflow-error-utils.test.js.map +0 -1
- package/dist/__tests__/unit/workflow-detachChild.test.d.ts +0 -2
- package/dist/__tests__/unit/workflow-detachChild.test.d.ts.map +0 -1
- package/dist/__tests__/unit/workflow-detachChild.test.js +0 -76
- package/dist/__tests__/unit/workflow-detachChild.test.js.map +0 -1
- package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts +0 -2
- package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.d.ts.map +0 -1
- package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js +0 -122
- package/dist/__tests__/unit/workflow-emitEvent-childDetached.test.js.map +0 -1
- package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts +0 -2
- package/dist/__tests__/unit/workflow-isDescendantOf.test.d.ts.map +0 -1
- package/dist/__tests__/unit/workflow-isDescendantOf.test.js +0 -140
- package/dist/__tests__/unit/workflow-isDescendantOf.test.js.map +0 -1
- package/dist/__tests__/unit/workflow.test.d.ts +0 -2
- package/dist/__tests__/unit/workflow.test.d.ts.map +0 -1
- package/dist/__tests__/unit/workflow.test.js +0 -330
- package/dist/__tests__/unit/workflow.test.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"observer-propagation.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/adversarial/observer-propagation.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG"}
|
|
@@ -1,404 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* PRD Section 7: Observer Propagation Compliance Test
|
|
3
|
-
*
|
|
4
|
-
* Validates that observer propagation works correctly per PRD Section 7 requirements:
|
|
5
|
-
* - Events from deeply nested children bubble up to root observers via getRoot()
|
|
6
|
-
* - After reparenting, events propagate to new root's observer (not old root's)
|
|
7
|
-
* - getRoot() correctly follows parent chain with cycle detection
|
|
8
|
-
* - All observer callbacks (onEvent, onTreeChanged) are invoked
|
|
9
|
-
*
|
|
10
|
-
* Bug Context: The tree integrity bug (child in multiple parents) broke observer
|
|
11
|
-
* propagation because getRoot() only followed child.parent chain. This test validates
|
|
12
|
-
* the fix ensures events route to correct observers.
|
|
13
|
-
*
|
|
14
|
-
* References:
|
|
15
|
-
* - Bug Analysis: plan/docs/bugfix-architecture/bug_analysis.md (lines 60-91)
|
|
16
|
-
* - getRoot() implementation: src/core/workflow.ts (lines 174-189)
|
|
17
|
-
* - getRootObservers() implementation: src/core/workflow.ts (lines 124-139)
|
|
18
|
-
* - emitEvent() implementation: src/core/workflow.ts (lines 313-329)
|
|
19
|
-
*/
|
|
20
|
-
import { describe, it, expect } from 'vitest';
|
|
21
|
-
import { Workflow, } from '../../index.js';
|
|
22
|
-
/**
|
|
23
|
-
* SimpleWorkflow class for testing
|
|
24
|
-
* Pattern from: src/__tests__/integration/workflow-reparenting.test.ts
|
|
25
|
-
*/
|
|
26
|
-
class SimpleWorkflow extends Workflow {
|
|
27
|
-
async run() {
|
|
28
|
-
this.setStatus('running');
|
|
29
|
-
this.setStatus('completed');
|
|
30
|
-
return 'done';
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Observer creation helper
|
|
35
|
-
* Pattern from: src/__tests__/integration/workflow-reparenting.test.ts:142-147
|
|
36
|
-
*/
|
|
37
|
-
const createObserver = (eventsArray) => ({
|
|
38
|
-
onLog: () => { }, // Empty - not testing logs in this test suite
|
|
39
|
-
onEvent: (e) => eventsArray.push(e), // Capture events for validation
|
|
40
|
-
onStateUpdated: () => { }, // Empty - not testing state updates
|
|
41
|
-
onTreeChanged: () => { }, // Empty - not testing tree changes
|
|
42
|
-
});
|
|
43
|
-
describe('PRD Section 7: Observer Propagation', () => {
|
|
44
|
-
describe('Event Bubbling: Grandchild to Root Observer', () => {
|
|
45
|
-
it('should propagate events from grandchild to root observer via getRoot()', () => {
|
|
46
|
-
// ============================================================
|
|
47
|
-
// PHASE 1: Setup - Create 3-level tree
|
|
48
|
-
// ============================================================
|
|
49
|
-
// ARRANGE: Create root, child, grandchild hierarchy
|
|
50
|
-
const root = new SimpleWorkflow('Root');
|
|
51
|
-
const child = new SimpleWorkflow('Child', root);
|
|
52
|
-
const grandchild = new SimpleWorkflow('Grandchild', child);
|
|
53
|
-
// ============================================================
|
|
54
|
-
// PHASE 2: Add observer to root
|
|
55
|
-
// ============================================================
|
|
56
|
-
// ARRANGE: Create event capture array and observer
|
|
57
|
-
const rootEvents = [];
|
|
58
|
-
root.addObserver(createObserver(rootEvents));
|
|
59
|
-
// ============================================================
|
|
60
|
-
// PHASE 3: Emit event from grandchild
|
|
61
|
-
// ============================================================
|
|
62
|
-
// ACT: Clear any construction events, then emit from grandchild
|
|
63
|
-
// PRD Section 7: "Observers attach to root workflow and receive all events"
|
|
64
|
-
rootEvents.length = 0; // Clear any construction events
|
|
65
|
-
grandchild.setStatus('running');
|
|
66
|
-
// ============================================================
|
|
67
|
-
// PHASE 4: Verify root observer received event
|
|
68
|
-
// ============================================================
|
|
69
|
-
// ASSERT: Root observer should receive event via getRoot() traversal
|
|
70
|
-
// getRoot() from grandchild returns root, then root.observers receive event
|
|
71
|
-
const receivedEvent = rootEvents.find((e) => e.type === 'treeUpdated');
|
|
72
|
-
expect(receivedEvent).toBeDefined();
|
|
73
|
-
// Type guard for discriminated union
|
|
74
|
-
if (receivedEvent?.type === 'treeUpdated') {
|
|
75
|
-
expect(receivedEvent.root.id).toBe(root.id);
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
it('should propagate events through multiple hierarchy levels', () => {
|
|
79
|
-
// ============================================================
|
|
80
|
-
// Test deeper hierarchy (4+ levels) to verify getRoot() traversal
|
|
81
|
-
// ============================================================
|
|
82
|
-
// ARRANGE: Create 5-level deep hierarchy
|
|
83
|
-
const root = new SimpleWorkflow('Root');
|
|
84
|
-
const level1 = new SimpleWorkflow('L1', root);
|
|
85
|
-
const level2 = new SimpleWorkflow('L2', level1);
|
|
86
|
-
const level3 = new SimpleWorkflow('L3', level2);
|
|
87
|
-
const level4 = new SimpleWorkflow('L4', level3);
|
|
88
|
-
const rootEvents = [];
|
|
89
|
-
root.addObserver(createObserver(rootEvents));
|
|
90
|
-
// ACT: Emit event from deepest level
|
|
91
|
-
rootEvents.length = 0;
|
|
92
|
-
level4.setStatus('running');
|
|
93
|
-
// ASSERT: Verify event bubbled through 4 levels to root
|
|
94
|
-
// This validates getRoot() correctly traverses: level4 -> level3 -> level2 -> level1 -> root
|
|
95
|
-
expect(rootEvents.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
96
|
-
// Verify the event root is the original root workflow
|
|
97
|
-
const treeUpdatedEvent = rootEvents.find((e) => e.type === 'treeUpdated');
|
|
98
|
-
if (treeUpdatedEvent?.type === 'treeUpdated') {
|
|
99
|
-
expect(treeUpdatedEvent.root.id).toBe(root.id);
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
});
|
|
103
|
-
describe('Observer Routing After Reparenting', () => {
|
|
104
|
-
it('should route events to new root observer after reparenting', () => {
|
|
105
|
-
// ============================================================
|
|
106
|
-
// PHASE 1: Setup - Create parent1, parent2, grandchild with parent1
|
|
107
|
-
// ============================================================
|
|
108
|
-
// ARRANGE: Create initial tree structure
|
|
109
|
-
const parent1 = new SimpleWorkflow('Parent1');
|
|
110
|
-
const child1 = new SimpleWorkflow('Child1', parent1);
|
|
111
|
-
const grandchild = new SimpleWorkflow('Grandchild', child1);
|
|
112
|
-
const parent2 = new SimpleWorkflow('Parent2');
|
|
113
|
-
// ============================================================
|
|
114
|
-
// PHASE 2: Verify initial propagation to parent1 observer
|
|
115
|
-
// ============================================================
|
|
116
|
-
// ARRANGE: Create observer for parent1
|
|
117
|
-
const parent1Events = [];
|
|
118
|
-
parent1.addObserver(createObserver(parent1Events));
|
|
119
|
-
// ACT: Emit event from grandchild
|
|
120
|
-
parent1Events.length = 0;
|
|
121
|
-
grandchild.setStatus('running');
|
|
122
|
-
// ASSERT: parent1 observer receives event (initial state)
|
|
123
|
-
expect(parent1Events.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
124
|
-
// ============================================================
|
|
125
|
-
// PHASE 3: Reparent grandchild to different tree
|
|
126
|
-
// ============================================================
|
|
127
|
-
// ACT: First detach from child1, then attach to child2
|
|
128
|
-
// Pattern: detachChild() -> attachChild() for proper reparenting
|
|
129
|
-
const child2 = new SimpleWorkflow('Child2', parent2);
|
|
130
|
-
child1.detachChild(grandchild);
|
|
131
|
-
child2.attachChild(grandchild);
|
|
132
|
-
// ============================================================
|
|
133
|
-
// PHASE 4: Add observer to new root (parent2)
|
|
134
|
-
// ============================================================
|
|
135
|
-
// ARRANGE: Create observer for parent2
|
|
136
|
-
const parent2Events = [];
|
|
137
|
-
parent2.addObserver(createObserver(parent2Events));
|
|
138
|
-
// ============================================================
|
|
139
|
-
// PHASE 5: Emit event from grandchild
|
|
140
|
-
// ============================================================
|
|
141
|
-
// ACT: Clear events to isolate post-reparenting behavior
|
|
142
|
-
parent1Events.length = 0;
|
|
143
|
-
parent2Events.length = 0;
|
|
144
|
-
grandchild.setStatus('completed');
|
|
145
|
-
// ============================================================
|
|
146
|
-
// PHASE 6: Verify new root observer receives event
|
|
147
|
-
// ============================================================
|
|
148
|
-
// ASSERT: parent2 observer receives event (after reparenting)
|
|
149
|
-
expect(parent2Events.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
150
|
-
});
|
|
151
|
-
it('should not route events to old root observer after reparenting', () => {
|
|
152
|
-
// ============================================================
|
|
153
|
-
// CRITICAL VALIDATION: This test validates the bug fix
|
|
154
|
-
// ============================================================
|
|
155
|
-
// Bug analysis (bug_analysis.md:60-91) showed:
|
|
156
|
-
// - child.parent stayed pointing to old parent
|
|
157
|
-
// - getRoot() returned wrong root
|
|
158
|
-
// - Old parent's observers still received events after reparenting
|
|
159
|
-
//
|
|
160
|
-
// This test ensures that after the fix:
|
|
161
|
-
// - child.parent is updated to new parent
|
|
162
|
-
// - getRoot() returns correct root
|
|
163
|
-
// - Old parent's observers do NOT receive events
|
|
164
|
-
// ARRANGE: Create two separate trees with observers
|
|
165
|
-
const parent1 = new SimpleWorkflow('Parent1');
|
|
166
|
-
const child1 = new SimpleWorkflow('Child1', parent1);
|
|
167
|
-
const grandchild = new SimpleWorkflow('Grandchild', child1);
|
|
168
|
-
const parent2 = new SimpleWorkflow('Parent2');
|
|
169
|
-
const child2 = new SimpleWorkflow('Child2', parent2);
|
|
170
|
-
const parent1Events = [];
|
|
171
|
-
const parent2Events = [];
|
|
172
|
-
parent1.addObserver(createObserver(parent1Events));
|
|
173
|
-
parent2.addObserver(createObserver(parent2Events));
|
|
174
|
-
// ACT: Reparent grandchild from parent1 tree to parent2 tree
|
|
175
|
-
// Pattern: detach from old parent, then attach to new parent
|
|
176
|
-
child1.detachChild(grandchild);
|
|
177
|
-
child2.attachChild(grandchild);
|
|
178
|
-
// Clear events to isolate post-reparenting behavior
|
|
179
|
-
parent1Events.length = 0;
|
|
180
|
-
parent2Events.length = 0;
|
|
181
|
-
// Emit event from grandchild
|
|
182
|
-
grandchild.setStatus('running');
|
|
183
|
-
// ASSERT: CRITICAL - Old root's observer must NOT receive event
|
|
184
|
-
// This was the bug - old parent's observers still received events
|
|
185
|
-
expect(parent1Events.some((e) => e.type === 'treeUpdated')).toBe(false);
|
|
186
|
-
expect(parent1Events.length).toBe(0);
|
|
187
|
-
// ASSERT: New root's observer MUST receive event
|
|
188
|
-
expect(parent2Events.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
189
|
-
});
|
|
190
|
-
});
|
|
191
|
-
describe('getRoot() Traversal Correctness', () => {
|
|
192
|
-
it('should find root workflow via parent chain traversal', () => {
|
|
193
|
-
// ============================================================
|
|
194
|
-
// Verify getRoot() from grandchild returns root
|
|
195
|
-
// ============================================================
|
|
196
|
-
// This is called internally by getRootObservers()
|
|
197
|
-
// ARRANGE: Create 3-level tree
|
|
198
|
-
const root = new SimpleWorkflow('Root');
|
|
199
|
-
const child = new SimpleWorkflow('Child', root);
|
|
200
|
-
const grandchild = new SimpleWorkflow('Grandchild', child);
|
|
201
|
-
// ACT: Call getRoot() on grandchild (protected method, access via cast)
|
|
202
|
-
const foundRoot = grandchild.getRoot();
|
|
203
|
-
// ASSERT: getRoot() should return root workflow
|
|
204
|
-
expect(foundRoot).toBe(root);
|
|
205
|
-
expect(foundRoot).not.toBe(child);
|
|
206
|
-
expect(foundRoot).not.toBe(grandchild);
|
|
207
|
-
});
|
|
208
|
-
it('should find root through deep parent chain', () => {
|
|
209
|
-
// ============================================================
|
|
210
|
-
// Verify getRoot() works correctly with deep hierarchies
|
|
211
|
-
// ============================================================
|
|
212
|
-
// ARRANGE: Create 10-level deep hierarchy
|
|
213
|
-
const root = new SimpleWorkflow('Root');
|
|
214
|
-
let current = root;
|
|
215
|
-
for (let i = 0; i < 10; i++) {
|
|
216
|
-
const nextChild = new SimpleWorkflow(`Level${i}`);
|
|
217
|
-
current.attachChild(nextChild);
|
|
218
|
-
current = nextChild;
|
|
219
|
-
}
|
|
220
|
-
// ACT: Call getRoot() on deepest child
|
|
221
|
-
const foundRoot = current.getRoot();
|
|
222
|
-
// ASSERT: Deepest child's getRoot() returns original root
|
|
223
|
-
expect(foundRoot).toBe(root);
|
|
224
|
-
});
|
|
225
|
-
it('should maintain correct root after multiple reparenting cycles', () => {
|
|
226
|
-
// ============================================================
|
|
227
|
-
// Test reparenting: A->B->C => X->Y->C => A->Z->C
|
|
228
|
-
// ============================================================
|
|
229
|
-
// ARRANGE: Create initial tree A->B->C
|
|
230
|
-
const parentA = new SimpleWorkflow('ParentA');
|
|
231
|
-
const parentB = new SimpleWorkflow('ParentB', parentA);
|
|
232
|
-
const childC = new SimpleWorkflow('ChildC', parentB);
|
|
233
|
-
// ASSERT: Initial - C's root should be A
|
|
234
|
-
expect(childC.getRoot()).toBe(parentA);
|
|
235
|
-
// ACT: Reparent to X->Y->C
|
|
236
|
-
const parentX = new SimpleWorkflow('ParentX');
|
|
237
|
-
const parentY = new SimpleWorkflow('ParentY', parentX);
|
|
238
|
-
parentB.detachChild(childC);
|
|
239
|
-
parentY.attachChild(childC);
|
|
240
|
-
// ASSERT: After first reparenting, C's root should be X
|
|
241
|
-
expect(childC.getRoot()).toBe(parentX);
|
|
242
|
-
// ACT: Reparent again to A->Z->C
|
|
243
|
-
const parentZ = new SimpleWorkflow('ParentZ', parentA);
|
|
244
|
-
parentY.detachChild(childC);
|
|
245
|
-
parentZ.attachChild(childC);
|
|
246
|
-
// ASSERT: After second reparenting, C's root should be A again
|
|
247
|
-
expect(childC.getRoot()).toBe(parentA);
|
|
248
|
-
});
|
|
249
|
-
});
|
|
250
|
-
describe('Observer Callback Invocation', () => {
|
|
251
|
-
it('should invoke onEvent() for all event types from children', () => {
|
|
252
|
-
// ============================================================
|
|
253
|
-
// Verify onEvent() callback is invoked
|
|
254
|
-
// ============================================================
|
|
255
|
-
// ARRANGE: Create 2-level tree with tracking observer
|
|
256
|
-
const root = new SimpleWorkflow('Root');
|
|
257
|
-
const child = new SimpleWorkflow('Child', root);
|
|
258
|
-
let onEventCallCount = 0;
|
|
259
|
-
let receivedEventType;
|
|
260
|
-
const trackingObserver = {
|
|
261
|
-
onLog: () => { },
|
|
262
|
-
onEvent: (e) => {
|
|
263
|
-
onEventCallCount++;
|
|
264
|
-
receivedEventType = e.type;
|
|
265
|
-
},
|
|
266
|
-
onStateUpdated: () => { },
|
|
267
|
-
onTreeChanged: () => { },
|
|
268
|
-
};
|
|
269
|
-
root.addObserver(trackingObserver);
|
|
270
|
-
// ACT: Emit event from child
|
|
271
|
-
child.setStatus('running');
|
|
272
|
-
// ASSERT: Verify onEvent was called
|
|
273
|
-
expect(onEventCallCount).toBeGreaterThan(0);
|
|
274
|
-
expect(receivedEventType).toBeDefined();
|
|
275
|
-
});
|
|
276
|
-
it('should invoke onTreeChanged() for tree update events', () => {
|
|
277
|
-
// ============================================================
|
|
278
|
-
// Verify onTreeChanged() callback is invoked
|
|
279
|
-
// ============================================================
|
|
280
|
-
// ARRANGE: Create 2-level tree with tracking observer
|
|
281
|
-
const root = new SimpleWorkflow('Root');
|
|
282
|
-
const child = new SimpleWorkflow('Child', root);
|
|
283
|
-
let onTreeChangedCallCount = 0;
|
|
284
|
-
let receivedRoot;
|
|
285
|
-
const trackingObserver = {
|
|
286
|
-
onLog: () => { },
|
|
287
|
-
onEvent: () => { },
|
|
288
|
-
onStateUpdated: () => { },
|
|
289
|
-
onTreeChanged: (rootNode) => {
|
|
290
|
-
onTreeChangedCallCount++;
|
|
291
|
-
receivedRoot = rootNode;
|
|
292
|
-
},
|
|
293
|
-
};
|
|
294
|
-
root.addObserver(trackingObserver);
|
|
295
|
-
// ACT: Emit tree update event (triggers both onEvent and onTreeChanged)
|
|
296
|
-
// Note: setStatus() emits treeUpdated event which triggers onTreeChanged()
|
|
297
|
-
child.setStatus('running');
|
|
298
|
-
// ASSERT: Verify onTreeChanged was called with correct root
|
|
299
|
-
expect(onTreeChangedCallCount).toBeGreaterThan(0);
|
|
300
|
-
expect(receivedRoot).toBeDefined();
|
|
301
|
-
expect(receivedRoot.id).toBe(root.id);
|
|
302
|
-
});
|
|
303
|
-
it('should invoke callbacks in correct order', () => {
|
|
304
|
-
// ============================================================
|
|
305
|
-
// Verify callback order: onEvent before onTreeChanged
|
|
306
|
-
// ============================================================
|
|
307
|
-
// ARRANGE: Create 2-level tree with order-tracking observer
|
|
308
|
-
const root = new SimpleWorkflow('Root');
|
|
309
|
-
const child = new SimpleWorkflow('Child', root);
|
|
310
|
-
const callOrder = [];
|
|
311
|
-
const orderTrackingObserver = {
|
|
312
|
-
onLog: () => callOrder.push('onLog'),
|
|
313
|
-
onEvent: () => callOrder.push('onEvent'),
|
|
314
|
-
onStateUpdated: () => callOrder.push('onStateUpdated'),
|
|
315
|
-
onTreeChanged: () => callOrder.push('onTreeChanged'),
|
|
316
|
-
};
|
|
317
|
-
root.addObserver(orderTrackingObserver);
|
|
318
|
-
// ACT: Emit tree update event
|
|
319
|
-
callOrder.length = 0;
|
|
320
|
-
child.setStatus('running');
|
|
321
|
-
// ASSERT: Verify callback order
|
|
322
|
-
// emitEvent() calls onEvent() first, then onTreeChanged()
|
|
323
|
-
// See workflow.ts:318-324
|
|
324
|
-
const eventIndex = callOrder.indexOf('onEvent');
|
|
325
|
-
const treeChangedIndex = callOrder.indexOf('onTreeChanged');
|
|
326
|
-
expect(eventIndex).toBeGreaterThanOrEqual(0);
|
|
327
|
-
expect(treeChangedIndex).toBeGreaterThanOrEqual(0);
|
|
328
|
-
expect(eventIndex).toBeLessThan(treeChangedIndex);
|
|
329
|
-
});
|
|
330
|
-
});
|
|
331
|
-
describe('Edge Cases: Cycle Detection', () => {
|
|
332
|
-
it('should still propagate events after cycle detection validation', () => {
|
|
333
|
-
// ============================================================
|
|
334
|
-
// Verify that cycle detection in getRoot() doesn't break normal propagation
|
|
335
|
-
// ============================================================
|
|
336
|
-
// getRoot() uses visited Set for cycle detection (workflow.ts:175-188)
|
|
337
|
-
// This test ensures normal operation is not affected
|
|
338
|
-
// ARRANGE: Create 3-level tree with no cycles
|
|
339
|
-
const root = new SimpleWorkflow('Root');
|
|
340
|
-
const child = new SimpleWorkflow('Child', root);
|
|
341
|
-
const grandchild = new SimpleWorkflow('Grandchild', child);
|
|
342
|
-
const rootEvents = [];
|
|
343
|
-
root.addObserver(createObserver(rootEvents));
|
|
344
|
-
// ACT: Emit event from grandchild
|
|
345
|
-
// This should work normally (no cycle exists)
|
|
346
|
-
grandchild.setStatus('running');
|
|
347
|
-
// ASSERT: Verify propagation still works
|
|
348
|
-
expect(rootEvents.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
349
|
-
// Verify getRoot() didn't throw cycle detection error
|
|
350
|
-
const foundRoot = grandchild.getRoot();
|
|
351
|
-
expect(foundRoot).toBe(root);
|
|
352
|
-
});
|
|
353
|
-
});
|
|
354
|
-
describe('Multiple Reparenting Cycles', () => {
|
|
355
|
-
it('should handle multiple reparenting cycles correctly', () => {
|
|
356
|
-
// ============================================================
|
|
357
|
-
// Test: A->B->C => X->Y->C => A->Z->C => P->Q->C
|
|
358
|
-
// ============================================================
|
|
359
|
-
// ARRANGE: Create three potential parents
|
|
360
|
-
const parentA = new SimpleWorkflow('ParentA');
|
|
361
|
-
const parentB = new SimpleWorkflow('ParentB', parentA);
|
|
362
|
-
const childC = new SimpleWorkflow('ChildC', parentB);
|
|
363
|
-
const parentX = new SimpleWorkflow('ParentX');
|
|
364
|
-
const parentY = new SimpleWorkflow('ParentY', parentX);
|
|
365
|
-
const parentP = new SimpleWorkflow('ParentP');
|
|
366
|
-
const parentQ = new SimpleWorkflow('ParentQ', parentP);
|
|
367
|
-
const eventsA = [];
|
|
368
|
-
const eventsX = [];
|
|
369
|
-
const eventsP = [];
|
|
370
|
-
const createObserverWithTracking = (eventsArray) => ({
|
|
371
|
-
onLog: () => { },
|
|
372
|
-
onEvent: (e) => eventsArray.push(e),
|
|
373
|
-
onStateUpdated: () => { },
|
|
374
|
-
onTreeChanged: () => { },
|
|
375
|
-
});
|
|
376
|
-
parentA.addObserver(createObserverWithTracking(eventsA));
|
|
377
|
-
parentX.addObserver(createObserverWithTracking(eventsX));
|
|
378
|
-
parentP.addObserver(createObserverWithTracking(eventsP));
|
|
379
|
-
// ACT & ASSERT: Cycle 1 - Verify initial state A->B->C
|
|
380
|
-
eventsA.length = 0;
|
|
381
|
-
childC.setStatus('running');
|
|
382
|
-
expect(eventsA.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
383
|
-
// ACT & ASSERT: Cycle 2 - Reparent to X->Y->C
|
|
384
|
-
parentB.detachChild(childC);
|
|
385
|
-
parentY.attachChild(childC);
|
|
386
|
-
eventsA.length = 0;
|
|
387
|
-
eventsX.length = 0;
|
|
388
|
-
childC.setStatus('completed');
|
|
389
|
-
expect(eventsX.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
390
|
-
expect(eventsA.some((e) => e.type === 'treeUpdated')).toBe(false);
|
|
391
|
-
// ACT & ASSERT: Cycle 3 - Reparent to P->Q->C
|
|
392
|
-
parentY.detachChild(childC);
|
|
393
|
-
parentQ.attachChild(childC);
|
|
394
|
-
eventsX.length = 0;
|
|
395
|
-
eventsP.length = 0;
|
|
396
|
-
childC.setStatus('running');
|
|
397
|
-
expect(eventsP.some((e) => e.type === 'treeUpdated')).toBe(true);
|
|
398
|
-
expect(eventsX.some((e) => e.type === 'treeUpdated')).toBe(false);
|
|
399
|
-
// Final: Verify getRoot() returns correct root
|
|
400
|
-
expect(childC.getRoot()).toBe(parentP);
|
|
401
|
-
});
|
|
402
|
-
});
|
|
403
|
-
});
|
|
404
|
-
//# sourceMappingURL=observer-propagation.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"observer-propagation.test.js","sourceRoot":"","sources":["../../../src/__tests__/adversarial/observer-propagation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Parent Validation Tests (TDD Red Phase)
|
|
3
|
-
*
|
|
4
|
-
* These tests validate the attachChild() method properly prevents
|
|
5
|
-
* attaching a child workflow that already has a different parent.
|
|
6
|
-
*
|
|
7
|
-
* This is the RED phase of TDD - tests are written to FAIL initially,
|
|
8
|
-
* documenting the expected behavior before implementation.
|
|
9
|
-
*
|
|
10
|
-
* Related: plan/docs/bugfix-architecture/bug_analysis.md
|
|
11
|
-
*/
|
|
12
|
-
export {};
|
|
13
|
-
//# sourceMappingURL=parent-validation.test.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"parent-validation.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/adversarial/parent-validation.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG"}
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Parent Validation Tests (TDD Red Phase)
|
|
3
|
-
*
|
|
4
|
-
* These tests validate the attachChild() method properly prevents
|
|
5
|
-
* attaching a child workflow that already has a different parent.
|
|
6
|
-
*
|
|
7
|
-
* This is the RED phase of TDD - tests are written to FAIL initially,
|
|
8
|
-
* documenting the expected behavior before implementation.
|
|
9
|
-
*
|
|
10
|
-
* Related: plan/docs/bugfix-architecture/bug_analysis.md
|
|
11
|
-
*/
|
|
12
|
-
import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest';
|
|
13
|
-
import { Workflow } from '../../index.js';
|
|
14
|
-
/**
|
|
15
|
-
* SimpleWorkflow class for testing
|
|
16
|
-
* Pattern from: src/__tests__/unit/workflow.test.ts:4-11
|
|
17
|
-
*/
|
|
18
|
-
class SimpleWorkflow extends Workflow {
|
|
19
|
-
async run() {
|
|
20
|
-
this.setStatus('running');
|
|
21
|
-
this.setStatus('completed');
|
|
22
|
-
return 'done';
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
describe('Adversarial: Parent Validation', () => {
|
|
26
|
-
/**
|
|
27
|
-
* Setup: Mock console methods to capture error messages
|
|
28
|
-
* Pattern from: research/console-mocking.md "Basic Spying Patterns"
|
|
29
|
-
*/
|
|
30
|
-
beforeEach(() => {
|
|
31
|
-
vi.spyOn(console, 'log').mockImplementation(() => { });
|
|
32
|
-
vi.spyOn(console, 'error').mockImplementation(() => { });
|
|
33
|
-
vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
34
|
-
});
|
|
35
|
-
/**
|
|
36
|
-
* Teardown: Restore all mocks to prevent test pollution
|
|
37
|
-
* CRITICAL: Always use vi.restoreAllMocks() in afterEach
|
|
38
|
-
*/
|
|
39
|
-
afterEach(() => {
|
|
40
|
-
vi.restoreAllMocks();
|
|
41
|
-
});
|
|
42
|
-
/**
|
|
43
|
-
* Primary failing test for parent validation bug
|
|
44
|
-
*
|
|
45
|
-
* Bug: attachChild() only checks if child is already attached to THIS workflow
|
|
46
|
-
* It does NOT check if child already has a different parent
|
|
47
|
-
*
|
|
48
|
-
* Expected: Error thrown with message containing 'already has a parent'
|
|
49
|
-
* Actual: No error thrown, inconsistent tree state created
|
|
50
|
-
*
|
|
51
|
-
* Pattern from: research/error-assertions.md "Partial Message Matching"
|
|
52
|
-
*/
|
|
53
|
-
it('should throw when attaching child that already has a different parent', () => {
|
|
54
|
-
// ARRANGE: Create two parent workflows
|
|
55
|
-
const parent1 = new SimpleWorkflow('Parent1');
|
|
56
|
-
const parent2 = new SimpleWorkflow('Parent2');
|
|
57
|
-
// ARRANGE: Create child with parent1 (constructor auto-attaches)
|
|
58
|
-
// CRITICAL: Constructor calls parent.attachChild(this) at workflow.ts:113-116
|
|
59
|
-
const child = new SimpleWorkflow('Child', parent1);
|
|
60
|
-
// Verify initial state
|
|
61
|
-
expect(child.parent).toBe(parent1);
|
|
62
|
-
expect(parent1.children).toContain(child);
|
|
63
|
-
// ACT & ASSERT: Attempting to attach child to parent2 should throw
|
|
64
|
-
// This test FAILS because attachChild() doesn't check child.parent !== this
|
|
65
|
-
expect(() => parent2.attachChild(child)).toThrow('already has a parent');
|
|
66
|
-
});
|
|
67
|
-
/**
|
|
68
|
-
* Test: Manual Parent Mutation with 'as any'
|
|
69
|
-
*
|
|
70
|
-
* Scenario: Even if someone manually mutates child.parent using 'as any',
|
|
71
|
-
* attachChild() should still validate and throw an error.
|
|
72
|
-
*
|
|
73
|
-
* This tests the defensive programming aspect - that the existing validation
|
|
74
|
-
* checks catch inconsistent state even when TypeScript type safety is bypassed.
|
|
75
|
-
*
|
|
76
|
-
* The attachChild() method has two validation checks (in order):
|
|
77
|
-
* 1. Line 217-219: children.includes(child) check
|
|
78
|
-
* 2. Line 222-228: child.parent !== null && child.parent !== this check
|
|
79
|
-
*
|
|
80
|
-
* When we manually mutate (child as any).parent = parent2, the child is
|
|
81
|
-
* still in parent1.children, so the first check throws first.
|
|
82
|
-
*
|
|
83
|
-
* Pattern from: plan/bugfix/P1M3T1S2/PRP.md "Manual Parent Mutation Test"
|
|
84
|
-
*/
|
|
85
|
-
it('should throw when manually mutating parent with as any then calling attachChild', () => {
|
|
86
|
-
// ARRANGE: Create two parent workflows
|
|
87
|
-
const parent1 = new SimpleWorkflow('Parent1');
|
|
88
|
-
const parent2 = new SimpleWorkflow('Parent2');
|
|
89
|
-
// ARRANGE: Create child with parent1 (constructor auto-attaches)
|
|
90
|
-
// CRITICAL: Constructor calls parent.attachChild(this) at workflow.ts:113-116
|
|
91
|
-
const child = new SimpleWorkflow('Child', parent1);
|
|
92
|
-
// Verify initial state - child should be attached to parent1
|
|
93
|
-
expect(child.parent).toBe(parent1);
|
|
94
|
-
expect(parent1.children).toContain(child);
|
|
95
|
-
// ARRANGE: Manually mutate child.parent using 'as any' to bypass TypeScript
|
|
96
|
-
// This simulates a developer bypassing the type system
|
|
97
|
-
child.parent = parent2;
|
|
98
|
-
// Verify manual mutation worked
|
|
99
|
-
expect(child.parent).toBe(parent2); // Now points to parent2
|
|
100
|
-
expect(parent1.children).toContain(child); // But still in parent1's children array!
|
|
101
|
-
// ACT & ASSERT: parent1.attachChild(child) should throw
|
|
102
|
-
// The validation at workflow.ts:217-219 checks children.includes(child) first
|
|
103
|
-
// Since child is still in parent1.children, it throws "Child already attached"
|
|
104
|
-
// This is defensive programming - even manual mutation is caught
|
|
105
|
-
expect(() => parent1.attachChild(child)).toThrow('Child already attached to this workflow');
|
|
106
|
-
});
|
|
107
|
-
/**
|
|
108
|
-
* Verify console.error is called with helpful message
|
|
109
|
-
*
|
|
110
|
-
* Pattern from: research/console-mocking.md "Verifying Error Messages"
|
|
111
|
-
*/
|
|
112
|
-
it('should log helpful error message to console when attaching child with existing parent', () => {
|
|
113
|
-
// ARRANGE
|
|
114
|
-
const parent1 = new SimpleWorkflow('Parent1');
|
|
115
|
-
const parent2 = new SimpleWorkflow('Parent2');
|
|
116
|
-
const child = new SimpleWorkflow('Child', parent1);
|
|
117
|
-
// ACT: Attempt the invalid attachment
|
|
118
|
-
try {
|
|
119
|
-
parent2.attachChild(child);
|
|
120
|
-
}
|
|
121
|
-
catch (err) {
|
|
122
|
-
// Expected error - test will fail because error isn't thrown yet
|
|
123
|
-
}
|
|
124
|
-
// ASSERT: Console.error should be called with helpful message
|
|
125
|
-
expect(console.error).toHaveBeenCalled();
|
|
126
|
-
});
|
|
127
|
-
});
|
|
128
|
-
//# sourceMappingURL=parent-validation.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"parent-validation.test.js","sourceRoot":"","sources":["../../../src/__tests__/adversarial/parent-validation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* PRD Section 12.2 Compliance Tests
|
|
3
|
-
*
|
|
4
|
-
* PRD Reference: PRPs/PRDs/001-hierarchical-workflow-engine.md, Section 12.2 (lines 311-368)
|
|
5
|
-
*
|
|
6
|
-
* These tests explicitly validate ALL requirements from PRD Section 12.2 for the Workflow Base Class
|
|
7
|
-
* related to parent-child tree structure integrity:
|
|
8
|
-
*
|
|
9
|
-
* PRD Section 12.2 Requirements:
|
|
10
|
-
* 1. Child has exactly one parent
|
|
11
|
-
* 2. child.parent matches parent (bidirectional link)
|
|
12
|
-
* 3. Child appears in only one parent's children array
|
|
13
|
-
* 4. Node tree mirrors workflow tree (1:1 correspondence)
|
|
14
|
-
*
|
|
15
|
-
* Each test includes clear documentation linking assertions to specific PRD requirements.
|
|
16
|
-
*
|
|
17
|
-
* Related: plan/bugfix/P1M3T2S1/PRP.md - PRD compliance validation for attachChild() bug fix
|
|
18
|
-
*/
|
|
19
|
-
export {};
|
|
20
|
-
//# sourceMappingURL=prd-12-2-compliance.test.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prd-12-2-compliance.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/adversarial/prd-12-2-compliance.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG"}
|