Commit bf9a94b
authored
Feat: Add async policy evaluation, typed side effects, and runtime namespace refactor (#43)
## Summary
Add async policy evaluation support with external governance checks,
introduce typed side effect contracts, and refactor the runtime
execution namespace structure for better cohesion.
## Added
- `IMutationPolicy<TState>.EvaluateAsync` contract with default
sync-to-async bridge for backwards compatibility
- `PolicyEvaluationTimeoutException` for explicit timeout failure
semantics during async policy evaluation
- `SideEffect<TData>` typed side effect contract with explicit payload
typing beyond `object?`
- Runtime test coverage for typed side effect payloads and Redis
serialization roundtrips
- `Runtime.Diagnostics` namespace containing `MutationAuditEntryFactory`
and `StateSizeEstimator`
- `Runtime.Internal.Execution` subfolder grouping pipeline
orchestration, concurrency, mode running, batch, and failure handling
- `Runtime.Internal.Evaluation` subfolder grouping policy evaluation and
policy modification application
## Changed
- `MutationPolicyEvaluator` now invokes `EvaluateAsync` with a linked
`CancellationTokenSource` respecting `PolicyEvaluationTimeout` from
engine options
- Sync and async policy paths coexist without ambiguous semantics —
async path is the primary evaluation contract
- `MutationEngine` wired to `Runtime.Diagnostics` namespace and
decomposed execution pipeline
- Governance persistence, query, and Redis flows handle typed side
effect payloads predictably through explicit `SideEffect<TData>`
contracts
- All `/// <inheritdoc />` usages in `MutationEngine` replaced with
explicit XML documentation matching `IMutationEngine` interface
- XML documentation added to all runtime components:
`MutationBatchExecutor`, `PolicyModificationApplier`,
`MutationAuditEntryFactory`, `StateSizeEstimator`
## Result
The runtime execution model is now organized by concern. Policy
evaluation is fully async with explicit timeout and cancellation
behavior. Side effect contracts are typed and survive persistence and
downstream integration scenarios. The execution namespace structure
matches the folder layout, aligning with `Runtime.Audit`,
`Runtime.Metrics`, and `Runtime.Policies` conventions.
## Testing
- dotnet build
- dotnet test
Tests/ModularityKit.Mutator.Tests/ModularityKit.Mutator.Tests.csproj
- dotnet test
Tests/ModularityKit.Mutator.Governance.Tests/ModularityKit.Mutator.Governance.Tests.csproj
- dotnet test
Tests/ModularityKit.Mutator.Governance.Redis.Tests/ModularityKit.Mutator.Governance.Redis.Tests.csproj
## Linked Issues
- Closes #23
- Closes #24
## Checklist
- [x] async policy evaluation path is implemented and tested
- [x] sync and async policy paths coexist without ambiguous semantics
- [x] typed side effect contract is introduced and integrated with
governance persistence
- [x] runtime namespace structure aligns with folder layout and existing
conventions
- [x] XML documentation added to all affected runtime components62 files changed
Lines changed: 2952 additions & 550 deletions
File tree
- Examples
- Core/WorkflowApprovals
- Contracts
- Mutations
- Scenarios
- Governance
- Queries/Scenarios
- RedisQueries/Scenarios
- Tests
- ModularityKit.Mutator.Governance.Redis.Tests/Serialization/Converters
- ModularityKit.Mutator.Governance.Tests
- Execution
- Queries
- ModularityKit.Mutator.Tests
- Effects
- Runtime
- src
- Abstractions
- Effects
- Exceptions
- Policies
- Governance
- Abstractions
- Queries/Model
- Approvals
- Decisions
- Requests
- Evaluation
- Matchers
- Filters
- Requests/Model
- Runtime
- Execution
- Orchestration
- Outcome
- Storage
- Persistence
- Queries/Materialization
- Reading
- Redis/Storage/Queries/Materialization
- Runtime
- Diagnostics
- Internal
- Evaluation
- Execution
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
Lines changed: 13 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
Lines changed: 13 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
Lines changed: 3 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
48 | 49 | | |
49 | 50 | | |
50 | 51 | | |
51 | | - | |
| 52 | + | |
52 | 53 | | |
53 | | - | |
| 54 | + | |
54 | 55 | | |
55 | 56 | | |
56 | 57 | | |
| |||
Lines changed: 3 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
54 | 55 | | |
55 | 56 | | |
56 | 57 | | |
57 | | - | |
| 58 | + | |
58 | 59 | | |
59 | | - | |
| 60 | + | |
60 | 61 | | |
61 | 62 | | |
62 | 63 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
70 | | - | |
| 70 | + | |
71 | 71 | | |
72 | 72 | | |
73 | 73 | | |
| |||
85 | 85 | | |
86 | 86 | | |
87 | 87 | | |
88 | | - | |
| 88 | + | |
89 | 89 | | |
90 | 90 | | |
91 | 91 | | |
| |||
135 | 135 | | |
136 | 136 | | |
137 | 137 | | |
138 | | - | |
| 138 | + | |
| 139 | + | |
139 | 140 | | |
140 | 141 | | |
141 | 142 | | |
| |||
Lines changed: 23 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
| 5 | + | |
4 | 6 | | |
5 | 7 | | |
6 | 8 | | |
| |||
12 | 14 | | |
13 | 15 | | |
14 | 16 | | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
15 | 20 | | |
16 | 21 | | |
17 | 22 | | |
| |||
51 | 56 | | |
52 | 57 | | |
53 | 58 | | |
54 | | - | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
55 | 76 | | |
56 | | - | |
| 77 | + | |
57 | 78 | | |
58 | 79 | | |
59 | 80 | | |
| |||
Lines changed: 17 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
| 2 | + | |
2 | 3 | | |
3 | 4 | | |
4 | 5 | | |
| |||
351 | 352 | | |
352 | 353 | | |
353 | 354 | | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
354 | 365 | | |
355 | 366 | | |
356 | 367 | | |
| |||
380 | 391 | | |
381 | 392 | | |
382 | 393 | | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
383 | 400 | | |
Lines changed: 10 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
55 | 55 | | |
56 | 56 | | |
57 | 57 | | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
58 | 68 | | |
59 | 69 | | |
60 | 70 | | |
| |||
Lines changed: 28 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| 11 | + | |
10 | 12 | | |
11 | 13 | | |
12 | 14 | | |
| |||
50 | 52 | | |
51 | 53 | | |
52 | 54 | | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
53 | 65 | | |
54 | 66 | | |
55 | 67 | | |
| |||
152 | 164 | | |
153 | 165 | | |
154 | 166 | | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
155 | 177 | | |
156 | 178 | | |
157 | 179 | | |
| |||
178 | 200 | | |
179 | 201 | | |
180 | 202 | | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
181 | 209 | | |
182 | 210 | | |
183 | 211 | | |
| |||
Lines changed: 23 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
| 2 | + | |
2 | 3 | | |
3 | 4 | | |
4 | 5 | | |
| |||
61 | 62 | | |
62 | 63 | | |
63 | 64 | | |
64 | | - | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
65 | 76 | | |
66 | 77 | | |
67 | 78 | | |
| |||
75 | 86 | | |
76 | 87 | | |
77 | 88 | | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
78 | 94 | | |
79 | 95 | | |
80 | 96 | | |
81 | 97 | | |
82 | 98 | | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
83 | 105 | | |
0 commit comments