@pennyfarthing/core 7.9.5 → 8.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 +14 -0
- package/README.md +209 -0
- package/package.json +32 -37
- package/{dist → packages/core/dist}/cli/utils/files.d.ts +6 -2
- package/{dist → packages/core/dist}/cli/utils/files.d.ts.map +1 -1
- package/{dist → packages/core/dist}/cli/utils/files.js +12 -4
- package/{dist → packages/core/dist}/cli/utils/files.js.map +1 -1
- package/{dist → packages/core/dist}/cli/workspace.test.js +3 -1
- package/{dist → packages/core/dist}/cli/workspace.test.js.map +1 -1
- package/pennyfarthing-dist/agents/README.md +12 -12
- package/pennyfarthing-dist/agents/architect.md +1 -1
- package/pennyfarthing-dist/agents/dev.md +2 -2
- package/pennyfarthing-dist/agents/devops.md +1 -1
- package/pennyfarthing-dist/agents/handoff.md +2 -2
- package/pennyfarthing-dist/agents/pm.md +1 -1
- package/pennyfarthing-dist/agents/reviewer.md +2 -2
- package/pennyfarthing-dist/agents/sm-setup.md +5 -5
- package/pennyfarthing-dist/agents/sm.md +6 -6
- package/pennyfarthing-dist/agents/tea.md +2 -2
- package/pennyfarthing-dist/agents/tech-writer.md +1 -1
- package/pennyfarthing-dist/agents/testing-runner.md +4 -4
- package/pennyfarthing-dist/agents/ux-designer.md +1 -1
- package/pennyfarthing-dist/agents/workflow-status-check.md +2 -2
- package/pennyfarthing-dist/commands/architect.md +1 -1
- package/pennyfarthing-dist/commands/create-branches-from-story.md +5 -5
- package/pennyfarthing-dist/commands/dev.md +1 -1
- package/pennyfarthing-dist/commands/devops.md +1 -1
- package/pennyfarthing-dist/commands/health-check.md +3 -3
- package/pennyfarthing-dist/commands/orchestrator.md +1 -1
- package/pennyfarthing-dist/commands/parallel-work.md +4 -4
- package/pennyfarthing-dist/commands/pm.md +1 -1
- package/pennyfarthing-dist/commands/release.md +1 -1
- package/pennyfarthing-dist/commands/repo-status.md +2 -2
- package/pennyfarthing-dist/commands/retro.md +2 -2
- package/pennyfarthing-dist/commands/reviewer.md +1 -1
- package/pennyfarthing-dist/commands/set-theme.md +1 -1
- package/pennyfarthing-dist/commands/sm.md +1 -1
- package/pennyfarthing-dist/commands/sprint.md +7 -7
- package/pennyfarthing-dist/commands/start-epic.md +3 -3
- package/pennyfarthing-dist/commands/sync-epic-to-jira.md +4 -4
- package/pennyfarthing-dist/commands/tea.md +1 -1
- package/pennyfarthing-dist/commands/tech-writer.md +1 -1
- package/pennyfarthing-dist/commands/ux-designer.md +1 -1
- package/pennyfarthing-dist/commands/work.md +1 -1
- package/pennyfarthing-dist/guides/agent-behavior.md +11 -11
- package/pennyfarthing-dist/guides/agent-tag-taxonomy.md +1 -1
- package/pennyfarthing-dist/guides/agent-template-strategic.md +1 -1
- package/pennyfarthing-dist/guides/agent-template-tactical.md +2 -2
- package/pennyfarthing-dist/guides/worktree-mode.md +3 -3
- package/pennyfarthing-dist/guides/xml-tags.md +1 -1
- package/pennyfarthing-dist/personas/themes/mash.yaml +2 -2
- package/pennyfarthing-dist/personas/themes/star-trek-tos.yaml +1 -1
- package/pennyfarthing-dist/scripts/README.md +6 -6
- package/pennyfarthing-dist/scripts/core/README.md +3 -4
- package/pennyfarthing-dist/scripts/core/phase-check-start.sh +12 -17
- package/pennyfarthing-dist/scripts/cyclist/is-cyclist.sh +1 -1
- package/pennyfarthing-dist/scripts/git/README.md +2 -2
- package/pennyfarthing-dist/scripts/git/install-git-hooks.sh +3 -15
- package/pennyfarthing-dist/scripts/git/release.sh +1 -1
- package/pennyfarthing-dist/scripts/health/drift-detection.sh +1 -1
- package/pennyfarthing-dist/scripts/hooks/README.md +1 -1
- package/pennyfarthing-dist/scripts/hooks/__pycache__/question_reflector_check.cpython-314.pyc +0 -0
- package/pennyfarthing-dist/scripts/hooks/post-merge.sh +3 -12
- package/pennyfarthing-dist/scripts/hooks/pre-push.sh +3 -15
- package/pennyfarthing-dist/scripts/jira/README.md +2 -2
- package/pennyfarthing-dist/scripts/jira/create-jira-epic.sh +1 -1
- package/pennyfarthing-dist/scripts/jira/create-jira-story.sh +1 -1
- package/pennyfarthing-dist/scripts/jira/jira-reconcile.sh +2 -2
- package/pennyfarthing-dist/scripts/lib/find-root.sh +45 -25
- package/pennyfarthing-dist/scripts/misc/README.md +2 -2
- package/pennyfarthing-dist/scripts/misc/backlog.sh +3 -17
- package/pennyfarthing-dist/scripts/misc/generate-skill-docs.sh +4 -30
- package/pennyfarthing-dist/scripts/misc/log-skill-usage.sh +1 -1
- package/pennyfarthing-dist/scripts/misc/run-ci.sh +3 -10
- package/pennyfarthing-dist/scripts/misc/skill-usage-report.sh +1 -1
- package/pennyfarthing-dist/scripts/misc/uninstall.sh +0 -1
- package/pennyfarthing-dist/scripts/portraits/generate-portraits.py +19 -2
- package/pennyfarthing-dist/scripts/sprint/README.md +2 -2
- package/pennyfarthing-dist/scripts/sprint/archive-story.sh +5 -5
- package/pennyfarthing-dist/scripts/sprint/available-stories.sh +2 -2
- package/pennyfarthing-dist/scripts/sprint/check-story.sh +1 -1
- package/pennyfarthing-dist/scripts/sprint/get-epic-field.sh +5 -5
- package/pennyfarthing-dist/scripts/sprint/get-story-field.sh +5 -5
- package/pennyfarthing-dist/scripts/sprint/list-future.sh +2 -2
- package/pennyfarthing-dist/scripts/sprint/new-sprint.sh +3 -3
- package/pennyfarthing-dist/scripts/sprint/promote-epic.sh +4 -4
- package/pennyfarthing-dist/scripts/sprint/sprint-common.sh +11 -17
- package/pennyfarthing-dist/scripts/sprint/sprint-info.sh +2 -2
- package/pennyfarthing-dist/scripts/sprint/sprint-metrics.sh +3 -14
- package/pennyfarthing-dist/scripts/sprint/sprint-status.sh +4 -4
- package/pennyfarthing-dist/scripts/story/README.md +2 -2
- package/pennyfarthing-dist/scripts/test/README.md +1 -1
- package/pennyfarthing-dist/scripts/theme/README.md +1 -1
- package/pennyfarthing-dist/scripts/workflow/README.md +2 -2
- package/pennyfarthing-dist/scripts/workflow/finish-story.sh +1 -1
- package/pennyfarthing-dist/scripts/workflow/fix-session-phase.sh +1 -1
- package/pennyfarthing-dist/scripts/workflow/get-workflow-type.sh +1 -1
- package/pennyfarthing-dist/scripts/workflow/list-workflows.sh +2 -2
- package/pennyfarthing-dist/scripts/workflow/resume-workflow.sh +2 -2
- package/pennyfarthing-dist/scripts/workflow/show-workflow.sh +2 -2
- package/pennyfarthing-dist/scripts/workflow/start-workflow.sh +2 -2
- package/pennyfarthing-dist/scripts/workflow/workflow-status.sh +2 -2
- package/pennyfarthing-dist/skills/cyclist/SKILL.md +2 -2
- package/pennyfarthing-dist/skills/jira/SKILL.md +15 -15
- package/pennyfarthing-dist/skills/judge/SKILL.md +1 -1
- package/pennyfarthing-dist/skills/sprint/scripts/archive-story.sh +3 -3
- package/pennyfarthing-dist/skills/sprint/scripts/available-stories.sh +2 -2
- package/pennyfarthing-dist/skills/sprint/scripts/check-story.sh +2 -2
- package/pennyfarthing-dist/skills/sprint/scripts/create-jira-epic.sh +1 -1
- package/pennyfarthing-dist/skills/sprint/scripts/new-sprint.sh +3 -3
- package/pennyfarthing-dist/skills/sprint/scripts/promote-epic.sh +4 -4
- package/pennyfarthing-dist/skills/sprint/scripts/sprint-info.sh +2 -2
- package/pennyfarthing-dist/skills/sprint/scripts/sprint-status.sh +2 -2
- package/pennyfarthing-dist/skills/sprint/scripts/sync-epic-jira.sh +4 -4
- package/pennyfarthing-dist/skills/sprint/skill.md +30 -30
- package/pennyfarthing-dist/skills/story/skill.md +16 -16
- package/pennyfarthing-dist/skills/workflow/scripts/list-workflows.sh +2 -2
- package/pennyfarthing-dist/skills/workflow/scripts/resume-workflow.sh +2 -2
- package/pennyfarthing-dist/skills/workflow/scripts/show-workflow.sh +2 -2
- package/pennyfarthing-dist/skills/workflow/scripts/start-workflow.sh +2 -2
- package/pennyfarthing-dist/skills/workflow/scripts/workflow-status.sh +2 -2
- package/pennyfarthing-dist/skills/workflow/skill.md +14 -14
- package/pennyfarthing-dist/workflows/epics-and-stories/steps/step-05-import-to-future.md +2 -2
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-01-analyze.md +2 -2
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-04-verify.md +1 -1
- package/pennyfarthing-dist/workflows/git-cleanup/steps/step-05-complete.md +1 -1
- package/pennyfarthing_scripts/README.md +66 -0
- package/pennyfarthing_scripts/__init__.py +17 -0
- package/pennyfarthing_scripts/__pycache__/__init__.cpython-311.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/config.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_epic_creation.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_sync.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/jira_sync_story.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/sprint.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/workflow.cpython-311.pyc +0 -0
- package/pennyfarthing_scripts/__pycache__/workflow.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/bellmode_hook.py +154 -0
- package/pennyfarthing_scripts/brownfield/__init__.py +35 -0
- package/pennyfarthing_scripts/brownfield/__main__.py +7 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/__pycache__/discover.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/brownfield/cli.py +131 -0
- package/pennyfarthing_scripts/brownfield/discover.py +753 -0
- package/pennyfarthing_scripts/common/__init__.py +49 -0
- package/pennyfarthing_scripts/common/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/__pycache__/config.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/__pycache__/output.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/common/config.py +91 -0
- package/pennyfarthing_scripts/common/output.py +180 -0
- package/pennyfarthing_scripts/config.py +21 -0
- package/pennyfarthing_scripts/git/__init__.py +29 -0
- package/pennyfarthing_scripts/git/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/__pycache__/create_branches.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/__pycache__/status_all.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/git/create_branches.py +439 -0
- package/pennyfarthing_scripts/git/status_all.py +310 -0
- package/pennyfarthing_scripts/hooks.py +455 -0
- package/pennyfarthing_scripts/jira/__init__.py +93 -0
- package/pennyfarthing_scripts/jira/__main__.py +10 -0
- package/pennyfarthing_scripts/jira/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/bidirectional.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/claim.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/client.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/compat.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/epic.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/mappings.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/models.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/story.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/__pycache__/sync.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/jira/bidirectional.py +561 -0
- package/pennyfarthing_scripts/jira/claim.py +211 -0
- package/pennyfarthing_scripts/jira/cli.py +150 -0
- package/pennyfarthing_scripts/jira/client.py +613 -0
- package/pennyfarthing_scripts/jira/epic.py +176 -0
- package/pennyfarthing_scripts/jira/story.py +219 -0
- package/pennyfarthing_scripts/jira/sync.py +350 -0
- package/pennyfarthing_scripts/jira_bidirectional_sync.py +37 -0
- package/pennyfarthing_scripts/jira_epic_creation.py +30 -0
- package/pennyfarthing_scripts/jira_sync.py +36 -0
- package/pennyfarthing_scripts/jira_sync_story.py +30 -0
- package/pennyfarthing_scripts/output.py +37 -0
- package/pennyfarthing_scripts/preflight/__init__.py +17 -0
- package/pennyfarthing_scripts/preflight/__main__.py +10 -0
- package/pennyfarthing_scripts/preflight/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/__pycache__/finish.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/preflight/cli.py +141 -0
- package/pennyfarthing_scripts/preflight/finish.py +382 -0
- package/pennyfarthing_scripts/pretooluse_hook.py +142 -0
- package/pennyfarthing_scripts/prime/__init__.py +125 -0
- package/pennyfarthing_scripts/prime/__main__.py +8 -0
- package/pennyfarthing_scripts/prime/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/loader.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/models.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/persona.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/session.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/__pycache__/workflow.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/prime/cli.py +375 -0
- package/pennyfarthing_scripts/prime/loader.py +239 -0
- package/pennyfarthing_scripts/prime/models.py +169 -0
- package/pennyfarthing_scripts/prime/persona.py +288 -0
- package/pennyfarthing_scripts/prime/session.py +183 -0
- package/pennyfarthing_scripts/prime/workflow.py +275 -0
- package/pennyfarthing_scripts/sprint/__init__.py +66 -0
- package/pennyfarthing_scripts/sprint/__main__.py +10 -0
- package/pennyfarthing_scripts/sprint/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/__main__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/archive.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/cli.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/loader.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/status.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/validator.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/__pycache__/work.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/sprint/archive.py +108 -0
- package/pennyfarthing_scripts/sprint/cli.py +124 -0
- package/pennyfarthing_scripts/sprint/loader.py +193 -0
- package/pennyfarthing_scripts/sprint/status.py +122 -0
- package/pennyfarthing_scripts/sprint/validator.py +405 -0
- package/pennyfarthing_scripts/sprint/work.py +192 -0
- package/pennyfarthing_scripts/story/__init__.py +67 -0
- package/pennyfarthing_scripts/story/__main__.py +10 -0
- package/pennyfarthing_scripts/story/cli.py +105 -0
- package/pennyfarthing_scripts/story/create.py +167 -0
- package/pennyfarthing_scripts/story/size.py +113 -0
- package/pennyfarthing_scripts/story/template.py +151 -0
- package/pennyfarthing_scripts/swebench.py +216 -0
- package/pennyfarthing_scripts/tests/__init__.py +1 -0
- package/pennyfarthing_scripts/tests/__pycache__/__init__.cpython-314.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/conftest.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_brownfield.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_git_utils.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_prime.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/__pycache__/test_sprint_validator.cpython-314-pytest-9.0.2.pyc +0 -0
- package/pennyfarthing_scripts/tests/conftest.py +106 -0
- package/pennyfarthing_scripts/tests/test_brownfield.py +842 -0
- package/pennyfarthing_scripts/tests/test_cli_modules.py +245 -0
- package/pennyfarthing_scripts/tests/test_common.py +180 -0
- package/pennyfarthing_scripts/tests/test_git_utils.py +866 -0
- package/pennyfarthing_scripts/tests/test_jira_package.py +334 -0
- package/pennyfarthing_scripts/tests/test_package_structure.py +372 -0
- package/pennyfarthing_scripts/tests/test_prime.py +1050 -0
- package/pennyfarthing_scripts/tests/test_sprint_package.py +236 -0
- package/pennyfarthing_scripts/tests/test_sprint_validator.py +675 -0
- package/pennyfarthing_scripts/tests/test_story_package.py +156 -0
- package/pennyfarthing_scripts/welcome_hook.py +157 -0
- package/pennyfarthing_scripts/workflow.py +183 -0
- package/pennyfarthing-dist/personas/BENCHMARK-METHODOLOGY.md +0 -105
- package/pennyfarthing-dist/personas/OCEAN-BENCHMARKING.md +0 -210
- package/pennyfarthing-dist/personas/TRAIL-OCEAN-MAPPING.md +0 -168
- package/pennyfarthing-dist/personas/ZEITGEIST-ANALYSIS.md +0 -171
- package/pennyfarthing-dist/personas/attributes.yaml +0 -69
- package/pennyfarthing-dist/personas/scripts/add-zeitgeist-calibrated.py +0 -81
- package/pennyfarthing-dist/personas/scripts/add-zeitgeist-scores.sh +0 -56
- package/pennyfarthing-dist/personas/zeitgeist-scores.yaml +0 -1172
- package/pennyfarthing-dist/scripts/core/run.sh +0 -92
- /package/{bin → packages/core/bin}/pennyfarthing.js +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.js +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.test.js +0 -0
- /package/{dist → packages/core/dist}/bmad/context-reader.test.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.js +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.test.js +0 -0
- /package/{dist → packages/core/dist}/bmad/epics-parser.test.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/index.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/index.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/index.js +0 -0
- /package/{dist → packages/core/dist}/bmad/index.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.js +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.test.js +0 -0
- /package/{dist → packages/core/dist}/bmad/status-sync.test.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.js +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.test.js +0 -0
- /package/{dist → packages/core/dist}/bmad/story-exporter.test.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.js +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.js.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.test.js +0 -0
- /package/{dist → packages/core/dist}/bmad/story-parser.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/command.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/command.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/command.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/command.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/cyclist.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor-legacy.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor-legacy.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor-legacy.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor-legacy.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/doctor.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/init.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/init.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/init.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/init.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/skill.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/skill.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/skill.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/skill.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/theme.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/theme.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/theme.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/theme.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/uninstall.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/uninstall.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/uninstall.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/uninstall.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/update.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/update.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/update.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/update.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/version.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/commands/version.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/commands/version.js +0 -0
- /package/{dist → packages/core/dist}/cli/commands/version.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/customization.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/customization.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/customization.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/customization.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/cyclist-migration.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/cyclist-migration.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/cyclist-migration.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/cyclist-migration.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/index.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/index.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/index.js +0 -0
- /package/{dist → packages/core/dist}/cli/index.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/ocean-profiles.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/ocean-profiles.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/ocean-profiles.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/ocean-profiles.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/theme-maker.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/theme-maker.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/theme-maker.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/theme-maker.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/constants.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/constants.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/constants.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/constants.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/logger.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/logger.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/logger.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/logger.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/manifest.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/manifest.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/manifest.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/manifest.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/node-modules.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/node-modules.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/node-modules.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/node-modules.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/prompts.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/prompts.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/prompts.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/prompts.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/symlinks.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/symlinks.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/symlinks.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/symlinks.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.test.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/themes.test.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/version.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/utils/version.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/cli/utils/version.js +0 -0
- /package/{dist → packages/core/dist}/cli/utils/version.js.map +0 -0
- /package/{dist → packages/core/dist}/cli/workspace.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/cli/workspace.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/index.d.ts +0 -0
- /package/{dist → packages/core/dist}/index.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/index.js +0 -0
- /package/{dist → packages/core/dist}/index.js.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.d.ts +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.js +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.js.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.test.js +0 -0
- /package/{dist → packages/core/dist}/jira/jira-epic-creation.test.js.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.d.ts +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.js +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.js.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.test.js +0 -0
- /package/{dist → packages/core/dist}/jira/jira-sprint-sync.test.js.map +0 -0
- /package/{dist → packages/core/dist}/permissions/index.d.ts +0 -0
- /package/{dist → packages/core/dist}/permissions/index.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/permissions/index.js +0 -0
- /package/{dist → packages/core/dist}/permissions/index.js.map +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.d.ts +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.js +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.js.map +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.test.js +0 -0
- /package/{dist → packages/core/dist}/permissions/permission-schema.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/add-ocean-profiles.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/add-ocean-profiles.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/add-ocean-profiles.js +0 -0
- /package/{dist → packages/core/dist}/scripts/add-ocean-profiles.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.js +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/benchmark-integration.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/debugging-scenarios.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/debugging-scenarios.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/debugging-scenarios.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/debugging-scenarios.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-all-spiders.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-all-spiders.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-all-spiders.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-all-spiders.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-report.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider-report.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/generate-spider.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.js +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/job-fair-aggregator.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/run-ci.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/run-ci.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/run-ci.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/run-ci.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/theme-detail.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/theme-detail.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/theme-detail.test.js +0 -0
- /package/{dist → packages/core/dist}/scripts/theme-detail.test.js.map +0 -0
- /package/{dist → packages/core/dist}/scripts/validate-ocean-profiles.d.ts +0 -0
- /package/{dist → packages/core/dist}/scripts/validate-ocean-profiles.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/scripts/validate-ocean-profiles.js +0 -0
- /package/{dist → packages/core/dist}/scripts/validate-ocean-profiles.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.js +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/gate-handler.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-finish.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-finish.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-finish.js +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-finish.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-setup.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-setup.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-setup.js +0 -0
- /package/{dist → packages/core/dist}/workflow/generic-sm-setup.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.js +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/handoff.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/index.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/index.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/index.js +0 -0
- /package/{dist → packages/core/dist}/workflow/index.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.js +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/session-state.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/sm-subagents.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/sm-subagents.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/sm-subagents.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/sm-subagents.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.js +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/step-parser.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/story-workflow-routing.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/story-workflow-routing.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/story-workflow-routing.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/story-workflow-routing.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.js +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/test-cache.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.js +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/trimodal.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.js +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/variable-resolver.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-executor.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-loader.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-migration.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-migration.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-migration.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-migration.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-permissions.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-router.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-schema.test.js.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-stepped-schema.test.d.ts +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-stepped-schema.test.d.ts.map +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-stepped-schema.test.js +0 -0
- /package/{dist → packages/core/dist}/workflow/workflow-stepped-schema.test.js.map +0 -0
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
"""Tests for the fan-out CLI package structure.
|
|
2
|
+
|
|
3
|
+
Story 63-9: Reorganize pennyfarthing_scripts into fan-out CLI pattern.
|
|
4
|
+
|
|
5
|
+
These tests verify:
|
|
6
|
+
1. Library packages exist (jira/, sprint/, story/, common/)
|
|
7
|
+
2. CLI modules exist (jira.py, sprint.py, story.py)
|
|
8
|
+
3. Library modules are importable from packages
|
|
9
|
+
4. CLIs delegate to library modules
|
|
10
|
+
5. Backwards compatibility for existing imports
|
|
11
|
+
"""
|
|
12
|
+
|
|
13
|
+
import importlib
|
|
14
|
+
import sys
|
|
15
|
+
from pathlib import Path
|
|
16
|
+
from typing import Any
|
|
17
|
+
|
|
18
|
+
import pytest
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class TestCommonPackage:
|
|
22
|
+
"""Tests for common/ shared utilities package."""
|
|
23
|
+
|
|
24
|
+
def test_common_package_exists(self) -> None:
|
|
25
|
+
"""common/ package should exist and be importable."""
|
|
26
|
+
from pennyfarthing_scripts import common
|
|
27
|
+
|
|
28
|
+
assert common is not None
|
|
29
|
+
|
|
30
|
+
def test_output_module_in_common(self) -> None:
|
|
31
|
+
"""output.py should be importable from common/."""
|
|
32
|
+
from pennyfarthing_scripts.common import output
|
|
33
|
+
|
|
34
|
+
assert hasattr(output, "success")
|
|
35
|
+
assert hasattr(output, "info")
|
|
36
|
+
assert hasattr(output, "warn")
|
|
37
|
+
assert hasattr(output, "error")
|
|
38
|
+
assert hasattr(output, "debug")
|
|
39
|
+
|
|
40
|
+
def test_config_module_in_common(self) -> None:
|
|
41
|
+
"""config.py should be importable from common/."""
|
|
42
|
+
from pennyfarthing_scripts.common import config
|
|
43
|
+
|
|
44
|
+
assert hasattr(config, "get_project_root")
|
|
45
|
+
assert hasattr(config, "load_yaml_config")
|
|
46
|
+
assert hasattr(config, "load_pennyfarthing_config")
|
|
47
|
+
|
|
48
|
+
def test_output_backwards_compatibility(self) -> None:
|
|
49
|
+
"""Old import path should still work for backwards compatibility."""
|
|
50
|
+
from pennyfarthing_scripts import output
|
|
51
|
+
|
|
52
|
+
# Should re-export from common.output
|
|
53
|
+
assert hasattr(output, "success")
|
|
54
|
+
assert hasattr(output, "error")
|
|
55
|
+
|
|
56
|
+
def test_config_backwards_compatibility(self) -> None:
|
|
57
|
+
"""Old import path should still work for backwards compatibility."""
|
|
58
|
+
from pennyfarthing_scripts import config
|
|
59
|
+
|
|
60
|
+
# Should re-export from common.config
|
|
61
|
+
assert hasattr(config, "get_project_root")
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
class TestJiraPackage:
|
|
65
|
+
"""Tests for jira/ library package."""
|
|
66
|
+
|
|
67
|
+
def test_jira_package_exists(self) -> None:
|
|
68
|
+
"""jira/ package should exist and be importable."""
|
|
69
|
+
from pennyfarthing_scripts import jira
|
|
70
|
+
|
|
71
|
+
# Should be a package, not the old flat module
|
|
72
|
+
assert hasattr(jira, "__path__") # Packages have __path__
|
|
73
|
+
|
|
74
|
+
def test_client_module_in_jira(self) -> None:
|
|
75
|
+
"""client.py should contain JiraClient and helper functions."""
|
|
76
|
+
from pennyfarthing_scripts.jira import client
|
|
77
|
+
|
|
78
|
+
assert hasattr(client, "JiraClient")
|
|
79
|
+
assert hasattr(client, "get_issue")
|
|
80
|
+
assert hasattr(client, "map_status_to_jira")
|
|
81
|
+
assert hasattr(client, "map_jira_to_status")
|
|
82
|
+
assert hasattr(client, "extract_jira_key")
|
|
83
|
+
|
|
84
|
+
def test_claim_module_in_jira(self) -> None:
|
|
85
|
+
"""claim.py should provide story claiming functionality."""
|
|
86
|
+
from pennyfarthing_scripts.jira import claim
|
|
87
|
+
|
|
88
|
+
# Main function for claiming stories
|
|
89
|
+
assert hasattr(claim, "claim_story")
|
|
90
|
+
assert hasattr(claim, "check_availability")
|
|
91
|
+
|
|
92
|
+
def test_sync_module_in_jira(self) -> None:
|
|
93
|
+
"""sync.py should provide epic sync functionality."""
|
|
94
|
+
from pennyfarthing_scripts.jira import sync
|
|
95
|
+
|
|
96
|
+
assert hasattr(sync, "sync_epic")
|
|
97
|
+
assert hasattr(sync, "sync_story")
|
|
98
|
+
assert hasattr(sync, "SyncResult")
|
|
99
|
+
|
|
100
|
+
def test_bidirectional_module_in_jira(self) -> None:
|
|
101
|
+
"""bidirectional.py should provide bidirectional sync."""
|
|
102
|
+
from pennyfarthing_scripts.jira import bidirectional
|
|
103
|
+
|
|
104
|
+
assert hasattr(bidirectional, "generate_sync_plan")
|
|
105
|
+
assert hasattr(bidirectional, "execute_sync_plan")
|
|
106
|
+
assert hasattr(bidirectional, "SyncPlan")
|
|
107
|
+
assert hasattr(bidirectional, "SyncChange")
|
|
108
|
+
|
|
109
|
+
def test_epic_module_in_jira(self) -> None:
|
|
110
|
+
"""epic.py should provide epic creation functionality."""
|
|
111
|
+
from pennyfarthing_scripts.jira import epic
|
|
112
|
+
|
|
113
|
+
assert hasattr(epic, "create_epic")
|
|
114
|
+
assert hasattr(epic, "create_epic_from_yaml")
|
|
115
|
+
assert hasattr(epic, "build_epic_payload")
|
|
116
|
+
|
|
117
|
+
def test_story_module_in_jira(self) -> None:
|
|
118
|
+
"""story.py should provide story sync functionality."""
|
|
119
|
+
from pennyfarthing_scripts.jira import story
|
|
120
|
+
|
|
121
|
+
assert hasattr(story, "sync_story")
|
|
122
|
+
assert hasattr(story, "get_story_from_sprint")
|
|
123
|
+
|
|
124
|
+
def test_jira_package_reexports(self) -> None:
|
|
125
|
+
"""jira/__init__.py should re-export commonly used items."""
|
|
126
|
+
from pennyfarthing_scripts.jira import (
|
|
127
|
+
JiraClient,
|
|
128
|
+
extract_jira_key,
|
|
129
|
+
map_status_to_jira,
|
|
130
|
+
map_jira_to_status,
|
|
131
|
+
)
|
|
132
|
+
|
|
133
|
+
assert JiraClient is not None
|
|
134
|
+
assert callable(extract_jira_key)
|
|
135
|
+
|
|
136
|
+
def test_jira_backwards_compatibility(self) -> None:
|
|
137
|
+
"""Old-style imports should still work."""
|
|
138
|
+
# These imports should work for backwards compatibility
|
|
139
|
+
from pennyfarthing_scripts.jira import JiraClient
|
|
140
|
+
from pennyfarthing_scripts.jira import get_issue
|
|
141
|
+
from pennyfarthing_scripts.jira import STATUS_TO_JIRA
|
|
142
|
+
|
|
143
|
+
assert JiraClient is not None
|
|
144
|
+
assert callable(get_issue)
|
|
145
|
+
assert isinstance(STATUS_TO_JIRA, dict)
|
|
146
|
+
|
|
147
|
+
|
|
148
|
+
class TestSprintPackage:
|
|
149
|
+
"""Tests for sprint/ library package."""
|
|
150
|
+
|
|
151
|
+
def test_sprint_package_exists(self) -> None:
|
|
152
|
+
"""sprint/ package should exist and be importable."""
|
|
153
|
+
from pennyfarthing_scripts import sprint
|
|
154
|
+
|
|
155
|
+
# Should be a package, not the old flat module
|
|
156
|
+
assert hasattr(sprint, "__path__")
|
|
157
|
+
|
|
158
|
+
def test_loader_module_in_sprint(self) -> None:
|
|
159
|
+
"""loader.py should provide sprint YAML loading."""
|
|
160
|
+
from pennyfarthing_scripts.sprint import loader
|
|
161
|
+
|
|
162
|
+
assert hasattr(loader, "load_sprint")
|
|
163
|
+
assert hasattr(loader, "find_epic")
|
|
164
|
+
assert hasattr(loader, "find_story")
|
|
165
|
+
assert hasattr(loader, "get_all_stories")
|
|
166
|
+
assert hasattr(loader, "get_story_by_id")
|
|
167
|
+
|
|
168
|
+
def test_status_module_in_sprint(self) -> None:
|
|
169
|
+
"""status.py should provide sprint status operations."""
|
|
170
|
+
from pennyfarthing_scripts.sprint import status
|
|
171
|
+
|
|
172
|
+
assert hasattr(status, "get_sprint_status")
|
|
173
|
+
assert hasattr(status, "format_status")
|
|
174
|
+
|
|
175
|
+
def test_work_module_in_sprint(self) -> None:
|
|
176
|
+
"""work.py should provide work session management."""
|
|
177
|
+
from pennyfarthing_scripts.sprint import work
|
|
178
|
+
|
|
179
|
+
assert hasattr(work, "start_work")
|
|
180
|
+
assert hasattr(work, "check_story")
|
|
181
|
+
|
|
182
|
+
def test_archive_module_in_sprint(self) -> None:
|
|
183
|
+
"""archive.py should provide story archiving."""
|
|
184
|
+
from pennyfarthing_scripts.sprint import archive
|
|
185
|
+
|
|
186
|
+
assert hasattr(archive, "archive_story")
|
|
187
|
+
|
|
188
|
+
def test_sprint_package_reexports(self) -> None:
|
|
189
|
+
"""sprint/__init__.py should re-export commonly used items."""
|
|
190
|
+
from pennyfarthing_scripts.sprint import (
|
|
191
|
+
load_sprint,
|
|
192
|
+
find_epic,
|
|
193
|
+
find_story,
|
|
194
|
+
get_all_stories,
|
|
195
|
+
)
|
|
196
|
+
|
|
197
|
+
assert callable(load_sprint)
|
|
198
|
+
assert callable(find_epic)
|
|
199
|
+
|
|
200
|
+
def test_sprint_backwards_compatibility(self) -> None:
|
|
201
|
+
"""Old-style imports should still work."""
|
|
202
|
+
from pennyfarthing_scripts.sprint import load_sprint
|
|
203
|
+
from pennyfarthing_scripts.sprint import find_epic
|
|
204
|
+
from pennyfarthing_scripts.sprint import load_current_sprint
|
|
205
|
+
|
|
206
|
+
assert callable(load_sprint)
|
|
207
|
+
assert callable(find_epic)
|
|
208
|
+
assert callable(load_current_sprint)
|
|
209
|
+
|
|
210
|
+
|
|
211
|
+
class TestStoryPackage:
|
|
212
|
+
"""Tests for story/ library package."""
|
|
213
|
+
|
|
214
|
+
def test_story_package_exists(self) -> None:
|
|
215
|
+
"""story/ package should exist and be importable."""
|
|
216
|
+
from pennyfarthing_scripts import story
|
|
217
|
+
|
|
218
|
+
# Should be a package
|
|
219
|
+
assert hasattr(story, "__path__")
|
|
220
|
+
|
|
221
|
+
def test_size_module_in_story(self) -> None:
|
|
222
|
+
"""size.py should provide story sizing utilities."""
|
|
223
|
+
from pennyfarthing_scripts.story import size
|
|
224
|
+
|
|
225
|
+
assert hasattr(size, "get_sizing_guidelines")
|
|
226
|
+
assert hasattr(size, "format_size_info")
|
|
227
|
+
|
|
228
|
+
def test_template_module_in_story(self) -> None:
|
|
229
|
+
"""template.py should provide story templates."""
|
|
230
|
+
from pennyfarthing_scripts.story import template
|
|
231
|
+
|
|
232
|
+
assert hasattr(template, "get_template")
|
|
233
|
+
assert hasattr(template, "get_all_templates")
|
|
234
|
+
|
|
235
|
+
def test_create_module_in_story(self) -> None:
|
|
236
|
+
"""create.py should provide story creation."""
|
|
237
|
+
from pennyfarthing_scripts.story import create
|
|
238
|
+
|
|
239
|
+
assert hasattr(create, "create_story")
|
|
240
|
+
assert hasattr(create, "generate_story_yaml")
|
|
241
|
+
|
|
242
|
+
|
|
243
|
+
class TestJiraCLI:
|
|
244
|
+
"""Tests for jira.py CLI entry point."""
|
|
245
|
+
|
|
246
|
+
def test_jira_cli_has_main(self) -> None:
|
|
247
|
+
"""jira.py should have a main() entry point."""
|
|
248
|
+
# Import the CLI module (not the package)
|
|
249
|
+
import pennyfarthing_scripts.jira as jira_pkg
|
|
250
|
+
|
|
251
|
+
# The package's __main__.py or main module should have main()
|
|
252
|
+
assert hasattr(jira_pkg, "main") or hasattr(jira_pkg, "cli")
|
|
253
|
+
|
|
254
|
+
def test_jira_cli_subcommands(self) -> None:
|
|
255
|
+
"""jira CLI should support expected subcommands."""
|
|
256
|
+
from pennyfarthing_scripts.jira import cli
|
|
257
|
+
|
|
258
|
+
# CLI should define these subcommands
|
|
259
|
+
assert hasattr(cli, "view") or "view" in dir(cli)
|
|
260
|
+
assert hasattr(cli, "claim") or "claim" in dir(cli)
|
|
261
|
+
assert hasattr(cli, "sync") or "sync" in dir(cli)
|
|
262
|
+
assert hasattr(cli, "create") or "create" in dir(cli)
|
|
263
|
+
assert hasattr(cli, "bidirectional") or "bidirectional" in dir(cli)
|
|
264
|
+
|
|
265
|
+
def test_jira_cli_runnable_as_module(self) -> None:
|
|
266
|
+
"""python -m pennyfarthing_scripts.jira should work."""
|
|
267
|
+
import subprocess
|
|
268
|
+
|
|
269
|
+
result = subprocess.run(
|
|
270
|
+
[sys.executable, "-m", "pennyfarthing_scripts.jira", "--help"],
|
|
271
|
+
capture_output=True,
|
|
272
|
+
text=True,
|
|
273
|
+
)
|
|
274
|
+
# Should exit 0 with help text
|
|
275
|
+
assert result.returncode == 0
|
|
276
|
+
assert "usage" in result.stdout.lower() or "Usage" in result.stdout
|
|
277
|
+
|
|
278
|
+
|
|
279
|
+
class TestSprintCLI:
|
|
280
|
+
"""Tests for sprint.py CLI entry point."""
|
|
281
|
+
|
|
282
|
+
def test_sprint_cli_has_main(self) -> None:
|
|
283
|
+
"""sprint.py should have a main() entry point."""
|
|
284
|
+
import pennyfarthing_scripts.sprint as sprint_pkg
|
|
285
|
+
|
|
286
|
+
assert hasattr(sprint_pkg, "main") or hasattr(sprint_pkg, "cli")
|
|
287
|
+
|
|
288
|
+
def test_sprint_cli_subcommands(self) -> None:
|
|
289
|
+
"""sprint CLI should support expected subcommands."""
|
|
290
|
+
from pennyfarthing_scripts.sprint import cli
|
|
291
|
+
|
|
292
|
+
# CLI should define these subcommands based on skill.md
|
|
293
|
+
assert hasattr(cli, "status") or "status" in dir(cli)
|
|
294
|
+
assert hasattr(cli, "backlog") or "backlog" in dir(cli)
|
|
295
|
+
assert hasattr(cli, "work") or "work" in dir(cli)
|
|
296
|
+
assert hasattr(cli, "archive") or "archive" in dir(cli)
|
|
297
|
+
|
|
298
|
+
def test_sprint_cli_runnable_as_module(self) -> None:
|
|
299
|
+
"""python -m pennyfarthing_scripts.sprint should work."""
|
|
300
|
+
import subprocess
|
|
301
|
+
|
|
302
|
+
result = subprocess.run(
|
|
303
|
+
[sys.executable, "-m", "pennyfarthing_scripts.sprint", "--help"],
|
|
304
|
+
capture_output=True,
|
|
305
|
+
text=True,
|
|
306
|
+
)
|
|
307
|
+
assert result.returncode == 0
|
|
308
|
+
assert "usage" in result.stdout.lower() or "Usage" in result.stdout
|
|
309
|
+
|
|
310
|
+
|
|
311
|
+
class TestStoryCLI:
|
|
312
|
+
"""Tests for story.py CLI entry point."""
|
|
313
|
+
|
|
314
|
+
def test_story_cli_has_main(self) -> None:
|
|
315
|
+
"""story.py should have a main() entry point."""
|
|
316
|
+
import pennyfarthing_scripts.story as story_pkg
|
|
317
|
+
|
|
318
|
+
assert hasattr(story_pkg, "main") or hasattr(story_pkg, "cli")
|
|
319
|
+
|
|
320
|
+
def test_story_cli_subcommands(self) -> None:
|
|
321
|
+
"""story CLI should support expected subcommands."""
|
|
322
|
+
from pennyfarthing_scripts.story import cli
|
|
323
|
+
|
|
324
|
+
# CLI should define these subcommands based on skill.md
|
|
325
|
+
assert hasattr(cli, "size") or "size" in dir(cli)
|
|
326
|
+
assert hasattr(cli, "template") or "template" in dir(cli)
|
|
327
|
+
assert hasattr(cli, "create") or "create" in dir(cli)
|
|
328
|
+
|
|
329
|
+
def test_story_cli_runnable_as_module(self) -> None:
|
|
330
|
+
"""python -m pennyfarthing_scripts.story should work."""
|
|
331
|
+
import subprocess
|
|
332
|
+
|
|
333
|
+
result = subprocess.run(
|
|
334
|
+
[sys.executable, "-m", "pennyfarthing_scripts.story", "--help"],
|
|
335
|
+
capture_output=True,
|
|
336
|
+
text=True,
|
|
337
|
+
)
|
|
338
|
+
assert result.returncode == 0
|
|
339
|
+
assert "usage" in result.stdout.lower() or "Usage" in result.stdout
|
|
340
|
+
|
|
341
|
+
|
|
342
|
+
class TestOldModuleCompatibility:
|
|
343
|
+
"""Tests ensuring old flat modules still work."""
|
|
344
|
+
|
|
345
|
+
def test_jira_sync_module_works(self) -> None:
|
|
346
|
+
"""jira_sync.py should still be importable and functional."""
|
|
347
|
+
from pennyfarthing_scripts import jira_sync
|
|
348
|
+
|
|
349
|
+
assert hasattr(jira_sync, "sync_epic")
|
|
350
|
+
assert hasattr(jira_sync, "sync_story")
|
|
351
|
+
assert hasattr(jira_sync, "main")
|
|
352
|
+
|
|
353
|
+
def test_jira_bidirectional_sync_module_works(self) -> None:
|
|
354
|
+
"""jira_bidirectional_sync.py should still be importable."""
|
|
355
|
+
from pennyfarthing_scripts import jira_bidirectional_sync
|
|
356
|
+
|
|
357
|
+
assert hasattr(jira_bidirectional_sync, "generate_sync_plan")
|
|
358
|
+
assert hasattr(jira_bidirectional_sync, "main")
|
|
359
|
+
|
|
360
|
+
def test_jira_epic_creation_module_works(self) -> None:
|
|
361
|
+
"""jira_epic_creation.py should still be importable."""
|
|
362
|
+
from pennyfarthing_scripts import jira_epic_creation
|
|
363
|
+
|
|
364
|
+
assert hasattr(jira_epic_creation, "create_epic")
|
|
365
|
+
assert hasattr(jira_epic_creation, "main")
|
|
366
|
+
|
|
367
|
+
def test_jira_sync_story_module_works(self) -> None:
|
|
368
|
+
"""jira_sync_story.py should still be importable."""
|
|
369
|
+
from pennyfarthing_scripts import jira_sync_story
|
|
370
|
+
|
|
371
|
+
assert hasattr(jira_sync_story, "sync_story")
|
|
372
|
+
assert hasattr(jira_sync_story, "main")
|