Changed the pastebin tutorial so it now starts skeletal: no prebuilt Flask behavior, no pre-generated task tests, and .gitkeep placeholders under templates/ and tests/. The new pipeline in nightshift/project_templates/tutorial-pastebin/nightshift.yaml:1 now runs:
plan -> semantic_context -> context -> write_tests -> review_tests -> implement -> pytest -> review
────────────────────────────────────────────────────
Added nightshift/project_templates/tutorial-pastebin/.nightshift/agents/test-writer.md:1, tightened the planner/implementer/reviewer/debugger prompts, mirrored the pipeline docs/
example, and raised default retries to 6 for the basic starter plus pastebin.
I also fixed the retry policy issue in nightshift/escalation.py:17 and nightshift/pipeline.py:251: configured repeated-failure thresholds are now respected instead of hard-stopping in nightshift/project_templates/tutorial-pastebin/
early after three same-stage/same-cause failures. Non-implementation file_writer stages now get stage-specific retry artifacts so test generation does not collide with implementation
repair artifacts
- Added nightshift what-happened to summarize the latest run/task failure from artifacts.
- Added integ-run --setup with setup options, so sandbox creation can immediately run integ-setup.
- integ-setup output now explicitly shows the venv activation command.
- Command stages now prefer a detected project/adjacent .venv, so python -m pytest -q should use the integ venv without relying on shell activation.
- Retry command outputs now get attempt-specific artifact names, like test-output-1.txt, instead of overwriting.
- Docs updated in README.md, the pastebin template README, and examples/tutorial/03-pastebin.
- Added pytest config so root python -m pytest -q ignores generated integ/template target tests.
- Version bumped to 0.2.4-alpha-bratwurst-relish.