@bastani/atomic 0.6.8 → 0.7.0-2
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/bin/atomic +65 -0
- package/package.json +17 -82
- package/postinstall.mjs +47 -0
- package/.agents/skills/ado-commit/SKILL.md +0 -94
- package/.agents/skills/ado-create-pr/SKILL.md +0 -211
- package/.agents/skills/advanced-evaluation/SKILL.md +0 -404
- package/.agents/skills/advanced-evaluation/references/bias-mitigation.md +0 -288
- package/.agents/skills/advanced-evaluation/references/evaluation-pipeline.md +0 -43
- package/.agents/skills/advanced-evaluation/references/implementation-patterns.md +0 -315
- package/.agents/skills/advanced-evaluation/references/metrics-guide.md +0 -331
- package/.agents/skills/advanced-evaluation/scripts/evaluation_example.py +0 -392
- package/.agents/skills/ast-grep/SKILL.md +0 -325
- package/.agents/skills/ast-grep/references/rule_reference.md +0 -297
- package/.agents/skills/bdi-mental-states/SKILL.md +0 -313
- package/.agents/skills/bdi-mental-states/references/bdi-ontology-core.md +0 -207
- package/.agents/skills/bdi-mental-states/references/framework-integration.md +0 -582
- package/.agents/skills/bdi-mental-states/references/rdf-examples.md +0 -315
- package/.agents/skills/bdi-mental-states/references/sparql-competency.md +0 -420
- package/.agents/skills/bun/SKILL.md +0 -233
- package/.agents/skills/context-compression/SKILL.md +0 -274
- package/.agents/skills/context-compression/references/evaluation-framework.md +0 -213
- package/.agents/skills/context-compression/scripts/compression_evaluator.py +0 -862
- package/.agents/skills/context-compression/tests/test_compression_evaluator.py +0 -56
- package/.agents/skills/context-degradation/SKILL.md +0 -208
- package/.agents/skills/context-degradation/references/patterns.md +0 -314
- package/.agents/skills/context-degradation/scripts/degradation_detector.py +0 -614
- package/.agents/skills/context-fundamentals/SKILL.md +0 -203
- package/.agents/skills/context-fundamentals/references/context-components.md +0 -283
- package/.agents/skills/context-fundamentals/scripts/context_manager.py +0 -533
- package/.agents/skills/context-optimization/SKILL.md +0 -197
- package/.agents/skills/context-optimization/references/optimization_techniques.md +0 -272
- package/.agents/skills/context-optimization/scripts/compaction.py +0 -562
- package/.agents/skills/create-spec/SKILL.md +0 -249
- package/.agents/skills/docx/LICENSE.txt +0 -30
- package/.agents/skills/docx/SKILL.md +0 -592
- package/.agents/skills/docx/scripts/__init__.py +0 -1
- package/.agents/skills/docx/scripts/accept_changes.py +0 -135
- package/.agents/skills/docx/scripts/comment.py +0 -318
- package/.agents/skills/docx/scripts/office/helpers/__init__.py +0 -0
- package/.agents/skills/docx/scripts/office/helpers/merge_runs.py +0 -199
- package/.agents/skills/docx/scripts/office/helpers/simplify_redlines.py +0 -197
- package/.agents/skills/docx/scripts/office/pack.py +0 -159
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
- package/.agents/skills/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
- package/.agents/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
- package/.agents/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
- package/.agents/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
- package/.agents/skills/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
- package/.agents/skills/docx/scripts/office/schemas/mce/mc.xsd +0 -75
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
- package/.agents/skills/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
- package/.agents/skills/docx/scripts/office/soffice.py +0 -183
- package/.agents/skills/docx/scripts/office/unpack.py +0 -132
- package/.agents/skills/docx/scripts/office/validate.py +0 -111
- package/.agents/skills/docx/scripts/office/validators/__init__.py +0 -15
- package/.agents/skills/docx/scripts/office/validators/base.py +0 -847
- package/.agents/skills/docx/scripts/office/validators/docx.py +0 -446
- package/.agents/skills/docx/scripts/office/validators/pptx.py +0 -275
- package/.agents/skills/docx/scripts/office/validators/redlining.py +0 -247
- package/.agents/skills/docx/scripts/templates/comments.xml +0 -3
- package/.agents/skills/docx/scripts/templates/commentsExtended.xml +0 -3
- package/.agents/skills/docx/scripts/templates/commentsExtensible.xml +0 -3
- package/.agents/skills/docx/scripts/templates/commentsIds.xml +0 -3
- package/.agents/skills/docx/scripts/templates/people.xml +0 -3
- package/.agents/skills/evaluation/SKILL.md +0 -253
- package/.agents/skills/evaluation/references/metrics.md +0 -339
- package/.agents/skills/evaluation/scripts/evaluator.py +0 -627
- package/.agents/skills/explain-code/SKILL.md +0 -232
- package/.agents/skills/filesystem-context/SKILL.md +0 -289
- package/.agents/skills/filesystem-context/references/implementation-patterns.md +0 -549
- package/.agents/skills/filesystem-context/scripts/filesystem_context.py +0 -425
- package/.agents/skills/find-skills/SKILL.md +0 -144
- package/.agents/skills/gh-commit/SKILL.md +0 -245
- package/.agents/skills/gh-create-pr/SKILL.md +0 -95
- package/.agents/skills/hosted-agents/SKILL.md +0 -262
- package/.agents/skills/hosted-agents/references/infrastructure-patterns.md +0 -700
- package/.agents/skills/hosted-agents/scripts/sandbox_manager.py +0 -590
- package/.agents/skills/impeccable/SKILL.md +0 -178
- package/.agents/skills/impeccable/agents/openai.yaml +0 -4
- package/.agents/skills/impeccable/reference/adapt.md +0 -190
- package/.agents/skills/impeccable/reference/animate.md +0 -175
- package/.agents/skills/impeccable/reference/audit.md +0 -134
- package/.agents/skills/impeccable/reference/bolder.md +0 -113
- package/.agents/skills/impeccable/reference/brand.md +0 -114
- package/.agents/skills/impeccable/reference/clarify.md +0 -174
- package/.agents/skills/impeccable/reference/cognitive-load.md +0 -106
- package/.agents/skills/impeccable/reference/color-and-contrast.md +0 -105
- package/.agents/skills/impeccable/reference/colorize.md +0 -154
- package/.agents/skills/impeccable/reference/craft.md +0 -193
- package/.agents/skills/impeccable/reference/critique.md +0 -213
- package/.agents/skills/impeccable/reference/delight.md +0 -302
- package/.agents/skills/impeccable/reference/distill.md +0 -111
- package/.agents/skills/impeccable/reference/document.md +0 -427
- package/.agents/skills/impeccable/reference/extract.md +0 -70
- package/.agents/skills/impeccable/reference/harden.md +0 -347
- package/.agents/skills/impeccable/reference/heuristics-scoring.md +0 -234
- package/.agents/skills/impeccable/reference/interaction-design.md +0 -195
- package/.agents/skills/impeccable/reference/layout.md +0 -141
- package/.agents/skills/impeccable/reference/live.md +0 -594
- package/.agents/skills/impeccable/reference/motion-design.md +0 -109
- package/.agents/skills/impeccable/reference/onboard.md +0 -234
- package/.agents/skills/impeccable/reference/optimize.md +0 -258
- package/.agents/skills/impeccable/reference/overdrive.md +0 -130
- package/.agents/skills/impeccable/reference/personas.md +0 -178
- package/.agents/skills/impeccable/reference/polish.md +0 -232
- package/.agents/skills/impeccable/reference/product.md +0 -62
- package/.agents/skills/impeccable/reference/quieter.md +0 -99
- package/.agents/skills/impeccable/reference/responsive-design.md +0 -114
- package/.agents/skills/impeccable/reference/shape.md +0 -151
- package/.agents/skills/impeccable/reference/spatial-design.md +0 -100
- package/.agents/skills/impeccable/reference/teach.md +0 -156
- package/.agents/skills/impeccable/reference/typeset.md +0 -124
- package/.agents/skills/impeccable/reference/typography.md +0 -159
- package/.agents/skills/impeccable/reference/ux-writing.md +0 -107
- package/.agents/skills/impeccable/scripts/cleanup-deprecated.mjs +0 -284
- package/.agents/skills/impeccable/scripts/command-metadata.json +0 -94
- package/.agents/skills/impeccable/scripts/design-parser.mjs +0 -820
- package/.agents/skills/impeccable/scripts/detect-csp.mjs +0 -198
- package/.agents/skills/impeccable/scripts/is-generated.mjs +0 -69
- package/.agents/skills/impeccable/scripts/live-accept.mjs +0 -595
- package/.agents/skills/impeccable/scripts/live-browser.js +0 -4781
- package/.agents/skills/impeccable/scripts/live-inject.mjs +0 -445
- package/.agents/skills/impeccable/scripts/live-poll.mjs +0 -186
- package/.agents/skills/impeccable/scripts/live-server.mjs +0 -694
- package/.agents/skills/impeccable/scripts/live-wrap.mjs +0 -571
- package/.agents/skills/impeccable/scripts/live.mjs +0 -247
- package/.agents/skills/impeccable/scripts/load-context.mjs +0 -141
- package/.agents/skills/impeccable/scripts/modern-screenshot.umd.js +0 -14
- package/.agents/skills/impeccable/scripts/pin.mjs +0 -214
- package/.agents/skills/init/SKILL.md +0 -140
- package/.agents/skills/liteparse/SKILL.md +0 -223
- package/.agents/skills/memory-systems/SKILL.md +0 -221
- package/.agents/skills/memory-systems/references/implementation.md +0 -551
- package/.agents/skills/memory-systems/scripts/memory_store.py +0 -616
- package/.agents/skills/multi-agent-patterns/SKILL.md +0 -259
- package/.agents/skills/multi-agent-patterns/references/frameworks.md +0 -433
- package/.agents/skills/multi-agent-patterns/scripts/coordination.py +0 -613
- package/.agents/skills/opentui/SKILL.md +0 -202
- package/.agents/skills/opentui/references/animation/REFERENCE.md +0 -431
- package/.agents/skills/opentui/references/components/REFERENCE.md +0 -144
- package/.agents/skills/opentui/references/components/code-diff.md +0 -672
- package/.agents/skills/opentui/references/components/containers.md +0 -417
- package/.agents/skills/opentui/references/components/inputs.md +0 -531
- package/.agents/skills/opentui/references/components/text-display.md +0 -386
- package/.agents/skills/opentui/references/core/REFERENCE.md +0 -145
- package/.agents/skills/opentui/references/core/api.md +0 -543
- package/.agents/skills/opentui/references/core/configuration.md +0 -168
- package/.agents/skills/opentui/references/core/gotchas.md +0 -393
- package/.agents/skills/opentui/references/core/patterns.md +0 -449
- package/.agents/skills/opentui/references/keyboard/REFERENCE.md +0 -617
- package/.agents/skills/opentui/references/layout/REFERENCE.md +0 -337
- package/.agents/skills/opentui/references/layout/patterns.md +0 -444
- package/.agents/skills/opentui/references/react/REFERENCE.md +0 -174
- package/.agents/skills/opentui/references/react/api.md +0 -436
- package/.agents/skills/opentui/references/react/configuration.md +0 -302
- package/.agents/skills/opentui/references/react/gotchas.md +0 -443
- package/.agents/skills/opentui/references/react/patterns.md +0 -501
- package/.agents/skills/opentui/references/solid/REFERENCE.md +0 -201
- package/.agents/skills/opentui/references/solid/api.md +0 -564
- package/.agents/skills/opentui/references/solid/configuration.md +0 -316
- package/.agents/skills/opentui/references/solid/gotchas.md +0 -427
- package/.agents/skills/opentui/references/solid/patterns.md +0 -560
- package/.agents/skills/opentui/references/testing/REFERENCE.md +0 -614
- package/.agents/skills/pdf/LICENSE.txt +0 -30
- package/.agents/skills/pdf/SKILL.md +0 -316
- package/.agents/skills/pdf/forms.md +0 -294
- package/.agents/skills/pdf/reference.md +0 -612
- package/.agents/skills/pdf/scripts/check_bounding_boxes.py +0 -65
- package/.agents/skills/pdf/scripts/check_fillable_fields.py +0 -11
- package/.agents/skills/pdf/scripts/convert_pdf_to_images.py +0 -33
- package/.agents/skills/pdf/scripts/create_validation_image.py +0 -37
- package/.agents/skills/pdf/scripts/extract_form_field_info.py +0 -122
- package/.agents/skills/pdf/scripts/extract_form_structure.py +0 -115
- package/.agents/skills/pdf/scripts/fill_fillable_fields.py +0 -98
- package/.agents/skills/pdf/scripts/fill_pdf_form_with_annotations.py +0 -107
- package/.agents/skills/playwright-cli/SKILL.md +0 -390
- package/.agents/skills/playwright-cli/references/element-attributes.md +0 -23
- package/.agents/skills/playwright-cli/references/playwright-tests.md +0 -39
- package/.agents/skills/playwright-cli/references/request-mocking.md +0 -87
- package/.agents/skills/playwright-cli/references/running-code.md +0 -241
- package/.agents/skills/playwright-cli/references/session-management.md +0 -225
- package/.agents/skills/playwright-cli/references/spec-driven-testing.md +0 -305
- package/.agents/skills/playwright-cli/references/storage-state.md +0 -275
- package/.agents/skills/playwright-cli/references/test-generation.md +0 -134
- package/.agents/skills/playwright-cli/references/tracing.md +0 -139
- package/.agents/skills/playwright-cli/references/video-recording.md +0 -143
- package/.agents/skills/pptx/LICENSE.txt +0 -30
- package/.agents/skills/pptx/SKILL.md +0 -234
- package/.agents/skills/pptx/editing.md +0 -205
- package/.agents/skills/pptx/pptxgenjs.md +0 -420
- package/.agents/skills/pptx/scripts/__init__.py +0 -0
- package/.agents/skills/pptx/scripts/add_slide.py +0 -195
- package/.agents/skills/pptx/scripts/clean.py +0 -286
- package/.agents/skills/pptx/scripts/office/helpers/__init__.py +0 -0
- package/.agents/skills/pptx/scripts/office/helpers/merge_runs.py +0 -199
- package/.agents/skills/pptx/scripts/office/helpers/simplify_redlines.py +0 -197
- package/.agents/skills/pptx/scripts/office/pack.py +0 -159
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
- package/.agents/skills/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
- package/.agents/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
- package/.agents/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
- package/.agents/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
- package/.agents/skills/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
- package/.agents/skills/pptx/scripts/office/schemas/mce/mc.xsd +0 -75
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
- package/.agents/skills/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
- package/.agents/skills/pptx/scripts/office/soffice.py +0 -183
- package/.agents/skills/pptx/scripts/office/unpack.py +0 -132
- package/.agents/skills/pptx/scripts/office/validate.py +0 -111
- package/.agents/skills/pptx/scripts/office/validators/__init__.py +0 -15
- package/.agents/skills/pptx/scripts/office/validators/base.py +0 -847
- package/.agents/skills/pptx/scripts/office/validators/docx.py +0 -446
- package/.agents/skills/pptx/scripts/office/validators/pptx.py +0 -275
- package/.agents/skills/pptx/scripts/office/validators/redlining.py +0 -247
- package/.agents/skills/pptx/scripts/thumbnail.py +0 -289
- package/.agents/skills/project-development/SKILL.md +0 -293
- package/.agents/skills/project-development/references/case-studies.md +0 -388
- package/.agents/skills/project-development/references/pipeline-patterns.md +0 -610
- package/.agents/skills/project-development/scripts/pipeline_template.py +0 -796
- package/.agents/skills/prompt-engineer/SKILL.md +0 -265
- package/.agents/skills/prompt-engineer/references/advanced_patterns.md +0 -271
- package/.agents/skills/prompt-engineer/references/core_prompting.md +0 -137
- package/.agents/skills/prompt-engineer/references/quality_improvement.md +0 -193
- package/.agents/skills/research-codebase/SKILL.md +0 -229
- package/.agents/skills/ripgrep/SKILL.md +0 -384
- package/.agents/skills/skill-creator/LICENSE.txt +0 -202
- package/.agents/skills/skill-creator/SKILL.md +0 -487
- package/.agents/skills/skill-creator/agents/analyzer.md +0 -274
- package/.agents/skills/skill-creator/agents/comparator.md +0 -202
- package/.agents/skills/skill-creator/agents/grader.md +0 -223
- package/.agents/skills/skill-creator/assets/eval_review.html +0 -146
- package/.agents/skills/skill-creator/eval-viewer/generate_review.py +0 -471
- package/.agents/skills/skill-creator/eval-viewer/viewer.html +0 -1325
- package/.agents/skills/skill-creator/references/schemas.md +0 -430
- package/.agents/skills/skill-creator/scripts/__init__.py +0 -0
- package/.agents/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
- package/.agents/skills/skill-creator/scripts/generate_report.py +0 -326
- package/.agents/skills/skill-creator/scripts/improve_description.py +0 -247
- package/.agents/skills/skill-creator/scripts/package_skill.py +0 -136
- package/.agents/skills/skill-creator/scripts/quick_validate.py +0 -103
- package/.agents/skills/skill-creator/scripts/run_eval.py +0 -310
- package/.agents/skills/skill-creator/scripts/run_loop.py +0 -328
- package/.agents/skills/skill-creator/scripts/utils.py +0 -47
- package/.agents/skills/sl-commit/SKILL.md +0 -53
- package/.agents/skills/sl-submit-diff/SKILL.md +0 -57
- package/.agents/skills/tdd/SKILL.md +0 -111
- package/.agents/skills/tdd/deep-modules.md +0 -33
- package/.agents/skills/tdd/interface-design.md +0 -31
- package/.agents/skills/tdd/mocking.md +0 -59
- package/.agents/skills/tdd/refactoring.md +0 -10
- package/.agents/skills/tdd/tests.md +0 -61
- package/.agents/skills/tool-design/SKILL.md +0 -273
- package/.agents/skills/tool-design/references/architectural_reduction.md +0 -210
- package/.agents/skills/tool-design/references/best_practices.md +0 -176
- package/.agents/skills/tool-design/scripts/description_generator.py +0 -528
- package/.agents/skills/typescript-advanced-types/SKILL.md +0 -720
- package/.agents/skills/typescript-expert/SKILL.md +0 -434
- package/.agents/skills/typescript-expert/references/tsconfig-strict.json +0 -92
- package/.agents/skills/typescript-expert/references/typescript-cheatsheet.md +0 -383
- package/.agents/skills/typescript-expert/references/utility-types.ts +0 -335
- package/.agents/skills/typescript-expert/scripts/ts_diagnostic.py +0 -203
- package/.agents/skills/typescript-react-reviewer/SKILL.md +0 -201
- package/.agents/skills/typescript-react-reviewer/references/antipatterns.md +0 -510
- package/.agents/skills/typescript-react-reviewer/references/checklist.md +0 -267
- package/.agents/skills/typescript-react-reviewer/references/react19-patterns.md +0 -305
- package/.agents/skills/workflow-creator/SKILL.md +0 -553
- package/.agents/skills/workflow-creator/references/agent-sessions.md +0 -891
- package/.agents/skills/workflow-creator/references/agent-setup-recipe.md +0 -266
- package/.agents/skills/workflow-creator/references/computation-and-validation.md +0 -201
- package/.agents/skills/workflow-creator/references/control-flow.md +0 -470
- package/.agents/skills/workflow-creator/references/failure-modes.md +0 -1014
- package/.agents/skills/workflow-creator/references/getting-started.md +0 -392
- package/.agents/skills/workflow-creator/references/registry-and-validation.md +0 -141
- package/.agents/skills/workflow-creator/references/running-workflows.md +0 -418
- package/.agents/skills/workflow-creator/references/session-config.md +0 -431
- package/.agents/skills/workflow-creator/references/state-and-data-flow.md +0 -356
- package/.agents/skills/workflow-creator/references/user-input.md +0 -234
- package/.agents/skills/workflow-creator/references/workflow-inputs.md +0 -392
- package/.agents/skills/xlsx/LICENSE.txt +0 -30
- package/.agents/skills/xlsx/SKILL.md +0 -294
- package/.agents/skills/xlsx/scripts/office/helpers/__init__.py +0 -0
- package/.agents/skills/xlsx/scripts/office/helpers/merge_runs.py +0 -199
- package/.agents/skills/xlsx/scripts/office/helpers/simplify_redlines.py +0 -197
- package/.agents/skills/xlsx/scripts/office/pack.py +0 -159
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
- package/.agents/skills/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
- package/.agents/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
- package/.agents/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
- package/.agents/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
- package/.agents/skills/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
- package/.agents/skills/xlsx/scripts/office/schemas/mce/mc.xsd +0 -75
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
- package/.agents/skills/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
- package/.agents/skills/xlsx/scripts/office/soffice.py +0 -183
- package/.agents/skills/xlsx/scripts/office/unpack.py +0 -132
- package/.agents/skills/xlsx/scripts/office/validate.py +0 -111
- package/.agents/skills/xlsx/scripts/office/validators/__init__.py +0 -15
- package/.agents/skills/xlsx/scripts/office/validators/base.py +0 -847
- package/.agents/skills/xlsx/scripts/office/validators/docx.py +0 -446
- package/.agents/skills/xlsx/scripts/office/validators/pptx.py +0 -275
- package/.agents/skills/xlsx/scripts/office/validators/redlining.py +0 -247
- package/.agents/skills/xlsx/scripts/recalc.py +0 -184
- package/.claude/agents/code-simplifier.md +0 -52
- package/.claude/agents/codebase-analyzer.md +0 -166
- package/.claude/agents/codebase-locator.md +0 -122
- package/.claude/agents/codebase-online-researcher.md +0 -148
- package/.claude/agents/codebase-pattern-finder.md +0 -247
- package/.claude/agents/codebase-research-analyzer.md +0 -179
- package/.claude/agents/codebase-research-locator.md +0 -145
- package/.claude/agents/debugger.md +0 -91
- package/.claude/agents/orchestrator.md +0 -19
- package/.claude/agents/planner.md +0 -295
- package/.claude/agents/reviewer.md +0 -98
- package/.claude/agents/worker.md +0 -165
- package/.claude/settings.json +0 -27
- package/.github/agents/code-simplifier.md +0 -52
- package/.github/agents/codebase-analyzer.md +0 -166
- package/.github/agents/codebase-locator.md +0 -122
- package/.github/agents/codebase-online-researcher.md +0 -146
- package/.github/agents/codebase-pattern-finder.md +0 -247
- package/.github/agents/codebase-research-analyzer.md +0 -179
- package/.github/agents/codebase-research-locator.md +0 -145
- package/.github/agents/debugger.md +0 -98
- package/.github/agents/orchestrator.md +0 -27
- package/.github/agents/planner.md +0 -305
- package/.github/agents/reviewer.md +0 -95
- package/.github/agents/worker.md +0 -237
- package/.github/lsp.json +0 -93
- package/.mcp.json +0 -20
- package/.opencode/agents/code-simplifier.md +0 -62
- package/.opencode/agents/codebase-analyzer.md +0 -171
- package/.opencode/agents/codebase-locator.md +0 -127
- package/.opencode/agents/codebase-online-researcher.md +0 -152
- package/.opencode/agents/codebase-pattern-finder.md +0 -252
- package/.opencode/agents/codebase-research-analyzer.md +0 -183
- package/.opencode/agents/codebase-research-locator.md +0 -149
- package/.opencode/agents/debugger.md +0 -99
- package/.opencode/agents/orchestrator.md +0 -27
- package/.opencode/agents/planner.md +0 -309
- package/.opencode/agents/reviewer.md +0 -103
- package/.opencode/agents/worker.md +0 -165
- package/.opencode/opencode.json +0 -25
- package/README.md +0 -1624
- package/assets/settings.schema.json +0 -51
- package/dist/commands/cli/claude-inflight-hook.d.ts +0 -100
- package/dist/commands/cli/claude-inflight-hook.d.ts.map +0 -1
- package/dist/commands/cli/claude-stop-hook.d.ts +0 -80
- package/dist/commands/cli/claude-stop-hook.d.ts.map +0 -1
- package/dist/lib/atomic-temp.d.ts +0 -8
- package/dist/lib/atomic-temp.d.ts.map +0 -1
- package/dist/lib/path-root-guard.d.ts +0 -4
- package/dist/lib/path-root-guard.d.ts.map +0 -1
- package/dist/lib/spawn.d.ts +0 -102
- package/dist/lib/spawn.d.ts.map +0 -1
- package/dist/lib/terminal-env.d.ts +0 -9
- package/dist/lib/terminal-env.d.ts.map +0 -1
- package/dist/sdk/components/attached-statusline.d.ts +0 -26
- package/dist/sdk/components/attached-statusline.d.ts.map +0 -1
- package/dist/sdk/components/color-utils.d.ts +0 -4
- package/dist/sdk/components/color-utils.d.ts.map +0 -1
- package/dist/sdk/components/compact-switcher.d.ts +0 -10
- package/dist/sdk/components/compact-switcher.d.ts.map +0 -1
- package/dist/sdk/components/connectors.d.ts +0 -16
- package/dist/sdk/components/connectors.d.ts.map +0 -1
- package/dist/sdk/components/edge.d.ts +0 -4
- package/dist/sdk/components/edge.d.ts.map +0 -1
- package/dist/sdk/components/error-boundary.d.ts +0 -23
- package/dist/sdk/components/error-boundary.d.ts.map +0 -1
- package/dist/sdk/components/graph-theme.d.ts +0 -18
- package/dist/sdk/components/graph-theme.d.ts.map +0 -1
- package/dist/sdk/components/header.d.ts +0 -3
- package/dist/sdk/components/header.d.ts.map +0 -1
- package/dist/sdk/components/hooks.d.ts +0 -15
- package/dist/sdk/components/hooks.d.ts.map +0 -1
- package/dist/sdk/components/layout.d.ts +0 -27
- package/dist/sdk/components/layout.d.ts.map +0 -1
- package/dist/sdk/components/node-card.d.ts +0 -10
- package/dist/sdk/components/node-card.d.ts.map +0 -1
- package/dist/sdk/components/orchestrator-panel-contexts.d.ts +0 -16
- package/dist/sdk/components/orchestrator-panel-contexts.d.ts.map +0 -1
- package/dist/sdk/components/orchestrator-panel-store.d.ts +0 -52
- package/dist/sdk/components/orchestrator-panel-store.d.ts.map +0 -1
- package/dist/sdk/components/orchestrator-panel-types.d.ts +0 -18
- package/dist/sdk/components/orchestrator-panel-types.d.ts.map +0 -1
- package/dist/sdk/components/orchestrator-panel.d.ts +0 -86
- package/dist/sdk/components/orchestrator-panel.d.ts.map +0 -1
- package/dist/sdk/components/renderer-background.d.ts +0 -9
- package/dist/sdk/components/renderer-background.d.ts.map +0 -1
- package/dist/sdk/components/session-graph-panel.d.ts +0 -7
- package/dist/sdk/components/session-graph-panel.d.ts.map +0 -1
- package/dist/sdk/components/status-helpers.d.ts +0 -6
- package/dist/sdk/components/status-helpers.d.ts.map +0 -1
- package/dist/sdk/components/statusline.d.ts +0 -5
- package/dist/sdk/components/statusline.d.ts.map +0 -1
- package/dist/sdk/components/tui-diagnostics.d.ts +0 -56
- package/dist/sdk/components/tui-diagnostics.d.ts.map +0 -1
- package/dist/sdk/components/workflow-picker-panel.d.ts +0 -126
- package/dist/sdk/components/workflow-picker-panel.d.ts.map +0 -1
- package/dist/sdk/define-workflow.d.ts +0 -107
- package/dist/sdk/define-workflow.d.ts.map +0 -1
- package/dist/sdk/errors.d.ts +0 -46
- package/dist/sdk/errors.d.ts.map +0 -1
- package/dist/sdk/index.d.ts +0 -26
- package/dist/sdk/index.d.ts.map +0 -1
- package/dist/sdk/primitives/inputs.d.ts +0 -36
- package/dist/sdk/primitives/inputs.d.ts.map +0 -1
- package/dist/sdk/primitives/metadata.d.ts +0 -40
- package/dist/sdk/primitives/metadata.d.ts.map +0 -1
- package/dist/sdk/primitives/run.d.ts +0 -57
- package/dist/sdk/primitives/run.d.ts.map +0 -1
- package/dist/sdk/primitives/sessions.d.ts +0 -128
- package/dist/sdk/primitives/sessions.d.ts.map +0 -1
- package/dist/sdk/providers/claude.d.ts +0 -392
- package/dist/sdk/providers/claude.d.ts.map +0 -1
- package/dist/sdk/providers/copilot.d.ts +0 -55
- package/dist/sdk/providers/copilot.d.ts.map +0 -1
- package/dist/sdk/providers/opencode.d.ts +0 -27
- package/dist/sdk/providers/opencode.d.ts.map +0 -1
- package/dist/sdk/registry.d.ts +0 -27
- package/dist/sdk/registry.d.ts.map +0 -1
- package/dist/sdk/runtime/attached-footer.d.ts +0 -31
- package/dist/sdk/runtime/attached-footer.d.ts.map +0 -1
- package/dist/sdk/runtime/cc-debounce.d.ts +0 -29
- package/dist/sdk/runtime/cc-debounce.d.ts.map +0 -1
- package/dist/sdk/runtime/executor-env.d.ts +0 -20
- package/dist/sdk/runtime/executor-env.d.ts.map +0 -1
- package/dist/sdk/runtime/executor.d.ts +0 -265
- package/dist/sdk/runtime/executor.d.ts.map +0 -1
- package/dist/sdk/runtime/graph-inference.d.ts +0 -35
- package/dist/sdk/runtime/graph-inference.d.ts.map +0 -1
- package/dist/sdk/runtime/orchestrator-entry.d.ts +0 -26
- package/dist/sdk/runtime/orchestrator-entry.d.ts.map +0 -1
- package/dist/sdk/runtime/panel.d.ts +0 -9
- package/dist/sdk/runtime/panel.d.ts.map +0 -1
- package/dist/sdk/runtime/port-discovery.d.ts +0 -71
- package/dist/sdk/runtime/port-discovery.d.ts.map +0 -1
- package/dist/sdk/runtime/status-writer.d.ts +0 -101
- package/dist/sdk/runtime/status-writer.d.ts.map +0 -1
- package/dist/sdk/runtime/theme.d.ts +0 -33
- package/dist/sdk/runtime/theme.d.ts.map +0 -1
- package/dist/sdk/runtime/tmux.d.ts +0 -307
- package/dist/sdk/runtime/tmux.d.ts.map +0 -1
- package/dist/sdk/runtime/version-compat.d.ts +0 -28
- package/dist/sdk/runtime/version-compat.d.ts.map +0 -1
- package/dist/sdk/types.d.ts +0 -435
- package/dist/sdk/types.d.ts.map +0 -1
- package/dist/sdk/worker-shared.d.ts +0 -42
- package/dist/sdk/worker-shared.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/claude/index.d.ts +0 -81
- package/dist/sdk/workflows/builtin/deep-research-codebase/claude/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/copilot/index.d.ts +0 -37
- package/dist/sdk/workflows/builtin/deep-research-codebase/copilot/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/batching.d.ts +0 -43
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/batching.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/heuristic.d.ts +0 -14
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/heuristic.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/prompts.d.ts +0 -136
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/prompts.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/scout.d.ts +0 -58
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/scout.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/scratch.d.ts +0 -43
- package/dist/sdk/workflows/builtin/deep-research-codebase/helpers/scratch.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/deep-research-codebase/opencode/index.d.ts +0 -37
- package/dist/sdk/workflows/builtin/deep-research-codebase/opencode/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/claude/index.d.ts +0 -68
- package/dist/sdk/workflows/builtin/open-claude-design/claude/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/copilot/index.d.ts +0 -56
- package/dist/sdk/workflows/builtin/open-claude-design/copilot/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/constants.d.ts +0 -72
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/constants.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/design-system.d.ts +0 -46
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/design-system.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/export.d.ts +0 -32
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/export.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/import.d.ts +0 -33
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/import.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/prompts.d.ts +0 -106
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/prompts.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/scan.d.ts +0 -50
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/scan.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/validation.d.ts +0 -12
- package/dist/sdk/workflows/builtin/open-claude-design/helpers/validation.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/open-claude-design/opencode/index.d.ts +0 -58
- package/dist/sdk/workflows/builtin/open-claude-design/opencode/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/claude/index.d.ts +0 -37
- package/dist/sdk/workflows/builtin/ralph/claude/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/copilot/index.d.ts +0 -34
- package/dist/sdk/workflows/builtin/ralph/copilot/index.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/helpers/copilot-reviewer.d.ts +0 -25
- package/dist/sdk/workflows/builtin/ralph/helpers/copilot-reviewer.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/helpers/git.d.ts +0 -69
- package/dist/sdk/workflows/builtin/ralph/helpers/git.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/helpers/prompts.d.ts +0 -266
- package/dist/sdk/workflows/builtin/ralph/helpers/prompts.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/helpers/review.d.ts +0 -24
- package/dist/sdk/workflows/builtin/ralph/helpers/review.d.ts.map +0 -1
- package/dist/sdk/workflows/builtin/ralph/opencode/index.d.ts +0 -33
- package/dist/sdk/workflows/builtin/ralph/opencode/index.d.ts.map +0 -1
- package/dist/sdk/workflows/index.d.ts +0 -32
- package/dist/sdk/workflows/index.d.ts.map +0 -1
- package/dist/services/config/additional-instructions.d.ts +0 -67
- package/dist/services/config/additional-instructions.d.ts.map +0 -1
- package/dist/services/config/atomic-config.d.ts +0 -42
- package/dist/services/config/atomic-config.d.ts.map +0 -1
- package/dist/services/config/definitions.d.ts +0 -52
- package/dist/services/config/definitions.d.ts.map +0 -1
- package/dist/services/config/index.d.ts +0 -7
- package/dist/services/config/index.d.ts.map +0 -1
- package/dist/services/config/scm-sync.d.ts +0 -37
- package/dist/services/config/scm-sync.d.ts.map +0 -1
- package/dist/services/config/settings-schema.d.ts +0 -2
- package/dist/services/config/settings-schema.d.ts.map +0 -1
- package/dist/services/system/copy.d.ts +0 -84
- package/dist/services/system/copy.d.ts.map +0 -1
- package/dist/services/system/detect.d.ts +0 -75
- package/dist/services/system/detect.d.ts.map +0 -1
- package/dist/theme/colors.d.ts +0 -35
- package/dist/theme/colors.d.ts.map +0 -1
- package/src/cli.ts +0 -397
- package/src/commands/builtin-registry.ts +0 -37
- package/src/commands/cli/chat/index.test.ts +0 -252
- package/src/commands/cli/chat/index.ts +0 -430
- package/src/commands/cli/chat.ts +0 -8
- package/src/commands/cli/claude-ask-hook.test.ts +0 -128
- package/src/commands/cli/claude-ask-hook.ts +0 -84
- package/src/commands/cli/claude-inflight-hook.test.ts +0 -598
- package/src/commands/cli/claude-inflight-hook.ts +0 -359
- package/src/commands/cli/claude-session-start-hook.ts +0 -61
- package/src/commands/cli/claude-stop-hook.test.ts +0 -317
- package/src/commands/cli/claude-stop-hook.ts +0 -441
- package/src/commands/cli/completions.ts +0 -24
- package/src/commands/cli/config.ts +0 -80
- package/src/commands/cli/footer.tsx +0 -248
- package/src/commands/cli/init/index.ts +0 -41
- package/src/commands/cli/init/onboarding.ts +0 -61
- package/src/commands/cli/init.ts +0 -8
- package/src/commands/cli/management-commands.ts +0 -112
- package/src/commands/cli/session.test.ts +0 -830
- package/src/commands/cli/session.ts +0 -447
- package/src/commands/cli/workflow-command.test.ts +0 -618
- package/src/commands/cli/workflow-inputs.test.ts +0 -353
- package/src/commands/cli/workflow-inputs.ts +0 -266
- package/src/commands/cli/workflow-list.test.ts +0 -235
- package/src/commands/cli/workflow-list.ts +0 -0
- package/src/commands/cli/workflow-status.test.ts +0 -451
- package/src/commands/cli/workflow-status.ts +0 -330
- package/src/commands/cli/workflow.ts +0 -196
- package/src/completions/bash.ts +0 -102
- package/src/completions/fish.ts +0 -136
- package/src/completions/index.ts +0 -7
- package/src/completions/powershell.ts +0 -195
- package/src/completions/zsh.ts +0 -150
- package/src/lib/atomic-temp.test.ts +0 -86
- package/src/lib/atomic-temp.ts +0 -62
- package/src/lib/common-ignore.ts +0 -46
- package/src/lib/merge.ts +0 -103
- package/src/lib/path-root-guard.ts +0 -38
- package/src/lib/spawn.test.ts +0 -109
- package/src/lib/spawn.ts +0 -678
- package/src/lib/terminal-env.test.ts +0 -343
- package/src/lib/terminal-env.ts +0 -100
- package/src/scripts/bump-version.ts +0 -94
- package/src/scripts/bundle-configs.ts +0 -116
- package/src/scripts/clean-dist.test.ts +0 -53
- package/src/scripts/clean-dist.ts +0 -37
- package/src/scripts/constants-base.ts +0 -14
- package/src/scripts/constants.ts +0 -35
- package/src/sdk/components/attached-statusline.tsx +0 -86
- package/src/sdk/components/color-utils.ts +0 -20
- package/src/sdk/components/compact-switcher.tsx +0 -78
- package/src/sdk/components/connectors.test.ts +0 -707
- package/src/sdk/components/connectors.ts +0 -160
- package/src/sdk/components/edge.tsx +0 -13
- package/src/sdk/components/error-boundary.tsx +0 -38
- package/src/sdk/components/graph-theme.ts +0 -37
- package/src/sdk/components/header.tsx +0 -85
- package/src/sdk/components/hooks.ts +0 -21
- package/src/sdk/components/layout.test.ts +0 -1245
- package/src/sdk/components/layout.ts +0 -223
- package/src/sdk/components/node-card.tsx +0 -91
- package/src/sdk/components/orchestrator-panel-contexts.ts +0 -35
- package/src/sdk/components/orchestrator-panel-store.test.ts +0 -847
- package/src/sdk/components/orchestrator-panel-store.ts +0 -187
- package/src/sdk/components/orchestrator-panel-types.ts +0 -23
- package/src/sdk/components/orchestrator-panel.tsx +0 -262
- package/src/sdk/components/renderer-background.ts +0 -49
- package/src/sdk/components/session-graph-panel.tsx +0 -471
- package/src/sdk/components/status-helpers.ts +0 -33
- package/src/sdk/components/statusline.tsx +0 -68
- package/src/sdk/components/tui-diagnostics.ts +0 -273
- package/src/sdk/components/workflow-picker-panel.tsx +0 -1613
- package/src/sdk/define-workflow.test.ts +0 -354
- package/src/sdk/define-workflow.ts +0 -275
- package/src/sdk/errors.test.ts +0 -83
- package/src/sdk/errors.ts +0 -77
- package/src/sdk/index.test.ts +0 -92
- package/src/sdk/index.ts +0 -101
- package/src/sdk/primitives/inputs.ts +0 -48
- package/src/sdk/primitives/metadata.ts +0 -63
- package/src/sdk/primitives/run.ts +0 -81
- package/src/sdk/primitives/sessions.test.ts +0 -594
- package/src/sdk/primitives/sessions.ts +0 -328
- package/src/sdk/providers/claude.ts +0 -1450
- package/src/sdk/providers/copilot.test.ts +0 -365
- package/src/sdk/providers/copilot.ts +0 -185
- package/src/sdk/providers/headless-hil-policy.test.ts +0 -211
- package/src/sdk/providers/opencode.ts +0 -88
- package/src/sdk/registry.ts +0 -132
- package/src/sdk/runtime/attached-footer.ts +0 -155
- package/src/sdk/runtime/cc-debounce.ts +0 -104
- package/src/sdk/runtime/executor-env.ts +0 -45
- package/src/sdk/runtime/executor.test.ts +0 -1321
- package/src/sdk/runtime/executor.ts +0 -2136
- package/src/sdk/runtime/graph-inference.ts +0 -50
- package/src/sdk/runtime/orchestrator-entry.ts +0 -110
- package/src/sdk/runtime/panel.tsx +0 -9
- package/src/sdk/runtime/port-discovery.test.ts +0 -573
- package/src/sdk/runtime/port-discovery.ts +0 -496
- package/src/sdk/runtime/status-writer.test.ts +0 -245
- package/src/sdk/runtime/status-writer.ts +0 -201
- package/src/sdk/runtime/theme.ts +0 -71
- package/src/sdk/runtime/tmux.conf +0 -112
- package/src/sdk/runtime/tmux.ts +0 -785
- package/src/sdk/runtime/version-compat.ts +0 -68
- package/src/sdk/types.ts +0 -548
- package/src/sdk/worker-shared.test.ts +0 -163
- package/src/sdk/worker-shared.ts +0 -155
- package/src/sdk/workflows/builtin/deep-research-codebase/claude/index.ts +0 -569
- package/src/sdk/workflows/builtin/deep-research-codebase/copilot/index.ts +0 -481
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/batching.ts +0 -65
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/heuristic.ts +0 -24
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/ignore-by-default.d.ts +0 -8
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/prompts.ts +0 -958
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/scout.ts +0 -505
- package/src/sdk/workflows/builtin/deep-research-codebase/helpers/scratch.ts +0 -115
- package/src/sdk/workflows/builtin/deep-research-codebase/opencode/index.ts +0 -530
- package/src/sdk/workflows/builtin/open-claude-design/claude/index.ts +0 -500
- package/src/sdk/workflows/builtin/open-claude-design/copilot/index.ts +0 -508
- package/src/sdk/workflows/builtin/open-claude-design/helpers/constants.ts +0 -159
- package/src/sdk/workflows/builtin/open-claude-design/helpers/design-system.ts +0 -88
- package/src/sdk/workflows/builtin/open-claude-design/helpers/export.ts +0 -193
- package/src/sdk/workflows/builtin/open-claude-design/helpers/import.ts +0 -52
- package/src/sdk/workflows/builtin/open-claude-design/helpers/prompts.ts +0 -1110
- package/src/sdk/workflows/builtin/open-claude-design/helpers/scan.ts +0 -117
- package/src/sdk/workflows/builtin/open-claude-design/helpers/validation.ts +0 -38
- package/src/sdk/workflows/builtin/open-claude-design/opencode/index.ts +0 -610
- package/src/sdk/workflows/builtin/ralph/claude/index.ts +0 -272
- package/src/sdk/workflows/builtin/ralph/copilot/index.ts +0 -298
- package/src/sdk/workflows/builtin/ralph/helpers/copilot-reviewer.ts +0 -105
- package/src/sdk/workflows/builtin/ralph/helpers/git.ts +0 -201
- package/src/sdk/workflows/builtin/ralph/helpers/prompts.ts +0 -1108
- package/src/sdk/workflows/builtin/ralph/helpers/review.ts +0 -33
- package/src/sdk/workflows/builtin/ralph/opencode/index.ts +0 -290
- package/src/sdk/workflows/index.ts +0 -116
- package/src/services/config/additional-instructions.ts +0 -273
- package/src/services/config/atomic-config.ts +0 -210
- package/src/services/config/atomic-global-config.ts +0 -348
- package/src/services/config/config-path.ts +0 -19
- package/src/services/config/definitions.ts +0 -125
- package/src/services/config/index.ts +0 -7
- package/src/services/config/scm-sync.ts +0 -185
- package/src/services/config/settings-schema.ts +0 -2
- package/src/services/config/settings.ts +0 -144
- package/src/services/system/agents.ts +0 -95
- package/src/services/system/auth.test.ts +0 -343
- package/src/services/system/auth.ts +0 -140
- package/src/services/system/auto-sync.ts +0 -128
- package/src/services/system/copy.ts +0 -392
- package/src/services/system/detect.ts +0 -161
- package/src/services/system/file-lock.ts +0 -289
- package/src/services/system/install-ui.ts +0 -296
- package/src/services/system/skills.ts +0 -58
- package/src/theme/colors.ts +0 -96
- package/src/theme/logo.ts +0 -123
- package/src/version.ts +0 -7
|
@@ -1,235 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Unit tests for `atomic workflow list` — the subcommand that replaced
|
|
3
|
-
* the old dispatcher `-l/--list` flag.
|
|
4
|
-
*
|
|
5
|
-
* The command itself is thin; these tests cover the behaviors that
|
|
6
|
-
* would silently break if the filter logic regressed: agent filtering,
|
|
7
|
-
* empty results, unknown agent rejection, and the sort order that
|
|
8
|
-
* keeps output stable across runs.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { describe, test, expect, beforeAll, beforeEach, afterAll, afterEach, mock } from "bun:test";
|
|
12
|
-
import { workflowListCommand } from "./workflow-list.ts";
|
|
13
|
-
import type { AgentType, WorkflowDefinition } from "../../sdk/workflows/index.ts";
|
|
14
|
-
|
|
15
|
-
function def(agent: AgentType, name: string, description = ""): WorkflowDefinition {
|
|
16
|
-
return {
|
|
17
|
-
__brand: "WorkflowDefinition",
|
|
18
|
-
agent,
|
|
19
|
-
name,
|
|
20
|
-
description,
|
|
21
|
-
inputs: [],
|
|
22
|
-
minSDKVersion: null,
|
|
23
|
-
source: import.meta.path,
|
|
24
|
-
run: async () => {},
|
|
25
|
-
} as unknown as WorkflowDefinition;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
let originalNoColor: string | undefined;
|
|
29
|
-
beforeAll(() => {
|
|
30
|
-
originalNoColor = process.env.NO_COLOR;
|
|
31
|
-
process.env.NO_COLOR = "1";
|
|
32
|
-
});
|
|
33
|
-
afterAll(() => {
|
|
34
|
-
if (originalNoColor === undefined) delete process.env.NO_COLOR;
|
|
35
|
-
else process.env.NO_COLOR = originalNoColor;
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
interface Captured {
|
|
39
|
-
stdout: string;
|
|
40
|
-
stderr: string;
|
|
41
|
-
restore: () => void;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
function captureOutput(): Captured {
|
|
45
|
-
const captured: Captured = { stdout: "", stderr: "", restore: () => {} };
|
|
46
|
-
const origStdout = process.stdout.write.bind(process.stdout);
|
|
47
|
-
const origStderr = process.stderr.write.bind(process.stderr);
|
|
48
|
-
process.stdout.write = ((chunk: string | Uint8Array): boolean => {
|
|
49
|
-
captured.stdout += typeof chunk === "string" ? chunk : new TextDecoder().decode(chunk);
|
|
50
|
-
return true;
|
|
51
|
-
}) as typeof process.stdout.write;
|
|
52
|
-
process.stderr.write = ((chunk: string | Uint8Array): boolean => {
|
|
53
|
-
captured.stderr += typeof chunk === "string" ? chunk : new TextDecoder().decode(chunk);
|
|
54
|
-
return true;
|
|
55
|
-
}) as typeof process.stderr.write;
|
|
56
|
-
captured.restore = () => {
|
|
57
|
-
process.stdout.write = origStdout;
|
|
58
|
-
process.stderr.write = origStderr;
|
|
59
|
-
};
|
|
60
|
-
return captured;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
const fixture = [
|
|
64
|
-
def("claude", "ralph", "iterative plan/orchestrate/review/debug loop"),
|
|
65
|
-
def("copilot", "ralph", "iterative plan/orchestrate/review/debug loop"),
|
|
66
|
-
def("opencode", "ralph", "iterative plan/orchestrate/review/debug loop"),
|
|
67
|
-
def("claude", "deep-research-codebase", "scout -> explorer fan-out"),
|
|
68
|
-
def("copilot", "deep-research-codebase", "scout -> explorer fan-out"),
|
|
69
|
-
def("opencode", "deep-research-codebase", "scout -> explorer fan-out"),
|
|
70
|
-
def("claude", "open-claude-design", "design system onboarding"),
|
|
71
|
-
def("copilot", "open-claude-design", "design system onboarding"),
|
|
72
|
-
def("opencode", "open-claude-design", "design system onboarding"),
|
|
73
|
-
];
|
|
74
|
-
|
|
75
|
-
let savedNoColor: string | undefined;
|
|
76
|
-
beforeEach(() => {
|
|
77
|
-
savedNoColor = process.env.NO_COLOR;
|
|
78
|
-
process.env.NO_COLOR = "1";
|
|
79
|
-
});
|
|
80
|
-
afterEach(() => {
|
|
81
|
-
if (savedNoColor === undefined) delete process.env.NO_COLOR;
|
|
82
|
-
else process.env.NO_COLOR = savedNoColor;
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
describe("workflowListCommand", () => {
|
|
86
|
-
test("no agent filter: prints every registered workflow, grouped by name", async () => {
|
|
87
|
-
const cap = captureOutput();
|
|
88
|
-
let code: number;
|
|
89
|
-
try {
|
|
90
|
-
code = await workflowListCommand({}, { list: () => fixture });
|
|
91
|
-
} finally {
|
|
92
|
-
cap.restore();
|
|
93
|
-
}
|
|
94
|
-
expect(code).toBe(0);
|
|
95
|
-
expect(cap.stdout).toContain("ralph");
|
|
96
|
-
expect(cap.stdout).toContain("deep-research-codebase");
|
|
97
|
-
expect(cap.stdout).toContain("open-claude-design");
|
|
98
|
-
// Grouping deduplicates identical (name, description) pairs, so each
|
|
99
|
-
// workflow name appears exactly once.
|
|
100
|
-
expect(cap.stdout.match(/\bralph\b/g)?.length).toBe(1);
|
|
101
|
-
// Agents are rendered as a badge line under each group.
|
|
102
|
-
expect(cap.stdout).toContain("claude");
|
|
103
|
-
expect(cap.stdout).toContain("copilot");
|
|
104
|
-
expect(cap.stdout).toContain("opencode");
|
|
105
|
-
expect(cap.stdout).toContain(" · ");
|
|
106
|
-
// The old `agent=<name>` label is gone — grouping replaces it.
|
|
107
|
-
expect(cap.stdout).not.toContain("agent=");
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
test("agent filter narrows to the selected agent only", async () => {
|
|
111
|
-
const cap = captureOutput();
|
|
112
|
-
let code: number;
|
|
113
|
-
try {
|
|
114
|
-
code = await workflowListCommand({ agent: "claude" }, { list: () => fixture });
|
|
115
|
-
} finally {
|
|
116
|
-
cap.restore();
|
|
117
|
-
}
|
|
118
|
-
expect(code).toBe(0);
|
|
119
|
-
// Every workflow with a claude variant appears.
|
|
120
|
-
expect(cap.stdout).toContain("ralph");
|
|
121
|
-
expect(cap.stdout).toContain("deep-research-codebase");
|
|
122
|
-
expect(cap.stdout).toContain("open-claude-design");
|
|
123
|
-
// Non-matching agents should not appear in the listing. We check for
|
|
124
|
-
// the agent-badge separator, not the strings themselves — a workflow
|
|
125
|
-
// named "open-claude-design" legitimately contains the token
|
|
126
|
-
// "claude" outside the badge list.
|
|
127
|
-
expect(cap.stdout).not.toContain("copilot");
|
|
128
|
-
expect(cap.stdout).not.toContain("opencode");
|
|
129
|
-
// Filtered output suppresses the agent-badge line entirely, since
|
|
130
|
-
// the filter itself provides the context.
|
|
131
|
-
expect(cap.stdout).not.toContain(" · ");
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
test("unknown agent returns non-zero and writes an error message", async () => {
|
|
135
|
-
const cap = captureOutput();
|
|
136
|
-
let code: number;
|
|
137
|
-
try {
|
|
138
|
-
code = await workflowListCommand({ agent: "bogus" }, { list: () => fixture });
|
|
139
|
-
} finally {
|
|
140
|
-
cap.restore();
|
|
141
|
-
}
|
|
142
|
-
expect(code).toBe(1);
|
|
143
|
-
expect(cap.stderr).toContain("Unknown agent 'bogus'");
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
test("empty registry prints a helpful placeholder", async () => {
|
|
147
|
-
const cap = captureOutput();
|
|
148
|
-
let code: number;
|
|
149
|
-
try {
|
|
150
|
-
code = await workflowListCommand({}, { list: () => [] });
|
|
151
|
-
} finally {
|
|
152
|
-
cap.restore();
|
|
153
|
-
}
|
|
154
|
-
expect(code).toBe(0);
|
|
155
|
-
expect(cap.stdout).toContain("No workflows registered.");
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
test("agent filter with zero matches prints the placeholder, not an error", async () => {
|
|
159
|
-
const cap = captureOutput();
|
|
160
|
-
let code: number;
|
|
161
|
-
try {
|
|
162
|
-
code = await workflowListCommand(
|
|
163
|
-
{ agent: "opencode" },
|
|
164
|
-
{ list: () => [def("claude", "ralph")] },
|
|
165
|
-
);
|
|
166
|
-
} finally {
|
|
167
|
-
cap.restore();
|
|
168
|
-
}
|
|
169
|
-
expect(code).toBe(0);
|
|
170
|
-
expect(cap.stdout).toContain("No workflows registered.");
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
test("groups are sorted alphabetically by workflow name", async () => {
|
|
174
|
-
const shuffled = [
|
|
175
|
-
def("opencode", "ralph"),
|
|
176
|
-
def("claude", "deep-research-codebase"),
|
|
177
|
-
def("claude", "ralph"),
|
|
178
|
-
def("copilot", "ralph"),
|
|
179
|
-
];
|
|
180
|
-
const cap = captureOutput();
|
|
181
|
-
try {
|
|
182
|
-
await workflowListCommand({}, { list: () => shuffled });
|
|
183
|
-
} finally {
|
|
184
|
-
cap.restore();
|
|
185
|
-
}
|
|
186
|
-
const deepIdx = cap.stdout.indexOf("deep-research-codebase");
|
|
187
|
-
const ralphIdx = cap.stdout.indexOf("ralph");
|
|
188
|
-
expect(deepIdx).toBeGreaterThan(-1);
|
|
189
|
-
expect(ralphIdx).toBeGreaterThan(deepIdx);
|
|
190
|
-
});
|
|
191
|
-
|
|
192
|
-
test("agents within a group are sorted alphabetically", async () => {
|
|
193
|
-
const shuffled = [
|
|
194
|
-
def("opencode", "ralph", "plan"),
|
|
195
|
-
def("claude", "ralph", "plan"),
|
|
196
|
-
def("copilot", "ralph", "plan"),
|
|
197
|
-
];
|
|
198
|
-
const cap = captureOutput();
|
|
199
|
-
try {
|
|
200
|
-
await workflowListCommand({}, { list: () => shuffled });
|
|
201
|
-
} finally {
|
|
202
|
-
cap.restore();
|
|
203
|
-
}
|
|
204
|
-
const claudeIdx = cap.stdout.indexOf("claude");
|
|
205
|
-
const copilotIdx = cap.stdout.indexOf("copilot");
|
|
206
|
-
const opencodeIdx = cap.stdout.indexOf("opencode");
|
|
207
|
-
expect(claudeIdx).toBeGreaterThan(-1);
|
|
208
|
-
expect(claudeIdx).toBeLessThan(copilotIdx);
|
|
209
|
-
expect(copilotIdx).toBeLessThan(opencodeIdx);
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
test("variants with differing descriptions print as separate groups", async () => {
|
|
213
|
-
// Two variants of `ralph` with different descriptions — the grouping
|
|
214
|
-
// should keep them separate so no information is lost, instead of
|
|
215
|
-
// silently collapsing to one arbitrary description.
|
|
216
|
-
const entries = [
|
|
217
|
-
def("claude", "ralph", "plan version A"),
|
|
218
|
-
def("copilot", "ralph", "plan version B"),
|
|
219
|
-
];
|
|
220
|
-
const cap = captureOutput();
|
|
221
|
-
try {
|
|
222
|
-
await workflowListCommand({}, { list: () => entries });
|
|
223
|
-
} finally {
|
|
224
|
-
cap.restore();
|
|
225
|
-
}
|
|
226
|
-
expect(cap.stdout).toContain("plan version A");
|
|
227
|
-
expect(cap.stdout).toContain("plan version B");
|
|
228
|
-
// Two separate groups means "ralph" appears as a heading twice.
|
|
229
|
-
expect(cap.stdout.match(/\bralph\b/g)?.length).toBe(2);
|
|
230
|
-
});
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
// mock import kept at module scope to match the lint pattern used by
|
|
234
|
-
// other test files — suppresses an unused-import warning if any.
|
|
235
|
-
void mock;
|
|
Binary file
|
|
@@ -1,451 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for `atomic workflow status` — covers the dependency-injected
|
|
3
|
-
* command shape end-to-end with no real tmux server, no real
|
|
4
|
-
* filesystem outside a temp dir, and JSON output capture so assertions
|
|
5
|
-
* can run on parsed objects.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { describe, test, expect, beforeAll, afterAll, beforeEach, mock } from "bun:test";
|
|
9
|
-
import { mkdtemp, mkdir, rm } from "node:fs/promises";
|
|
10
|
-
import { join } from "node:path";
|
|
11
|
-
import { tmpdir } from "node:os";
|
|
12
|
-
import { workflowStatusCommand, type StatusDeps } from "./workflow-status.ts";
|
|
13
|
-
import {
|
|
14
|
-
buildSnapshot,
|
|
15
|
-
writeSnapshot,
|
|
16
|
-
type WorkflowStatusSnapshot,
|
|
17
|
-
} from "../../sdk/runtime/status-writer.ts";
|
|
18
|
-
import type { TmuxSession } from "../../sdk/runtime/tmux.ts";
|
|
19
|
-
import type { SessionData } from "../../sdk/components/orchestrator-panel-types.ts";
|
|
20
|
-
|
|
21
|
-
// ─── output capture ────────────────────────────────────────────────
|
|
22
|
-
|
|
23
|
-
function captureStdout(): { read: () => string; restore: () => void } {
|
|
24
|
-
const chunks: string[] = [];
|
|
25
|
-
const orig = process.stdout.write;
|
|
26
|
-
process.stdout.write = ((c: string | Uint8Array) => {
|
|
27
|
-
chunks.push(typeof c === "string" ? c : new TextDecoder().decode(c));
|
|
28
|
-
return true;
|
|
29
|
-
}) as typeof process.stdout.write;
|
|
30
|
-
return {
|
|
31
|
-
read: () => chunks.join(""),
|
|
32
|
-
restore: () => {
|
|
33
|
-
process.stdout.write = orig;
|
|
34
|
-
},
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
let originalNoColor: string | undefined;
|
|
39
|
-
beforeAll(() => {
|
|
40
|
-
originalNoColor = process.env.NO_COLOR;
|
|
41
|
-
process.env.NO_COLOR = "1";
|
|
42
|
-
});
|
|
43
|
-
afterAll(() => {
|
|
44
|
-
if (originalNoColor === undefined) delete process.env.NO_COLOR;
|
|
45
|
-
else process.env.NO_COLOR = originalNoColor;
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
function tmuxSession(name: string): TmuxSession {
|
|
49
|
-
return {
|
|
50
|
-
name,
|
|
51
|
-
windows: 1,
|
|
52
|
-
created: new Date().toISOString(),
|
|
53
|
-
attached: false,
|
|
54
|
-
type: "workflow",
|
|
55
|
-
agent: "claude",
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
function panelSession(
|
|
60
|
-
name: string,
|
|
61
|
-
status: SessionData["status"],
|
|
62
|
-
extra: Partial<SessionData> = {},
|
|
63
|
-
): SessionData {
|
|
64
|
-
return {
|
|
65
|
-
name,
|
|
66
|
-
status,
|
|
67
|
-
parents: [],
|
|
68
|
-
startedAt: 1000,
|
|
69
|
-
endedAt: null,
|
|
70
|
-
...extra,
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
function snapshotOf(
|
|
75
|
-
workflowName: string,
|
|
76
|
-
agent: string,
|
|
77
|
-
sessions: SessionData[],
|
|
78
|
-
opts: { fatalError?: string | null; completionReached?: boolean } = {},
|
|
79
|
-
): WorkflowStatusSnapshot {
|
|
80
|
-
return buildSnapshot({
|
|
81
|
-
workflowRunId: "abcd1234",
|
|
82
|
-
tmuxSession: `atomic-wf-${agent}-${workflowName}-abcd1234`,
|
|
83
|
-
workflowName,
|
|
84
|
-
agent,
|
|
85
|
-
prompt: "",
|
|
86
|
-
fatalError: opts.fatalError ?? null,
|
|
87
|
-
completionReached: opts.completionReached ?? false,
|
|
88
|
-
sessions,
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
interface Mocks {
|
|
93
|
-
isTmuxInstalled: ReturnType<typeof mock>;
|
|
94
|
-
sessionExists: ReturnType<typeof mock>;
|
|
95
|
-
listSessions: ReturnType<typeof mock>;
|
|
96
|
-
readSnapshot: ReturnType<typeof mock>;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
function makeDeps(sessionsBaseDir: string): { deps: StatusDeps; mocks: Mocks } {
|
|
100
|
-
const mocks: Mocks = {
|
|
101
|
-
isTmuxInstalled: mock(() => true),
|
|
102
|
-
sessionExists: mock(() => true),
|
|
103
|
-
listSessions: mock<() => TmuxSession[]>(() => []),
|
|
104
|
-
readSnapshot: mock(async () => null),
|
|
105
|
-
};
|
|
106
|
-
const deps: StatusDeps = {
|
|
107
|
-
isTmuxInstalled: mocks.isTmuxInstalled,
|
|
108
|
-
sessionExists: mocks.sessionExists,
|
|
109
|
-
listSessions: mocks.listSessions as unknown as StatusDeps["listSessions"],
|
|
110
|
-
readSnapshot: mocks.readSnapshot as unknown as StatusDeps["readSnapshot"],
|
|
111
|
-
sessionsBaseDir,
|
|
112
|
-
};
|
|
113
|
-
return { deps, mocks };
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// ─── tests ─────────────────────────────────────────────────────────
|
|
117
|
-
|
|
118
|
-
describe("workflowStatusCommand", () => {
|
|
119
|
-
let tmpDir = "";
|
|
120
|
-
beforeEach(async () => {
|
|
121
|
-
tmpDir = await mkdtemp(join(tmpdir(), "atomic-status-cmd-"));
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
test("prints empty list when no workflow sessions are running", async () => {
|
|
125
|
-
const { deps } = makeDeps(tmpDir);
|
|
126
|
-
const cap = captureStdout();
|
|
127
|
-
try {
|
|
128
|
-
const code = await workflowStatusCommand({ format: "json" }, deps);
|
|
129
|
-
expect(code).toBe(0);
|
|
130
|
-
const parsed = JSON.parse(cap.read());
|
|
131
|
-
expect(parsed).toEqual({ workflows: [] });
|
|
132
|
-
} finally {
|
|
133
|
-
cap.restore();
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
test("derives 'in_progress' for an alive workflow with a running stage", async () => {
|
|
138
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
139
|
-
mocks.listSessions.mockReturnValue([
|
|
140
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
141
|
-
]);
|
|
142
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
143
|
-
snapshotOf("ralph", "claude", [panelSession("orchestrator", "running")]),
|
|
144
|
-
);
|
|
145
|
-
const cap = captureStdout();
|
|
146
|
-
try {
|
|
147
|
-
const code = await workflowStatusCommand({ format: "json" }, deps);
|
|
148
|
-
expect(code).toBe(0);
|
|
149
|
-
const parsed = JSON.parse(cap.read());
|
|
150
|
-
expect(parsed.workflows).toHaveLength(1);
|
|
151
|
-
expect(parsed.workflows[0].overall).toBe("in_progress");
|
|
152
|
-
expect(parsed.workflows[0].alive).toBe(true);
|
|
153
|
-
} finally {
|
|
154
|
-
cap.restore();
|
|
155
|
-
}
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
test("returns 'needs_review' when any stage is awaiting input (HIL)", async () => {
|
|
159
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
160
|
-
mocks.listSessions.mockReturnValue([
|
|
161
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
162
|
-
]);
|
|
163
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
164
|
-
snapshotOf("ralph", "claude", [
|
|
165
|
-
panelSession("orchestrator", "running"),
|
|
166
|
-
panelSession("loop", "awaiting_input"),
|
|
167
|
-
]),
|
|
168
|
-
);
|
|
169
|
-
const cap = captureStdout();
|
|
170
|
-
try {
|
|
171
|
-
const code = await workflowStatusCommand(
|
|
172
|
-
{ format: "json", id: "atomic-wf-claude-ralph-abcd1234" },
|
|
173
|
-
deps,
|
|
174
|
-
);
|
|
175
|
-
expect(code).toBe(0);
|
|
176
|
-
const parsed = JSON.parse(cap.read());
|
|
177
|
-
expect(parsed.overall).toBe("needs_review");
|
|
178
|
-
} finally {
|
|
179
|
-
cap.restore();
|
|
180
|
-
}
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
test("returns 'completed' when completionReached and no errors", async () => {
|
|
184
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
185
|
-
mocks.listSessions.mockReturnValue([
|
|
186
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
187
|
-
]);
|
|
188
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
189
|
-
snapshotOf(
|
|
190
|
-
"ralph",
|
|
191
|
-
"claude",
|
|
192
|
-
[panelSession("orchestrator", "complete")],
|
|
193
|
-
{ completionReached: true },
|
|
194
|
-
),
|
|
195
|
-
);
|
|
196
|
-
const cap = captureStdout();
|
|
197
|
-
try {
|
|
198
|
-
const code = await workflowStatusCommand(
|
|
199
|
-
{ format: "json", id: "atomic-wf-claude-ralph-abcd1234" },
|
|
200
|
-
deps,
|
|
201
|
-
);
|
|
202
|
-
expect(code).toBe(0);
|
|
203
|
-
const parsed = JSON.parse(cap.read());
|
|
204
|
-
expect(parsed.overall).toBe("completed");
|
|
205
|
-
} finally {
|
|
206
|
-
cap.restore();
|
|
207
|
-
}
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
test("returns 'error' when fatalError is present in the snapshot", async () => {
|
|
211
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
212
|
-
mocks.listSessions.mockReturnValue([
|
|
213
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
214
|
-
]);
|
|
215
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
216
|
-
snapshotOf("ralph", "claude", [panelSession("orchestrator", "running")], {
|
|
217
|
-
fatalError: "boom",
|
|
218
|
-
}),
|
|
219
|
-
);
|
|
220
|
-
const cap = captureStdout();
|
|
221
|
-
try {
|
|
222
|
-
const code = await workflowStatusCommand(
|
|
223
|
-
{ format: "json", id: "atomic-wf-claude-ralph-abcd1234" },
|
|
224
|
-
deps,
|
|
225
|
-
);
|
|
226
|
-
expect(code).toBe(0);
|
|
227
|
-
const parsed = JSON.parse(cap.read());
|
|
228
|
-
expect(parsed.overall).toBe("error");
|
|
229
|
-
expect(parsed.fatalError).toBe("boom");
|
|
230
|
-
} finally {
|
|
231
|
-
cap.restore();
|
|
232
|
-
}
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
test("returns 1 with a JSON error envelope when the requested id is unknown", async () => {
|
|
236
|
-
const { deps } = makeDeps(tmpDir);
|
|
237
|
-
const cap = captureStdout();
|
|
238
|
-
try {
|
|
239
|
-
const code = await workflowStatusCommand(
|
|
240
|
-
{ format: "json", id: "atomic-wf-claude-ralph-deadbeef" },
|
|
241
|
-
deps,
|
|
242
|
-
);
|
|
243
|
-
expect(code).toBe(1);
|
|
244
|
-
const parsed = JSON.parse(cap.read());
|
|
245
|
-
expect(parsed.error).toContain("not found");
|
|
246
|
-
} finally {
|
|
247
|
-
cap.restore();
|
|
248
|
-
}
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
test("falls back to a minimal report when the orchestrator hasn't written a snapshot yet", async () => {
|
|
252
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
253
|
-
mocks.listSessions.mockReturnValue([
|
|
254
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
255
|
-
]);
|
|
256
|
-
mocks.readSnapshot.mockResolvedValue(null);
|
|
257
|
-
const cap = captureStdout();
|
|
258
|
-
try {
|
|
259
|
-
const code = await workflowStatusCommand({ format: "json" }, deps);
|
|
260
|
-
expect(code).toBe(0);
|
|
261
|
-
const parsed = JSON.parse(cap.read());
|
|
262
|
-
expect(parsed.workflows).toHaveLength(1);
|
|
263
|
-
expect(parsed.workflows[0].overall).toBe("in_progress");
|
|
264
|
-
expect(parsed.workflows[0].workflowName).toBe("");
|
|
265
|
-
} finally {
|
|
266
|
-
cap.restore();
|
|
267
|
-
}
|
|
268
|
-
});
|
|
269
|
-
|
|
270
|
-
test("recognises a stale snapshot as 'error' when the tmux session is gone", async () => {
|
|
271
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
272
|
-
mocks.listSessions.mockReturnValue([]);
|
|
273
|
-
// Place a real snapshot on disk so the dead-session post-mortem
|
|
274
|
-
// path can read it.
|
|
275
|
-
const sessionDir = join(tmpDir, "abcd1234");
|
|
276
|
-
await mkdir(sessionDir, { recursive: true });
|
|
277
|
-
await writeSnapshot(
|
|
278
|
-
sessionDir,
|
|
279
|
-
snapshotOf("ralph", "claude", [panelSession("orchestrator", "running")]),
|
|
280
|
-
);
|
|
281
|
-
// Use the real reader for this test so the dead-session lookup
|
|
282
|
-
// hits the file we just wrote.
|
|
283
|
-
deps.readSnapshot = (await import(
|
|
284
|
-
"../../sdk/runtime/status-writer.ts"
|
|
285
|
-
)).readSnapshot;
|
|
286
|
-
const cap = captureStdout();
|
|
287
|
-
try {
|
|
288
|
-
const code = await workflowStatusCommand(
|
|
289
|
-
{ format: "json", id: "atomic-wf-claude-ralph-abcd1234" },
|
|
290
|
-
deps,
|
|
291
|
-
);
|
|
292
|
-
expect(code).toBe(0);
|
|
293
|
-
const parsed = JSON.parse(cap.read());
|
|
294
|
-
expect(parsed.alive).toBe(false);
|
|
295
|
-
expect(parsed.overall).toBe("error");
|
|
296
|
-
} finally {
|
|
297
|
-
cap.restore();
|
|
298
|
-
}
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
test("text format: empty list prints the 'no workflows running' hint", async () => {
|
|
302
|
-
const { deps } = makeDeps(tmpDir);
|
|
303
|
-
const cap = captureStdout();
|
|
304
|
-
try {
|
|
305
|
-
const code = await workflowStatusCommand({ format: "text" }, deps);
|
|
306
|
-
expect(code).toBe(0);
|
|
307
|
-
expect(cap.read()).toContain("no workflows running");
|
|
308
|
-
} finally {
|
|
309
|
-
cap.restore();
|
|
310
|
-
}
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
test("text format: renders a workflow list with indicator, id, and status", async () => {
|
|
314
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
315
|
-
mocks.listSessions.mockReturnValue([
|
|
316
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
317
|
-
]);
|
|
318
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
319
|
-
snapshotOf("ralph", "claude", [panelSession("orchestrator", "running")]),
|
|
320
|
-
);
|
|
321
|
-
const cap = captureStdout();
|
|
322
|
-
try {
|
|
323
|
-
const code = await workflowStatusCommand({ format: "text" }, deps);
|
|
324
|
-
expect(code).toBe(0);
|
|
325
|
-
const out = cap.read();
|
|
326
|
-
expect(out).toContain("atomic-wf-claude-ralph-abcd1234");
|
|
327
|
-
expect(out).toContain("in_progress");
|
|
328
|
-
expect(out).toContain("ralph");
|
|
329
|
-
// singular noun when list has exactly one workflow
|
|
330
|
-
expect(out).toContain("1");
|
|
331
|
-
} finally {
|
|
332
|
-
cap.restore();
|
|
333
|
-
}
|
|
334
|
-
});
|
|
335
|
-
|
|
336
|
-
test("text format: list uses '(no snapshot)' placeholder when workflowName is empty", async () => {
|
|
337
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
338
|
-
mocks.listSessions.mockReturnValue([
|
|
339
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
340
|
-
]);
|
|
341
|
-
mocks.readSnapshot.mockResolvedValue(null);
|
|
342
|
-
const cap = captureStdout();
|
|
343
|
-
try {
|
|
344
|
-
const code = await workflowStatusCommand({ format: "text" }, deps);
|
|
345
|
-
expect(code).toBe(0);
|
|
346
|
-
expect(cap.read()).toContain("(no snapshot)");
|
|
347
|
-
} finally {
|
|
348
|
-
cap.restore();
|
|
349
|
-
}
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
test("text format: single-report render includes workflow, stages, fatal error, and updatedAt", async () => {
|
|
353
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
354
|
-
mocks.listSessions.mockReturnValue([
|
|
355
|
-
tmuxSession("atomic-wf-claude-ralph-abcd1234"),
|
|
356
|
-
]);
|
|
357
|
-
mocks.readSnapshot.mockResolvedValue(
|
|
358
|
-
snapshotOf(
|
|
359
|
-
"ralph",
|
|
360
|
-
"claude",
|
|
361
|
-
[
|
|
362
|
-
panelSession("orchestrator", "error", { error: "stage boom" }),
|
|
363
|
-
],
|
|
364
|
-
{ fatalError: "the whole thing" },
|
|
365
|
-
),
|
|
366
|
-
);
|
|
367
|
-
const cap = captureStdout();
|
|
368
|
-
try {
|
|
369
|
-
const code = await workflowStatusCommand(
|
|
370
|
-
{ format: "text", id: "atomic-wf-claude-ralph-abcd1234" },
|
|
371
|
-
deps,
|
|
372
|
-
);
|
|
373
|
-
expect(code).toBe(0);
|
|
374
|
-
const out = cap.read();
|
|
375
|
-
expect(out).toContain("atomic-wf-claude-ralph-abcd1234");
|
|
376
|
-
expect(out).toContain("workflow:");
|
|
377
|
-
expect(out).toContain("ralph");
|
|
378
|
-
expect(out).toContain("stages:");
|
|
379
|
-
expect(out).toContain("orchestrator");
|
|
380
|
-
expect(out).toContain("stage boom");
|
|
381
|
-
expect(out).toContain("the whole thing");
|
|
382
|
-
expect(out).toContain("updated:");
|
|
383
|
-
} finally {
|
|
384
|
-
cap.restore();
|
|
385
|
-
}
|
|
386
|
-
});
|
|
387
|
-
|
|
388
|
-
test("text format: unknown id writes 'not found' to stderr and returns 1", async () => {
|
|
389
|
-
const { deps } = makeDeps(tmpDir);
|
|
390
|
-
const errChunks: string[] = [];
|
|
391
|
-
const origErr = process.stderr.write;
|
|
392
|
-
process.stderr.write = ((c: string | Uint8Array) => {
|
|
393
|
-
errChunks.push(typeof c === "string" ? c : new TextDecoder().decode(c));
|
|
394
|
-
return true;
|
|
395
|
-
}) as typeof process.stderr.write;
|
|
396
|
-
try {
|
|
397
|
-
const code = await workflowStatusCommand(
|
|
398
|
-
{ format: "text", id: "atomic-wf-claude-ralph-deadbeef" },
|
|
399
|
-
deps,
|
|
400
|
-
);
|
|
401
|
-
expect(code).toBe(1);
|
|
402
|
-
expect(errChunks.join("")).toContain("not found");
|
|
403
|
-
} finally {
|
|
404
|
-
process.stderr.write = origErr;
|
|
405
|
-
}
|
|
406
|
-
});
|
|
407
|
-
|
|
408
|
-
test("reports zero workflows when tmux is not installed", async () => {
|
|
409
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
410
|
-
mocks.isTmuxInstalled.mockReturnValue(false);
|
|
411
|
-
const cap = captureStdout();
|
|
412
|
-
try {
|
|
413
|
-
const code = await workflowStatusCommand({ format: "json" }, deps);
|
|
414
|
-
expect(code).toBe(0);
|
|
415
|
-
const parsed = JSON.parse(cap.read());
|
|
416
|
-
expect(parsed).toEqual({ workflows: [] });
|
|
417
|
-
} finally {
|
|
418
|
-
cap.restore();
|
|
419
|
-
}
|
|
420
|
-
});
|
|
421
|
-
|
|
422
|
-
test("text format: tmux not installed prints the 'no sessions running' hint", async () => {
|
|
423
|
-
const { deps, mocks } = makeDeps(tmpDir);
|
|
424
|
-
mocks.isTmuxInstalled.mockReturnValue(false);
|
|
425
|
-
const cap = captureStdout();
|
|
426
|
-
try {
|
|
427
|
-
const code = await workflowStatusCommand({ format: "text" }, deps);
|
|
428
|
-
expect(code).toBe(0);
|
|
429
|
-
expect(cap.read()).toContain("tmux is not installed");
|
|
430
|
-
} finally {
|
|
431
|
-
cap.restore();
|
|
432
|
-
}
|
|
433
|
-
});
|
|
434
|
-
|
|
435
|
-
test("defaults format to 'json' when omitted", async () => {
|
|
436
|
-
const { deps } = makeDeps(tmpDir);
|
|
437
|
-
const cap = captureStdout();
|
|
438
|
-
try {
|
|
439
|
-
const code = await workflowStatusCommand({}, deps);
|
|
440
|
-
expect(code).toBe(0);
|
|
441
|
-
// JSON parses cleanly
|
|
442
|
-
JSON.parse(cap.read());
|
|
443
|
-
} finally {
|
|
444
|
-
cap.restore();
|
|
445
|
-
}
|
|
446
|
-
});
|
|
447
|
-
|
|
448
|
-
afterAll(async () => {
|
|
449
|
-
if (tmpDir) await rm(tmpDir, { recursive: true, force: true });
|
|
450
|
-
});
|
|
451
|
-
});
|