@zigrivers/scaffold 3.16.0 → 3.17.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/README.md +28 -0
- package/content/knowledge/backend/backend-fintech-broker-integration.md +244 -0
- package/content/knowledge/backend/backend-fintech-compliance.md +181 -0
- package/content/knowledge/backend/backend-fintech-data-modeling.md +210 -0
- package/content/knowledge/backend/backend-fintech-ledger.md +226 -0
- package/content/knowledge/backend/backend-fintech-observability.md +151 -0
- package/content/knowledge/backend/backend-fintech-order-lifecycle.md +213 -0
- package/content/knowledge/backend/backend-fintech-risk-management.md +150 -0
- package/content/knowledge/backend/backend-fintech-testing.md +197 -0
- package/content/knowledge/core/automated-review-tooling.md +10 -0
- package/content/knowledge/core/multi-service-api-contracts.md +634 -0
- package/content/knowledge/core/multi-service-architecture.md +492 -0
- package/content/knowledge/core/multi-service-auth.md +706 -0
- package/content/knowledge/core/multi-service-data-ownership.md +539 -0
- package/content/knowledge/core/multi-service-observability.md +545 -0
- package/content/knowledge/core/multi-service-resilience.md +710 -0
- package/content/knowledge/core/multi-service-task-decomposition.md +615 -0
- package/content/knowledge/core/multi-service-testing.md +728 -0
- package/content/methodology/backend-fintech.yml +46 -0
- package/content/methodology/custom-defaults.yml +6 -0
- package/content/methodology/deep.yml +6 -0
- package/content/methodology/multi-service-overlay.yml +103 -0
- package/content/methodology/mvp.yml +6 -0
- package/content/pipeline/architecture/service-ownership-map.md +83 -0
- package/content/pipeline/quality/cross-service-auth.md +96 -0
- package/content/pipeline/quality/cross-service-observability.md +104 -0
- package/content/pipeline/quality/integration-test-plan.md +106 -0
- package/content/pipeline/specification/inter-service-contracts.md +95 -0
- package/dist/cli/commands/adopt.cli-flags.test.js +20 -0
- package/dist/cli/commands/adopt.cli-flags.test.js.map +1 -1
- package/dist/cli/commands/adopt.d.ts.map +1 -1
- package/dist/cli/commands/adopt.js +11 -3
- package/dist/cli/commands/adopt.js.map +1 -1
- package/dist/cli/commands/complete.d.ts +1 -0
- package/dist/cli/commands/complete.d.ts.map +1 -1
- package/dist/cli/commands/complete.js +26 -8
- package/dist/cli/commands/complete.js.map +1 -1
- package/dist/cli/commands/dashboard.d.ts +1 -0
- package/dist/cli/commands/dashboard.d.ts.map +1 -1
- package/dist/cli/commands/dashboard.js +19 -6
- package/dist/cli/commands/dashboard.js.map +1 -1
- package/dist/cli/commands/decisions.d.ts +1 -0
- package/dist/cli/commands/decisions.d.ts.map +1 -1
- package/dist/cli/commands/decisions.js +18 -4
- package/dist/cli/commands/decisions.js.map +1 -1
- package/dist/cli/commands/info.d.ts +1 -0
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +25 -3
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init-from.test.d.ts +2 -0
- package/dist/cli/commands/init-from.test.d.ts.map +1 -0
- package/dist/cli/commands/init-from.test.js +315 -0
- package/dist/cli/commands/init-from.test.js.map +1 -0
- package/dist/cli/commands/init.d.ts +3 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +239 -129
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/init.test.js +20 -0
- package/dist/cli/commands/init.test.js.map +1 -1
- package/dist/cli/commands/next.d.ts +1 -0
- package/dist/cli/commands/next.d.ts.map +1 -1
- package/dist/cli/commands/next.js +40 -4
- package/dist/cli/commands/next.js.map +1 -1
- package/dist/cli/commands/next.test.js +151 -0
- package/dist/cli/commands/next.test.js.map +1 -1
- package/dist/cli/commands/reset.d.ts +1 -0
- package/dist/cli/commands/reset.d.ts.map +1 -1
- package/dist/cli/commands/reset.js +77 -29
- package/dist/cli/commands/reset.js.map +1 -1
- package/dist/cli/commands/rework.d.ts +1 -0
- package/dist/cli/commands/rework.d.ts.map +1 -1
- package/dist/cli/commands/rework.js +16 -2
- package/dist/cli/commands/rework.js.map +1 -1
- package/dist/cli/commands/run.d.ts +1 -0
- package/dist/cli/commands/run.d.ts.map +1 -1
- package/dist/cli/commands/run.js +65 -13
- package/dist/cli/commands/run.js.map +1 -1
- package/dist/cli/commands/run.test.js +192 -3
- package/dist/cli/commands/run.test.js.map +1 -1
- package/dist/cli/commands/skip.d.ts +1 -0
- package/dist/cli/commands/skip.d.ts.map +1 -1
- package/dist/cli/commands/skip.js +24 -7
- package/dist/cli/commands/skip.js.map +1 -1
- package/dist/cli/commands/status.d.ts +1 -0
- package/dist/cli/commands/status.d.ts.map +1 -1
- package/dist/cli/commands/status.js +51 -4
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/commands/status.test.js +128 -0
- package/dist/cli/commands/status.test.js.map +1 -1
- package/dist/cli/guards-coverage.test.d.ts +2 -0
- package/dist/cli/guards-coverage.test.d.ts.map +1 -0
- package/dist/cli/guards-coverage.test.js +26 -0
- package/dist/cli/guards-coverage.test.js.map +1 -0
- package/dist/cli/guards-integration.test.d.ts +2 -0
- package/dist/cli/guards-integration.test.d.ts.map +1 -0
- package/dist/cli/guards-integration.test.js +178 -0
- package/dist/cli/guards-integration.test.js.map +1 -0
- package/dist/cli/guards.d.ts +13 -0
- package/dist/cli/guards.d.ts.map +1 -0
- package/dist/cli/guards.js +70 -0
- package/dist/cli/guards.js.map +1 -0
- package/dist/cli/guards.test.d.ts +2 -0
- package/dist/cli/guards.test.d.ts.map +1 -0
- package/dist/cli/guards.test.js +136 -0
- package/dist/cli/guards.test.js.map +1 -0
- package/dist/cli/init-flag-families.d.ts +1 -1
- package/dist/cli/init-flag-families.d.ts.map +1 -1
- package/dist/cli/init-flag-families.js +4 -1
- package/dist/cli/init-flag-families.js.map +1 -1
- package/dist/cli/init-flag-families.test.js +10 -0
- package/dist/cli/init-flag-families.test.js.map +1 -1
- package/dist/cli/shutdown.d.ts +2 -3
- package/dist/cli/shutdown.d.ts.map +1 -1
- package/dist/cli/shutdown.js +14 -11
- package/dist/cli/shutdown.js.map +1 -1
- package/dist/cli/shutdown.test.js +2 -4
- package/dist/cli/shutdown.test.js.map +1 -1
- package/dist/config/schema.d.ts +12122 -288
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +74 -79
- package/dist/config/schema.js.map +1 -1
- package/dist/config/schema.test.js +230 -1
- package/dist/config/schema.test.js.map +1 -1
- package/dist/config/validators/backend.d.ts +4 -0
- package/dist/config/validators/backend.d.ts.map +1 -0
- package/dist/config/validators/backend.js +14 -0
- package/dist/config/validators/backend.js.map +1 -0
- package/dist/config/validators/browser-extension.d.ts +4 -0
- package/dist/config/validators/browser-extension.d.ts.map +1 -0
- package/dist/config/validators/browser-extension.js +24 -0
- package/dist/config/validators/browser-extension.js.map +1 -0
- package/dist/config/validators/cli.d.ts +4 -0
- package/dist/config/validators/cli.d.ts.map +1 -0
- package/dist/config/validators/cli.js +14 -0
- package/dist/config/validators/cli.js.map +1 -0
- package/dist/config/validators/data-pipeline.d.ts +4 -0
- package/dist/config/validators/data-pipeline.d.ts.map +1 -0
- package/dist/config/validators/data-pipeline.js +14 -0
- package/dist/config/validators/data-pipeline.js.map +1 -0
- package/dist/config/validators/game.d.ts +4 -0
- package/dist/config/validators/game.d.ts.map +1 -0
- package/dist/config/validators/game.js +14 -0
- package/dist/config/validators/game.js.map +1 -0
- package/dist/config/validators/index.d.ts +7 -0
- package/dist/config/validators/index.d.ts.map +1 -0
- package/dist/config/validators/index.js +27 -0
- package/dist/config/validators/index.js.map +1 -0
- package/dist/config/validators/library.d.ts +4 -0
- package/dist/config/validators/library.d.ts.map +1 -0
- package/dist/config/validators/library.js +25 -0
- package/dist/config/validators/library.js.map +1 -0
- package/dist/config/validators/ml.d.ts +4 -0
- package/dist/config/validators/ml.d.ts.map +1 -0
- package/dist/config/validators/ml.js +31 -0
- package/dist/config/validators/ml.js.map +1 -0
- package/dist/config/validators/mobile-app.d.ts +4 -0
- package/dist/config/validators/mobile-app.d.ts.map +1 -0
- package/dist/config/validators/mobile-app.js +14 -0
- package/dist/config/validators/mobile-app.js.map +1 -0
- package/dist/config/validators/registry.test.d.ts +2 -0
- package/dist/config/validators/registry.test.d.ts.map +1 -0
- package/dist/config/validators/registry.test.js +26 -0
- package/dist/config/validators/registry.test.js.map +1 -0
- package/dist/config/validators/research.d.ts +4 -0
- package/dist/config/validators/research.d.ts.map +1 -0
- package/dist/config/validators/research.js +24 -0
- package/dist/config/validators/research.js.map +1 -0
- package/dist/config/validators/research.test.d.ts +2 -0
- package/dist/config/validators/research.test.d.ts.map +1 -0
- package/dist/config/validators/research.test.js +44 -0
- package/dist/config/validators/research.test.js.map +1 -0
- package/dist/config/validators/types.d.ts +19 -0
- package/dist/config/validators/types.d.ts.map +1 -0
- package/dist/config/validators/types.js +2 -0
- package/dist/config/validators/types.js.map +1 -0
- package/dist/config/validators/validators.test.d.ts +2 -0
- package/dist/config/validators/validators.test.d.ts.map +1 -0
- package/dist/config/validators/validators.test.js +25 -0
- package/dist/config/validators/validators.test.js.map +1 -0
- package/dist/config/validators/web-app.d.ts +4 -0
- package/dist/config/validators/web-app.d.ts.map +1 -0
- package/dist/config/validators/web-app.js +31 -0
- package/dist/config/validators/web-app.js.map +1 -0
- package/dist/core/assembly/context-gatherer.d.ts.map +1 -1
- package/dist/core/assembly/context-gatherer.js +4 -2
- package/dist/core/assembly/context-gatherer.js.map +1 -1
- package/dist/core/assembly/cross-reads.d.ts +58 -0
- package/dist/core/assembly/cross-reads.d.ts.map +1 -0
- package/dist/core/assembly/cross-reads.js +185 -0
- package/dist/core/assembly/cross-reads.js.map +1 -0
- package/dist/core/assembly/cross-reads.test.d.ts +2 -0
- package/dist/core/assembly/cross-reads.test.d.ts.map +1 -0
- package/dist/core/assembly/cross-reads.test.js +383 -0
- package/dist/core/assembly/cross-reads.test.js.map +1 -0
- package/dist/core/assembly/overlay-loader-structural.test.d.ts +2 -0
- package/dist/core/assembly/overlay-loader-structural.test.d.ts.map +1 -0
- package/dist/core/assembly/overlay-loader-structural.test.js +114 -0
- package/dist/core/assembly/overlay-loader-structural.test.js.map +1 -0
- package/dist/core/assembly/overlay-loader.d.ts +17 -3
- package/dist/core/assembly/overlay-loader.d.ts.map +1 -1
- package/dist/core/assembly/overlay-loader.js +75 -0
- package/dist/core/assembly/overlay-loader.js.map +1 -1
- package/dist/core/assembly/overlay-resolver.d.ts +2 -2
- package/dist/core/assembly/overlay-resolver.d.ts.map +1 -1
- package/dist/core/assembly/overlay-resolver.js.map +1 -1
- package/dist/core/assembly/overlay-resolver.test.js.map +1 -1
- package/dist/core/assembly/overlay-state-resolver.d.ts +5 -0
- package/dist/core/assembly/overlay-state-resolver.d.ts.map +1 -1
- package/dist/core/assembly/overlay-state-resolver.js +41 -1
- package/dist/core/assembly/overlay-state-resolver.js.map +1 -1
- package/dist/core/assembly/overlay-state-resolver.test.js +262 -0
- package/dist/core/assembly/overlay-state-resolver.test.js.map +1 -1
- package/dist/core/assembly/update-mode.d.ts +1 -0
- package/dist/core/assembly/update-mode.d.ts.map +1 -1
- package/dist/core/assembly/update-mode.js +17 -9
- package/dist/core/assembly/update-mode.js.map +1 -1
- package/dist/core/dependency/eligibility.d.ts +10 -1
- package/dist/core/dependency/eligibility.d.ts.map +1 -1
- package/dist/core/dependency/eligibility.js +19 -1
- package/dist/core/dependency/eligibility.js.map +1 -1
- package/dist/core/dependency/eligibility.test.js +82 -0
- package/dist/core/dependency/eligibility.test.js.map +1 -1
- package/dist/core/dependency/graph.d.ts +4 -1
- package/dist/core/dependency/graph.d.ts.map +1 -1
- package/dist/core/dependency/graph.js +7 -1
- package/dist/core/dependency/graph.js.map +1 -1
- package/dist/core/dependency/graph.test.js +29 -0
- package/dist/core/dependency/graph.test.js.map +1 -1
- package/dist/core/pipeline/global-steps.d.ts +7 -0
- package/dist/core/pipeline/global-steps.d.ts.map +1 -0
- package/dist/core/pipeline/global-steps.js +18 -0
- package/dist/core/pipeline/global-steps.js.map +1 -0
- package/dist/core/pipeline/resolver.d.ts +1 -0
- package/dist/core/pipeline/resolver.d.ts.map +1 -1
- package/dist/core/pipeline/resolver.js +51 -6
- package/dist/core/pipeline/resolver.js.map +1 -1
- package/dist/core/pipeline/types.d.ts +5 -1
- package/dist/core/pipeline/types.d.ts.map +1 -1
- package/dist/e2e/cross-service-references.test.d.ts +22 -0
- package/dist/e2e/cross-service-references.test.d.ts.map +1 -0
- package/dist/e2e/cross-service-references.test.js +188 -0
- package/dist/e2e/cross-service-references.test.js.map +1 -0
- package/dist/e2e/multi-service-pipeline.test.d.ts +10 -0
- package/dist/e2e/multi-service-pipeline.test.d.ts.map +1 -0
- package/dist/e2e/multi-service-pipeline.test.js +185 -0
- package/dist/e2e/multi-service-pipeline.test.js.map +1 -0
- package/dist/e2e/project-type-overlays.test.js +68 -0
- package/dist/e2e/project-type-overlays.test.js.map +1 -1
- package/dist/e2e/service-execution.test.d.ts +15 -0
- package/dist/e2e/service-execution.test.d.ts.map +1 -0
- package/dist/e2e/service-execution.test.js +219 -0
- package/dist/e2e/service-execution.test.js.map +1 -0
- package/dist/e2e/service-manifest.test.d.ts +19 -0
- package/dist/e2e/service-manifest.test.d.ts.map +1 -0
- package/dist/e2e/service-manifest.test.js +166 -0
- package/dist/e2e/service-manifest.test.js.map +1 -0
- package/dist/project/__frozen-schemas__/schema-v3.9.2.d.ts +224 -224
- package/dist/project/frontmatter.d.ts.map +1 -1
- package/dist/project/frontmatter.js +11 -0
- package/dist/project/frontmatter.js.map +1 -1
- package/dist/project/frontmatter.test.js +71 -0
- package/dist/project/frontmatter.test.js.map +1 -1
- package/dist/state/completion.d.ts +1 -1
- package/dist/state/completion.d.ts.map +1 -1
- package/dist/state/completion.js +10 -8
- package/dist/state/completion.js.map +1 -1
- package/dist/state/decision-logger.d.ts +3 -2
- package/dist/state/decision-logger.d.ts.map +1 -1
- package/dist/state/decision-logger.js +12 -11
- package/dist/state/decision-logger.js.map +1 -1
- package/dist/state/ensure-v3-migration.d.ts +9 -0
- package/dist/state/ensure-v3-migration.d.ts.map +1 -0
- package/dist/state/ensure-v3-migration.js +35 -0
- package/dist/state/ensure-v3-migration.js.map +1 -0
- package/dist/state/lock-manager.d.ts +5 -4
- package/dist/state/lock-manager.d.ts.map +1 -1
- package/dist/state/lock-manager.js +11 -11
- package/dist/state/lock-manager.js.map +1 -1
- package/dist/state/rework-manager.d.ts +1 -2
- package/dist/state/rework-manager.d.ts.map +1 -1
- package/dist/state/rework-manager.js +4 -5
- package/dist/state/rework-manager.js.map +1 -1
- package/dist/state/state-manager.d.ts +25 -1
- package/dist/state/state-manager.d.ts.map +1 -1
- package/dist/state/state-manager.js +86 -12
- package/dist/state/state-manager.js.map +1 -1
- package/dist/state/state-manager.test.js +278 -0
- package/dist/state/state-manager.test.js.map +1 -1
- package/dist/state/state-migration-v3.d.ts +22 -0
- package/dist/state/state-migration-v3.d.ts.map +1 -0
- package/dist/state/state-migration-v3.js +82 -0
- package/dist/state/state-migration-v3.js.map +1 -0
- package/dist/state/state-migration-v3.test.d.ts +2 -0
- package/dist/state/state-migration-v3.test.d.ts.map +1 -0
- package/dist/state/state-migration-v3.test.js +196 -0
- package/dist/state/state-migration-v3.test.js.map +1 -0
- package/dist/state/state-migration.d.ts.map +1 -1
- package/dist/state/state-migration.js +11 -6
- package/dist/state/state-migration.js.map +1 -1
- package/dist/state/state-migration.test.js +47 -2
- package/dist/state/state-migration.test.js.map +1 -1
- package/dist/state/state-path-resolver.d.ts +23 -0
- package/dist/state/state-path-resolver.d.ts.map +1 -0
- package/dist/state/state-path-resolver.js +36 -0
- package/dist/state/state-path-resolver.js.map +1 -0
- package/dist/state/state-path-resolver.test.d.ts +2 -0
- package/dist/state/state-path-resolver.test.d.ts.map +1 -0
- package/dist/state/state-path-resolver.test.js +78 -0
- package/dist/state/state-path-resolver.test.js.map +1 -0
- package/dist/state/state-version-dispatch.d.ts +17 -0
- package/dist/state/state-version-dispatch.d.ts.map +1 -0
- package/dist/state/state-version-dispatch.js +27 -0
- package/dist/state/state-version-dispatch.js.map +1 -0
- package/dist/state/state-version-dispatch.test.d.ts +2 -0
- package/dist/state/state-version-dispatch.test.d.ts.map +1 -0
- package/dist/state/state-version-dispatch.test.js +40 -0
- package/dist/state/state-version-dispatch.test.js.map +1 -0
- package/dist/types/config.d.ts +25 -3
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.test.js +13 -1
- package/dist/types/config.test.js.map +1 -1
- package/dist/types/dependency.d.ts +5 -0
- package/dist/types/dependency.d.ts.map +1 -1
- package/dist/types/frontmatter.d.ts +5 -0
- package/dist/types/frontmatter.d.ts.map +1 -1
- package/dist/types/lock.d.ts +1 -1
- package/dist/types/lock.d.ts.map +1 -1
- package/dist/types/state.d.ts +1 -1
- package/dist/types/state.d.ts.map +1 -1
- package/dist/utils/artifact-path.d.ts +19 -0
- package/dist/utils/artifact-path.d.ts.map +1 -0
- package/dist/utils/artifact-path.js +95 -0
- package/dist/utils/artifact-path.js.map +1 -0
- package/dist/utils/artifact-path.test.d.ts +2 -0
- package/dist/utils/artifact-path.test.d.ts.map +1 -0
- package/dist/utils/artifact-path.test.js +138 -0
- package/dist/utils/artifact-path.test.js.map +1 -0
- package/dist/utils/errors.d.ts +1 -1
- package/dist/utils/errors.d.ts.map +1 -1
- package/dist/utils/errors.js +5 -2
- package/dist/utils/errors.js.map +1 -1
- package/dist/utils/user-errors.d.ts +46 -0
- package/dist/utils/user-errors.d.ts.map +1 -0
- package/dist/utils/user-errors.js +76 -0
- package/dist/utils/user-errors.js.map +1 -0
- package/dist/utils/user-errors.test.d.ts +2 -0
- package/dist/utils/user-errors.test.d.ts.map +1 -0
- package/dist/utils/user-errors.test.js +74 -0
- package/dist/utils/user-errors.test.js.map +1 -0
- package/dist/validation/index.d.ts.map +1 -1
- package/dist/validation/index.js +16 -0
- package/dist/validation/index.js.map +1 -1
- package/dist/validation/index.test.js +48 -0
- package/dist/validation/index.test.js.map +1 -1
- package/dist/validation/state-validator.d.ts +5 -2
- package/dist/validation/state-validator.d.ts.map +1 -1
- package/dist/validation/state-validator.js +18 -20
- package/dist/validation/state-validator.js.map +1 -1
- package/dist/validation/state-validator.test.js +31 -2
- package/dist/validation/state-validator.test.js.map +1 -1
- package/dist/wizard/copy/backend.d.ts.map +1 -1
- package/dist/wizard/copy/backend.js +12 -0
- package/dist/wizard/copy/backend.js.map +1 -1
- package/dist/wizard/flags.d.ts +1 -0
- package/dist/wizard/flags.d.ts.map +1 -1
- package/dist/wizard/questions.d.ts.map +1 -1
- package/dist/wizard/questions.js +5 -1
- package/dist/wizard/questions.js.map +1 -1
- package/dist/wizard/questions.test.js +45 -2
- package/dist/wizard/questions.test.js.map +1 -1
- package/dist/wizard/wizard.d.ts +23 -0
- package/dist/wizard/wizard.d.ts.map +1 -1
- package/dist/wizard/wizard.js +85 -47
- package/dist/wizard/wizard.js.map +1 -1
- package/dist/wizard/wizard.test.js +186 -1
- package/dist/wizard/wizard.test.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { researchCouplingValidator } from './research.js';
|
|
4
|
+
describe('researchCouplingValidator — intra-type rules', () => {
|
|
5
|
+
it('rejects notebook-driven + autonomous combination', () => {
|
|
6
|
+
const schema = z.object({}).superRefine((_, ctx) => {
|
|
7
|
+
researchCouplingValidator.validate(ctx, [], 'research', {
|
|
8
|
+
experimentDriver: 'notebook-driven',
|
|
9
|
+
interactionMode: 'autonomous',
|
|
10
|
+
hasExperimentTracking: true,
|
|
11
|
+
domain: 'none',
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
const result = schema.safeParse({});
|
|
15
|
+
expect(result.success).toBe(false);
|
|
16
|
+
if (!result.success) {
|
|
17
|
+
expect(result.error.issues[0].path).toEqual(['researchConfig', 'interactionMode']);
|
|
18
|
+
expect(result.error.issues[0].message).toMatch(/notebook-driven/i);
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
it('allows notebook-driven + checkpoint-gated combination', () => {
|
|
22
|
+
const schema = z.object({}).superRefine((_, ctx) => {
|
|
23
|
+
researchCouplingValidator.validate(ctx, [], 'research', {
|
|
24
|
+
experimentDriver: 'notebook-driven',
|
|
25
|
+
interactionMode: 'checkpoint-gated',
|
|
26
|
+
hasExperimentTracking: true,
|
|
27
|
+
domain: 'none',
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
expect(schema.safeParse({}).success).toBe(true);
|
|
31
|
+
});
|
|
32
|
+
it('allows code-driven + autonomous combination', () => {
|
|
33
|
+
const schema = z.object({}).superRefine((_, ctx) => {
|
|
34
|
+
researchCouplingValidator.validate(ctx, [], 'research', {
|
|
35
|
+
experimentDriver: 'code-driven',
|
|
36
|
+
interactionMode: 'autonomous',
|
|
37
|
+
hasExperimentTracking: true,
|
|
38
|
+
domain: 'none',
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
expect(schema.safeParse({}).success).toBe(true);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
//# sourceMappingURL=research.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"research.test.js","sourceRoot":"","sources":["../../../src/config/validators/research.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AACvB,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAA;AAEzD,QAAQ,CAAC,8CAA8C,EAAE,GAAG,EAAE;IAC5D,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACjD,yBAAyB,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,EAAE,UAAU,EAAE;gBACtD,gBAAgB,EAAE,iBAAiB;gBACnC,eAAe,EAAE,YAAY;gBAC7B,qBAAqB,EAAE,IAAI;gBAC3B,MAAM,EAAE,MAAM;aACf,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACnC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAClC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,CAAC,CAAA;YAClF,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAA;QACpE,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACjD,yBAAyB,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,EAAE,UAAU,EAAE;gBACtD,gBAAgB,EAAE,iBAAiB;gBACnC,eAAe,EAAE,kBAAkB;gBACnC,qBAAqB,EAAE,IAAI;gBAC3B,MAAM,EAAE,MAAM;aACf,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QACF,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACjD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACjD,yBAAyB,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,EAAE,UAAU,EAAE;gBACtD,gBAAgB,EAAE,aAAa;gBAC/B,eAAe,EAAE,YAAY;gBAC7B,qBAAqB,EAAE,IAAI;gBAC3B,MAAM,EAAE,MAAM;aACf,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QACF,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACjD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { z } from 'zod';
|
|
2
|
+
import type { ProjectType } from '../../types/config.js';
|
|
3
|
+
/**
|
|
4
|
+
* A coupling validator encapsulates the rules that relate a given project
|
|
5
|
+
* type's per-type config to the `projectType` value. Used by both
|
|
6
|
+
* `ProjectSchema.superRefine` and `ServiceSchema.superRefine` via the
|
|
7
|
+
* registry at `src/config/validators/index.ts`.
|
|
8
|
+
*
|
|
9
|
+
* Preserves the existing asymmetric rule: a config set without the matching
|
|
10
|
+
* projectType is an error; projectType set without the matching config is
|
|
11
|
+
* NOT an error in root ProjectSchema (see ServiceSchema for the forward
|
|
12
|
+
* rule).
|
|
13
|
+
*/
|
|
14
|
+
export interface CouplingValidator<T> {
|
|
15
|
+
readonly configKey: string;
|
|
16
|
+
readonly projectType: ProjectType;
|
|
17
|
+
validate(ctx: z.RefinementCtx, path: (string | number)[], projectType: ProjectType | undefined, config: T | undefined): void;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/config/validators/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAC5B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAExD;;;;;;;;;;GAUG;AACH,MAAM,WAAW,iBAAiB,CAAC,CAAC;IAClC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAA;IAC1B,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAA;IACjC,QAAQ,CACN,GAAG,EAAE,CAAC,CAAC,aAAa,EACpB,IAAI,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,EACzB,WAAW,EAAE,WAAW,GAAG,SAAS,EACpC,MAAM,EAAE,CAAC,GAAG,SAAS,GACpB,IAAI,CAAA;CACR"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/config/validators/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.test.d.ts","sourceRoot":"","sources":["../../../src/config/validators/validators.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { z } from 'zod';
|
|
3
|
+
import { ALL_COUPLING_VALIDATORS } from './index.js';
|
|
4
|
+
describe('coupling validators (parameterized)', () => {
|
|
5
|
+
it.each(ALL_COUPLING_VALIDATORS.map(v => [v.projectType, v]))('validator for %s emits no issue when config is absent (preserves current asymmetric behavior)', (_type, validator) => {
|
|
6
|
+
const schema = z.object({}).superRefine((_, ctx) => {
|
|
7
|
+
validator.validate(ctx, [], validator.projectType, undefined);
|
|
8
|
+
});
|
|
9
|
+
const result = schema.safeParse({});
|
|
10
|
+
expect(result.success).toBe(true);
|
|
11
|
+
});
|
|
12
|
+
it.each(ALL_COUPLING_VALIDATORS.map(v => [v.projectType, v]))('validator for %s emits coupling issue when config present with wrong projectType', (type, validator) => {
|
|
13
|
+
const schema = z.object({}).superRefine((_, ctx) => {
|
|
14
|
+
const wrongType = type === 'backend' ? 'web-app' : 'backend';
|
|
15
|
+
validator.validate(ctx, [], wrongType, {});
|
|
16
|
+
});
|
|
17
|
+
const result = schema.safeParse({});
|
|
18
|
+
expect(result.success).toBe(false);
|
|
19
|
+
if (!result.success) {
|
|
20
|
+
expect(result.error.issues[0].path).toEqual([validator.configKey]);
|
|
21
|
+
expect(result.error.issues[0].message).toContain(validator.projectType);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=validators.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.test.js","sourceRoot":"","sources":["../../../src/config/validators/validators.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AACvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAA;AAEpD,QAAQ,CAAC,qCAAqC,EAAE,GAAG,EAAE;IACnD,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAC3D,+FAA+F,EAC/F,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;QACnB,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACjD,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,EAAE,SAAS,CAAC,WAAW,EAAE,SAAS,CAAC,CAAA;QAC/D,CAAC,CAAC,CAAA;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACnC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACnC,CAAC,CACF,CAAA;IAED,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAC3D,kFAAkF,EAClF,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE;QAClB,MAAM,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACjD,MAAM,SAAS,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAA;YAC5D,SAAS,CAAC,QAAQ,CAChB,GAAG,EACH,EAAE,EACF,SAAkB,EAClB,EAAW,CACZ,CAAA;QACH,CAAC,CAAC,CAAA;QACF,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACnC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAClC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAA;YAClE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QACzE,CAAC;IACH,CAAC,CACF,CAAA;AACH,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"web-app.d.ts","sourceRoot":"","sources":["../../../src/config/validators/web-app.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AACnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AAEzD,eAAO,MAAM,uBAAuB,EAAE,iBAAiB,CAAC,YAAY,CA6BnE,CAAA"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export const webAppCouplingValidator = {
|
|
2
|
+
configKey: 'webAppConfig',
|
|
3
|
+
projectType: 'web-app',
|
|
4
|
+
validate(ctx, path, projectType, config) {
|
|
5
|
+
if (config !== undefined && projectType !== 'web-app') {
|
|
6
|
+
ctx.addIssue({
|
|
7
|
+
path: [...path, 'webAppConfig'],
|
|
8
|
+
code: 'custom',
|
|
9
|
+
message: 'webAppConfig requires projectType: web-app',
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
if (config) {
|
|
13
|
+
const { renderingStrategy, deployTarget, authFlow } = config;
|
|
14
|
+
if (['ssr', 'hybrid'].includes(renderingStrategy) && deployTarget === 'static') {
|
|
15
|
+
ctx.addIssue({
|
|
16
|
+
path: [...path, 'webAppConfig', 'deployTarget'],
|
|
17
|
+
code: 'custom',
|
|
18
|
+
message: 'SSR/hybrid rendering requires compute, not static hosting',
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
if (authFlow === 'session' && deployTarget === 'static') {
|
|
22
|
+
ctx.addIssue({
|
|
23
|
+
path: [...path, 'webAppConfig', 'authFlow'],
|
|
24
|
+
code: 'custom',
|
|
25
|
+
message: 'Session auth requires server state, incompatible with static hosting',
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=web-app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"web-app.js","sourceRoot":"","sources":["../../../src/config/validators/web-app.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,uBAAuB,GAAoC;IACtE,SAAS,EAAE,cAAc;IACzB,WAAW,EAAE,SAAS;IACtB,QAAQ,CAAC,GAAG,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM;QACrC,IAAI,MAAM,KAAK,SAAS,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;YACtD,GAAG,CAAC,QAAQ,CAAC;gBACX,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,cAAc,CAAC;gBAC/B,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,4CAA4C;aACtD,CAAC,CAAA;QACJ,CAAC;QACD,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,EAAE,iBAAiB,EAAE,YAAY,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAA;YAC5D,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,YAAY,KAAK,QAAQ,EAAE,CAAC;gBAC/E,GAAG,CAAC,QAAQ,CAAC;oBACX,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,cAAc,EAAE,cAAc,CAAC;oBAC/C,IAAI,EAAE,QAAQ;oBACd,OAAO,EAAE,2DAA2D;iBACrE,CAAC,CAAA;YACJ,CAAC;YACD,IAAI,QAAQ,KAAK,SAAS,IAAI,YAAY,KAAK,QAAQ,EAAE,CAAC;gBACxD,GAAG,CAAC,QAAQ,CAAC;oBACX,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,cAAc,EAAE,UAAU,CAAC;oBAC3C,IAAI,EAAE,QAAQ;oBACd,OAAO,EAAE,sEAAsE;iBAChF,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-gatherer.d.ts","sourceRoot":"","sources":["../../../src/core/assembly/context-gatherer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAiB,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AAC3F,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAiB,MAAM,sBAAsB,CAAA;AAOxF;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE;IACrC,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,aAAa,CAAA;IACpB,MAAM,EAAE,cAAc,CAAA;IACtB,WAAW,EAAE,MAAM,CAAA;IACnB,qEAAqE;IACrE,eAAe,EAAE,MAAM,EAAE,CAAA;IACzB,iDAAiD;IACjD,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC,GAAG,cAAc,
|
|
1
|
+
{"version":3,"file":"context-gatherer.d.ts","sourceRoot":"","sources":["../../../src/core/assembly/context-gatherer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAiB,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AAC3F,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAiB,MAAM,sBAAsB,CAAA;AAOxF;;;GAGG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE;IACrC,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,aAAa,CAAA;IACpB,MAAM,EAAE,cAAc,CAAA;IACtB,WAAW,EAAE,MAAM,CAAA;IACnB,qEAAqE;IACrE,eAAe,EAAE,MAAM,EAAE,CAAA;IACzB,iDAAiD;IACjD,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC,GAAG,cAAc,CAsCjB"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { fileExists } from '../../utils/fs.js';
|
|
2
2
|
import { readDecisions } from '../../state/decision-logger.js';
|
|
3
3
|
import { resolveArtifactPath } from '../../state/state-migration.js';
|
|
4
|
+
import { resolveContainedArtifactPath } from '../../utils/artifact-path.js';
|
|
4
5
|
import fs from 'node:fs';
|
|
5
|
-
import path from 'node:path';
|
|
6
6
|
/**
|
|
7
7
|
* Gather project context for assembly.
|
|
8
8
|
* Collects artifacts from dependency chain + reads, config, state, decisions.
|
|
@@ -19,7 +19,9 @@ export function gatherContext(options) {
|
|
|
19
19
|
for (const outputPath of produces) {
|
|
20
20
|
// Resolve aliased paths (e.g., docs/prd.md ↔ docs/plan.md)
|
|
21
21
|
const resolvedPath = resolveArtifactPath(projectRoot, outputPath);
|
|
22
|
-
const fullPath =
|
|
22
|
+
const fullPath = resolveContainedArtifactPath(projectRoot, resolvedPath);
|
|
23
|
+
if (fullPath === null)
|
|
24
|
+
continue; // path escapes project root — skip silently
|
|
23
25
|
if (fileExists(fullPath)) {
|
|
24
26
|
try {
|
|
25
27
|
const content = fs.readFileSync(fullPath, 'utf8');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context-gatherer.js","sourceRoot":"","sources":["../../../src/core/assembly/context-gatherer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAA;AACpE,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"context-gatherer.js","sourceRoot":"","sources":["../../../src/core/assembly/context-gatherer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAA;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAA;AACpE,OAAO,EAAE,4BAA4B,EAAE,MAAM,8BAA8B,CAAA;AAC3E,OAAO,EAAE,MAAM,SAAS,CAAA;AAExB;;;GAGG;AACH,MAAM,UAAU,aAAa,CAAC,OAS7B;IACC,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAA;IAEjF,kDAAkD;IAClD,MAAM,SAAS,GAAoB,EAAE,CAAA;IACrC,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE,CAAC;QACtC,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QACtC,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,WAAW;YAAE,SAAQ;QAC5D,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,IAAI,EAAE,CAAA;QACzC,KAAK,MAAM,UAAU,IAAI,QAAQ,EAAE,CAAC;YAClC,2DAA2D;YAC3D,MAAM,YAAY,GAAG,mBAAmB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAA;YACjE,MAAM,QAAQ,GAAG,4BAA4B,CAAC,WAAW,EAAE,YAAY,CAAC,CAAA;YACxE,IAAI,QAAQ,KAAK,IAAI;gBAAE,SAAQ,CAAC,4CAA4C;YAC5E,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACzB,IAAI,CAAC;oBACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAA;oBACjD,SAAS,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAE,CAAC,CAAA;gBACxE,CAAC;gBAAC,MAAM,CAAC;oBACP,0DAA0D;gBAC5D,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,yCAAyC;IACzC,MAAM,eAAe,GAAG,aAAa,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAA;IACvE,4DAA4D;IAC5D,MAAM,iBAAiB,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;IACzF,MAAM,SAAS,GAAG,eAAe,CAAC,iBAAiB,CAAC,CAAA;IAEpD,OAAO;QACL,SAAS;QACT,MAAM;QACN,KAAK;QACL,SAAS;QACT,cAAc,EAAE,gBAAgB;KACjC,CAAA;AACH,CAAC;AAED,SAAS,eAAe,CAAC,OAAwB;IAC/C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAA;IACnC,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AAC5E,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import type { ScaffoldConfig, PipelineState, ArtifactEntry, MetaPromptFile } from '../../types/index.js';
|
|
2
|
+
import type { OutputContext } from '../../cli/output/context.js';
|
|
3
|
+
/**
|
|
4
|
+
* Resolve a single cross-read against a foreign service's state, with allowlist
|
|
5
|
+
* check, per-service state cache, path containment, warning symmetry with the
|
|
6
|
+
* existing `reads` loop in run.ts, and an optional runtime global-step guard.
|
|
7
|
+
*
|
|
8
|
+
* Returns { completed, artifacts } so transitive callers can gate recursion on
|
|
9
|
+
* step completion rather than artifact count (aggregator steps may produce no
|
|
10
|
+
* artifacts of their own but still have valid transitive cross-reads).
|
|
11
|
+
*/
|
|
12
|
+
export declare function resolveDirectCrossRead(cr: {
|
|
13
|
+
service: string;
|
|
14
|
+
step: string;
|
|
15
|
+
}, config: ScaffoldConfig, projectRoot: string, output: OutputContext, foreignStateCache: Map<string, PipelineState | null>, globalSteps?: Set<string>): {
|
|
16
|
+
completed: boolean;
|
|
17
|
+
artifacts: ArtifactEntry[];
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* DFS-driven transitive cross-reads resolver with:
|
|
21
|
+
* - cycle detection via `visiting` set (gray nodes),
|
|
22
|
+
* - memoization via `resolved` map (black nodes) caching the FULL closure per service:step,
|
|
23
|
+
* - per-service foreign-state cache via `foreignStateCache`,
|
|
24
|
+
* - per-traversal dedup via a local Map<filePath, entry>,
|
|
25
|
+
* - skips foreign meta of category: 'tool' for transitive lookup.
|
|
26
|
+
*
|
|
27
|
+
* Gates transitive recursion on `direct.completed` (not artifact count) so
|
|
28
|
+
* aggregator steps with empty `produces` still participate in the chain.
|
|
29
|
+
*/
|
|
30
|
+
export declare function resolveTransitiveCrossReads(crossReads: Array<{
|
|
31
|
+
service: string;
|
|
32
|
+
step: string;
|
|
33
|
+
}>, config: ScaffoldConfig, projectRoot: string, metaPrompts: Map<string, MetaPromptFile>, output: OutputContext, visiting: Set<string>, resolved: Map<string, ArtifactEntry[]>, foreignStateCache: Map<string, PipelineState | null>, globalSteps?: Set<string>): ArtifactEntry[];
|
|
34
|
+
export type CrossReadStatus = 'completed' | 'pending' | 'not-bootstrapped' | 'read-error' | 'service-unknown' | 'not-exported';
|
|
35
|
+
/** Human-facing rendering of CrossReadStatus for text display in next/status. */
|
|
36
|
+
export declare function humanCrossReadStatus(status: CrossReadStatus): string;
|
|
37
|
+
export interface CrossReadReadiness {
|
|
38
|
+
service: string;
|
|
39
|
+
step: string;
|
|
40
|
+
status: CrossReadStatus;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Compute readiness status for a list of cross-reads. Shared by `next --service`
|
|
44
|
+
* and `status --service` so both commands surface identical diagnostics.
|
|
45
|
+
* Uses a per-call Map cache to avoid re-reading the same foreign state file.
|
|
46
|
+
*/
|
|
47
|
+
/**
|
|
48
|
+
* Internal sentinel distinguishing "foreign file missing" from "foreign file
|
|
49
|
+
* exists but failed to load". `null` = not-bootstrapped (no state.json);
|
|
50
|
+
* `'read-error'` = state.json existed but parse/validation failed.
|
|
51
|
+
*/
|
|
52
|
+
type ForeignStateCacheEntry = PipelineState | null | 'read-error';
|
|
53
|
+
export declare function resolveCrossReadReadiness(crossReads: Array<{
|
|
54
|
+
service: string;
|
|
55
|
+
step: string;
|
|
56
|
+
}>, config: ScaffoldConfig, projectRoot: string, globalSteps?: Set<string>, cache?: Map<string, ForeignStateCacheEntry>): CrossReadReadiness[];
|
|
57
|
+
export {};
|
|
58
|
+
//# sourceMappingURL=cross-reads.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cross-reads.d.ts","sourceRoot":"","sources":["../../../src/core/assembly/cross-reads.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,cAAc,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,EAC7D,MAAM,sBAAsB,CAAA;AAC7B,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAA;AAKhE;;;;;;;;GAQG;AACH,wBAAgB,sBAAsB,CACpC,EAAE,EAAE;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EACrC,MAAM,EAAE,cAAc,EACtB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,aAAa,EACrB,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAAC,EACpD,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,GACxB;IAAE,SAAS,EAAE,OAAO,CAAC;IAAC,SAAS,EAAE,aAAa,EAAE,CAAA;CAAE,CAgFpD;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,2BAA2B,CACzC,UAAU,EAAE,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,EACpD,MAAM,EAAE,cAAc,EACtB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,GAAG,CAAC,MAAM,EAAE,cAAc,CAAC,EACxC,MAAM,EAAE,aAAa,EACrB,QAAQ,EAAE,GAAG,CAAC,MAAM,CAAC,EACrB,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,CAAC,EACtC,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAAC,EACpD,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,GACxB,aAAa,EAAE,CAuCjB;AAED,MAAM,MAAM,eAAe,GACvB,WAAW,GACX,SAAS,GACT,kBAAkB,GAClB,YAAY,GACZ,iBAAiB,GACjB,cAAc,CAAA;AAElB,iFAAiF;AACjF,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,eAAe,GAAG,MAAM,CASpE;AAED,MAAM,WAAW,kBAAkB;IACjC,OAAO,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,eAAe,CAAA;CACxB;AAED;;;;GAIG;AACH;;;;GAIG;AACH,KAAK,sBAAsB,GAAG,aAAa,GAAG,IAAI,GAAG,YAAY,CAAA;AAEjE,wBAAgB,yBAAyB,CACvC,UAAU,EAAE,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,EACpD,MAAM,EAAE,cAAc,EACtB,WAAW,EAAE,MAAM,EACnB,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,EACzB,KAAK,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,sBAAsB,CAAC,GAC1C,kBAAkB,EAAE,CAuCtB"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import fs from 'node:fs';
|
|
2
|
+
import { StateManager } from '../../state/state-manager.js';
|
|
3
|
+
import { StatePathResolver } from '../../state/state-path-resolver.js';
|
|
4
|
+
import { resolveContainedArtifactPath } from '../../utils/artifact-path.js';
|
|
5
|
+
/**
|
|
6
|
+
* Resolve a single cross-read against a foreign service's state, with allowlist
|
|
7
|
+
* check, per-service state cache, path containment, warning symmetry with the
|
|
8
|
+
* existing `reads` loop in run.ts, and an optional runtime global-step guard.
|
|
9
|
+
*
|
|
10
|
+
* Returns { completed, artifacts } so transitive callers can gate recursion on
|
|
11
|
+
* step completion rather than artifact count (aggregator steps may produce no
|
|
12
|
+
* artifacts of their own but still have valid transitive cross-reads).
|
|
13
|
+
*/
|
|
14
|
+
export function resolveDirectCrossRead(cr, config, projectRoot, output, foreignStateCache, globalSteps) {
|
|
15
|
+
// 1. Defense-in-depth: skip if cr.step is a global step. Parse-time refinement
|
|
16
|
+
// rejects this in service.exports, but the runtime guard protects against
|
|
17
|
+
// malformed configs or future overlay-override paths.
|
|
18
|
+
if (globalSteps && globalSteps.has(cr.step)) {
|
|
19
|
+
output.warn(`cross-reads: '${cr.step}' is a global step and cannot be cross-read`);
|
|
20
|
+
return { completed: false, artifacts: [] };
|
|
21
|
+
}
|
|
22
|
+
// 2. Validate service exists in config
|
|
23
|
+
const serviceEntry = config.project?.services?.find(s => s.name === cr.service);
|
|
24
|
+
if (!serviceEntry) {
|
|
25
|
+
output.warn(`cross-reads: service '${cr.service}' not found`);
|
|
26
|
+
return { completed: false, artifacts: [] };
|
|
27
|
+
}
|
|
28
|
+
// 3. Check exports allowlist (closed by default)
|
|
29
|
+
if (!serviceEntry.exports?.some(e => e.step === cr.step)) {
|
|
30
|
+
output.warn(`cross-reads: '${cr.step}' not exported by '${cr.service}'`);
|
|
31
|
+
return { completed: false, artifacts: [] };
|
|
32
|
+
}
|
|
33
|
+
// 4. Load foreign service state via read-only loader, cached per service
|
|
34
|
+
let foreignState = foreignStateCache.get(cr.service);
|
|
35
|
+
if (foreignState === undefined) {
|
|
36
|
+
const foreignResolver = new StatePathResolver(projectRoot, cr.service);
|
|
37
|
+
if (!fs.existsSync(foreignResolver.statePath)) {
|
|
38
|
+
output.warn(`cross-reads: service '${cr.service}' not bootstrapped`);
|
|
39
|
+
foreignStateCache.set(cr.service, null);
|
|
40
|
+
return { completed: false, artifacts: [] };
|
|
41
|
+
}
|
|
42
|
+
try {
|
|
43
|
+
foreignState = StateManager.loadStateReadOnly(projectRoot, foreignResolver, () => config);
|
|
44
|
+
foreignStateCache.set(cr.service, foreignState);
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
output.warn(`cross-reads: failed to load state for '${cr.service}'`);
|
|
48
|
+
foreignStateCache.set(cr.service, null);
|
|
49
|
+
return { completed: false, artifacts: [] };
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
if (!foreignState)
|
|
53
|
+
return { completed: false, artifacts: [] };
|
|
54
|
+
// 5. Check step is completed
|
|
55
|
+
const stepEntry = foreignState.steps?.[cr.step];
|
|
56
|
+
if (!stepEntry || stepEntry.status !== 'completed') {
|
|
57
|
+
return { completed: false, artifacts: [] };
|
|
58
|
+
}
|
|
59
|
+
// 6. Resolve artifacts with containment check + warning symmetry with run.ts reads loop
|
|
60
|
+
const artifacts = [];
|
|
61
|
+
for (const relPath of stepEntry.produces ?? []) {
|
|
62
|
+
const fullPath = resolveContainedArtifactPath(projectRoot, relPath);
|
|
63
|
+
if (fullPath === null) {
|
|
64
|
+
output.warn({
|
|
65
|
+
code: 'ARTIFACT_PATH_REJECTED',
|
|
66
|
+
message: `Cross-read artifact '${relPath}' from '${cr.service}:${cr.step}' `
|
|
67
|
+
+ 'resolves outside project root — skipping',
|
|
68
|
+
});
|
|
69
|
+
continue;
|
|
70
|
+
}
|
|
71
|
+
if (!fs.existsSync(fullPath))
|
|
72
|
+
continue;
|
|
73
|
+
try {
|
|
74
|
+
artifacts.push({
|
|
75
|
+
stepName: `${cr.service}:${cr.step}`,
|
|
76
|
+
filePath: relPath,
|
|
77
|
+
content: fs.readFileSync(fullPath, 'utf8'),
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
output.warn({
|
|
82
|
+
code: 'ARTIFACT_READ_ERROR',
|
|
83
|
+
message: `Could not read cross-read artifact '${relPath}' from `
|
|
84
|
+
+ `'${cr.service}:${cr.step}': ${err.message}`,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return { completed: true, artifacts };
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* DFS-driven transitive cross-reads resolver with:
|
|
92
|
+
* - cycle detection via `visiting` set (gray nodes),
|
|
93
|
+
* - memoization via `resolved` map (black nodes) caching the FULL closure per service:step,
|
|
94
|
+
* - per-service foreign-state cache via `foreignStateCache`,
|
|
95
|
+
* - per-traversal dedup via a local Map<filePath, entry>,
|
|
96
|
+
* - skips foreign meta of category: 'tool' for transitive lookup.
|
|
97
|
+
*
|
|
98
|
+
* Gates transitive recursion on `direct.completed` (not artifact count) so
|
|
99
|
+
* aggregator steps with empty `produces` still participate in the chain.
|
|
100
|
+
*/
|
|
101
|
+
export function resolveTransitiveCrossReads(crossReads, config, projectRoot, metaPrompts, output, visiting, resolved, foreignStateCache, globalSteps) {
|
|
102
|
+
const closure = new Map(); // filePath → entry (dedup inside traversal)
|
|
103
|
+
for (const cr of crossReads) {
|
|
104
|
+
const key = `${cr.service}:${cr.step}`;
|
|
105
|
+
if (visiting.has(key))
|
|
106
|
+
continue; // cycle — skip silently
|
|
107
|
+
if (resolved.has(key)) {
|
|
108
|
+
for (const a of resolved.get(key))
|
|
109
|
+
closure.set(a.filePath, a);
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
visiting.add(key);
|
|
113
|
+
const direct = resolveDirectCrossRead(cr, config, projectRoot, output, foreignStateCache, globalSteps);
|
|
114
|
+
let transitive = [];
|
|
115
|
+
if (direct.completed) {
|
|
116
|
+
const foreignMeta = metaPrompts.get(cr.step);
|
|
117
|
+
const isTool = foreignMeta?.frontmatter.category === 'tool';
|
|
118
|
+
if (!isTool && foreignMeta?.frontmatter.crossReads?.length) {
|
|
119
|
+
transitive = resolveTransitiveCrossReads(foreignMeta.frontmatter.crossReads, config, projectRoot, metaPrompts, output, visiting, resolved, foreignStateCache, globalSteps);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
// Dedup before caching so subsequent cache hits return unique paths,
|
|
123
|
+
// matching the per-traversal `closure` dedup semantics.
|
|
124
|
+
const dedupedClosure = [...new Map([...direct.artifacts, ...transitive].map(a => [a.filePath, a])).values()];
|
|
125
|
+
for (const a of dedupedClosure)
|
|
126
|
+
closure.set(a.filePath, a);
|
|
127
|
+
visiting.delete(key);
|
|
128
|
+
resolved.set(key, dedupedClosure); // cache FULL deduped closure (direct + transitive)
|
|
129
|
+
}
|
|
130
|
+
return [...closure.values()];
|
|
131
|
+
}
|
|
132
|
+
/** Human-facing rendering of CrossReadStatus for text display in next/status. */
|
|
133
|
+
export function humanCrossReadStatus(status) {
|
|
134
|
+
switch (status) {
|
|
135
|
+
case 'completed': return 'completed';
|
|
136
|
+
case 'pending': return 'pending';
|
|
137
|
+
case 'not-bootstrapped': return 'service not bootstrapped';
|
|
138
|
+
case 'read-error': return 'foreign state unreadable';
|
|
139
|
+
case 'service-unknown': return 'service unknown';
|
|
140
|
+
case 'not-exported': return 'not exported';
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
export function resolveCrossReadReadiness(crossReads, config, projectRoot, globalSteps, cache) {
|
|
144
|
+
const foreignCache = cache ?? new Map();
|
|
145
|
+
return crossReads.map(cr => {
|
|
146
|
+
// Defense-in-depth: global steps never participate in cross-reads (spec §2.3).
|
|
147
|
+
// Display commands must agree with `run`'s runtime skip, not show the entry
|
|
148
|
+
// as completed/pending.
|
|
149
|
+
if (globalSteps && globalSteps.has(cr.step)) {
|
|
150
|
+
return { ...cr, status: 'not-exported' };
|
|
151
|
+
}
|
|
152
|
+
const serviceEntry = config.project?.services?.find(s => s.name === cr.service);
|
|
153
|
+
if (!serviceEntry)
|
|
154
|
+
return { ...cr, status: 'service-unknown' };
|
|
155
|
+
if (!serviceEntry.exports?.some(e => e.step === cr.step)) {
|
|
156
|
+
return { ...cr, status: 'not-exported' };
|
|
157
|
+
}
|
|
158
|
+
let entry = foreignCache.get(cr.service);
|
|
159
|
+
if (entry === undefined) {
|
|
160
|
+
const resolver = new StatePathResolver(projectRoot, cr.service);
|
|
161
|
+
if (!fs.existsSync(resolver.statePath)) {
|
|
162
|
+
foreignCache.set(cr.service, null);
|
|
163
|
+
return { ...cr, status: 'not-bootstrapped' };
|
|
164
|
+
}
|
|
165
|
+
try {
|
|
166
|
+
entry = StateManager.loadStateReadOnly(projectRoot, resolver, () => config);
|
|
167
|
+
foreignCache.set(cr.service, entry);
|
|
168
|
+
}
|
|
169
|
+
catch {
|
|
170
|
+
foreignCache.set(cr.service, 'read-error');
|
|
171
|
+
return { ...cr, status: 'read-error' };
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
if (entry === null)
|
|
175
|
+
return { ...cr, status: 'not-bootstrapped' };
|
|
176
|
+
if (entry === 'read-error')
|
|
177
|
+
return { ...cr, status: 'read-error' };
|
|
178
|
+
const stepEntry = entry.steps?.[cr.step];
|
|
179
|
+
return {
|
|
180
|
+
...cr,
|
|
181
|
+
status: stepEntry?.status === 'completed' ? 'completed' : 'pending',
|
|
182
|
+
};
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
//# sourceMappingURL=cross-reads.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cross-reads.js","sourceRoot":"","sources":["../../../src/core/assembly/cross-reads.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cross-reads.test.d.ts","sourceRoot":"","sources":["../../../src/core/assembly/cross-reads.test.ts"],"names":[],"mappings":""}
|