@gian-tiaga/eda 0.8.0 → 0.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -3,7 +3,7 @@
3
3
  > Поточная разработка с AI-агентами — на русском языке.
4
4
  > Набор готовых скилов для **Claude Code** и **Codex CLI**, которые ведут тебя через весь цикл: от исследования до коммита.
5
5
 
6
- `eda` — это шестнадцать скилов, каждый отвечает за свой кусок работы. Вместо того чтобы каждый раз объяснять модели, как делать ревью или как исполнять план, ты говоришь одно слово — и она следует чёткой инструкции на русском, со всеми правилами, проверками и артефактами в нужных папках.
6
+ `eda` — это восемнадцать скилов, каждый отвечает за свой кусок работы. Вместо того чтобы каждый раз объяснять модели, как делать ревью или как исполнять план, ты говоришь одно слово — и она следует чёткой инструкции на русском, со всеми правилами, проверками и артефактами в нужных папках.
7
7
 
8
8
  ---
9
9
 
@@ -35,15 +35,17 @@ eda update-all ~/Code
35
35
 
36
36
  | Скил | Что делает | Куда складывает |
37
37
  |---|---|---|
38
- | `eda-start` | Помогает стартовать новый проект: собирает требования, вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Не пишет код и не ставит зависимости; сохраняет согласованные стартовые решения и по подтверждению создаёт черновики правил/архитектуры/AGENTS | `docs/project-starts/`, опционально `docs/rules.md`, `docs/arch.md`, `AGENTS.md` |
38
+ | `eda-start` | Помогает стартовать новый проект: собирает требования, вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Для выбранных пакетов всегда ищет последние стабильные версии по официальным источникам. Не пишет код и не ставит зависимости; сохраняет согласованные стартовые решения и по подтверждению создаёт черновики правил/архитектуры/AGENTS | `docs/project-starts/`, опционально `docs/rules.md`, `docs/arch.md`, `AGENTS.md` |
39
39
  | `eda-roadmap` | Создаёт roadmap-файл: список будущих задач с короткими, понятными и недвусмысленными описаниями без деталей реализации, файлов, библиотек, API и пошагового плана | `docs/roadmaps/` |
40
40
  | `eda-explore` | Исследует тему до конкретного результата: описание проблемы, релевантная архитектура, закрытые развилки, риски внутри решений и короткий выбранный вариант решения без плана. В дефолтном режиме ведёт исследование как диалог: факты собирает сам, а значимые развилки выносит тебе с рекомендацией. Если нужны пакеты или ПО — проверяет актуальные стабильные версии через context7 или web search | `docs/researches/` |
41
41
  | `eda-plan` | Пишет план реализации через стандартный Plan Mode хост-агента. `docs/rules.md` и `docs/arch.md` использует как обязательную рамку, а не справочный контекст: план должен строго следовать правилам и архитектуре. В плане явно фиксирует контракты БД/API, если задача их затрагивает. Затем три параллельных субагента/модели (слабая, средняя, мощная) проверяют план на реалистичность, пропущенные шаги и нарушения правил — главный планировщик сам решает, что применить | `docs/plans/` |
42
+ | `eda-plan-polish` | Полирует уже готовый план до оценки 95/100 или заданного порога. Сначала основной агент оценивает план; если оценка ниже порога, запускает три изолированных параллельных plan-polish агента, анализирует их предложения, правит только файл плана и повторяет цикл до качества или лимита | `docs/plans/` |
42
43
  | `eda-execute` | Выполняет план. Спрашивает, где работать (текущая ветка, новая ветка, отдельный worktree). Перед правками читает план, `docs/rules.md` и `docs/arch.md`; правила и архитектура обязательны к исполнению. Если шаг плана им противоречит, останавливается и спрашивает. Тесты пишет внутри каждого шага. В конце — полный прогон тестов и линтеров | `docs/executions/` |
43
44
  | `eda-fix` | Делает обычные фиксы по короткому контексту, баг-репорту или файлу плана. Перед правками читает правила и архитектуру, добавляет нужные тесты, прогоняет проверки и сохраняет историю правок | `docs/fixes/` |
44
45
  | `eda-review` | Делает код-ревью с оценкой 0–100 и сверкой с планом работ, но в файл пишет только проблемы: ошибки, недоделки, неточности, нарушения правил/архитектуры, риски и недостающие тесты. Если запущен без аргументов, ревьюит незакоммиченный `git diff HEAD` без проверки плана. Не перечисляет выполненную работу. В обычном режиме после черновика передаёт файл в `eda-review-check`; с флагом `draft` сохраняет только первичное ревью без субагентов | `docs/reviews/` |
45
46
  | `eda-review-check` | Проверяет готовое ревью из `docs/reviews/` специализированными субагентами: архитектуру, правила, выполнение плана при указанном plan-файле и при включённой настройке качество кода. В строгом режиме добавляет кросс-ревью между Claude и Codex. Сам применяет подтверждённые замечания к файлу ревью, но не правит код | `docs/reviews/` |
46
47
  | `eda-fix-by-review` | Применяет замечания из ревью. Обязательные — сразу. Спорные — спрашивает. В конце ссылается на отчёт прямо в файле ревью | `docs/review-fixes/` |
48
+ | `eda-manual-test` | Делает ручную smoke/acceptance-проверку после изменений: API прогоняет через `curl`/HTTP-запросы, фронт — через Playwright или доступную browser automation. Сам строит чеклист из входа, плана или diff, запускает очевидные dev/API-серверы и сохраняет QA-отчёт. Не правит код, не пишет автотесты и не коммитит | `docs/manual-tests/` |
47
49
  | `eda-polish` | Оркестрирует доводку изменений: запускает `eda-review draft`, затем `eda-review-check`, затем `eda-fix-by-review apply-optional` и повторяет цикл до оценки 95/100 или лимита 5 итераций. Каждый шаг идёт в изолированном субагенте или отдельном CLI-процессе. Не коммитит | `docs/reviews/`, `docs/review-fixes/` |
48
50
  | `eda-send-review` | Отправляет ревью на GitHub PR через `gh` — как комментарий, review, approve или request-changes. Сам определяет PR по текущей ветке | (комментарий в PR) |
49
51
  | `eda-commit` | Делает один аккуратный коммит в стиле проекта. В конце спрашивает: push, merge в main + удалить ветку, или ничего | (git) |
@@ -127,10 +129,10 @@ review:
127
129
  start ─────────────> docs ───────────────┬───────────────┐
128
130
  │ │ │
129
131
  v v v
130
- roadmap ────────> explore ─────> plan ───> execute ───┬──> review ───> review-check ───> fix-by-review ───┬──> send-review
132
+ roadmap ────────> explore ─────> plan ───> plan-polish ───> execute ───┬──> manual-test ───> review ───> review-check ───> fix-by-review ───┬──> send-review
131
133
  │ │ │
132
134
  └────────────> plan v └──> commit
133
- fix ─────────────> review
135
+ fix ─────────────> manual-test
134
136
  ```
135
137
 
136
138
  Если проект уже существует, можно начинать без `eda-start`:
@@ -139,16 +141,19 @@ start ─────────────> docs ─────────
139
141
  docs ───────────────┬───────────────┐
140
142
  │ │
141
143
  v v
142
- roadmap ────────> explore ─────> plan ───> execute ───┬──> review ───> review-check ───> fix-by-review ───┬──> send-review
144
+ roadmap ────────> explore ─────> plan ───> plan-polish ───> execute ───┬──> manual-test ───> review ───> review-check ───> fix-by-review ───┬──> send-review
143
145
  │ │ │
144
146
  └──────────────> plan v └──> commit
145
- fix ─────────────> review
147
+ fix ─────────────> manual-test
146
148
 
147
149
  polish = review draft ─> review-check ─> fix-by-review apply-optional ─> повтор до нужной оценки
150
+ plan-polish = оценка плана ─> 3 plan-polish агента ─> правка плана ─> повтор до 95/100
148
151
 
149
152
  automate может запускаться от review, fix-by-review или fix.
150
153
  ```
151
154
 
155
+ `eda-manual-test` обычно ставится после `eda-execute`, `eda-fix` или `eda-fix-by-review`, чтобы руками проверить API/UI перед ревью или коммитом.
156
+
152
157
  Использовать всю цепочку не обязательно — каждый скил самодостаточен. Новый проект можно начать с `eda-start`; существующий — с `eda-roadmap`, `eda-explore`, или сразу с `eda-execute` на готовом плане, или просто `eda-commit`, когда правки уже сделаны. Для параллельной работы есть `eda-worktree`, а для возврата ветки из worktree в текущую ветку — `eda-merge-worktree`.
153
158
 
154
159
  ---
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@gian-tiaga/eda",
3
- "version": "0.8.0",
4
- "description": "Набор скилов eda-* для Claude Code и Codex CLI: start, roadmap, explore, plan, execute, fix, review, review-check, fix-by-review, polish, send-review, commit, worktree, merge-worktree, docs, automate",
3
+ "version": "0.8.1",
4
+ "description": "Набор скилов eda-* для Claude Code и Codex CLI: start, roadmap, explore, plan, plan-polish, execute, fix, review, review-check, fix-by-review, manual-test, polish, send-review, commit, worktree, merge-worktree, docs, automate",
5
5
  "type": "module",
6
6
  "bin": {
7
7
  "eda": "bin/cli.js"
@@ -0,0 +1,135 @@
1
+ ---
2
+ name: eda-manual-test
3
+ description: 'Делает ручную smoke/acceptance-проверку после изменений: сам строит чеклист из входа пользователя, плана или незакоммиченного diff; для API выполняет curl/HTTP-запросы, для фронта использует Playwright или доступную browser automation. Сам запускает очевидные dev/API-серверы, фиксирует фактическое поведение и сохраняет QA-отчёт в docs/manual-tests/. Не правит код, не пишет автотесты, не ставит зависимости, не коммитит.'
4
+ ---
5
+
6
+ # Скил: Ручное тестирование (eda-manual-test)
7
+
8
+ Делаешь ручную smoke/acceptance-проверку уже сделанных изменений. Проверяешь не «что тесты зелёные», а что пользовательский или API-сценарий реально работает: страница открывается, действие проходит, endpoint отвечает, ошибки выглядят ожидаемо. Сохраняешь QA-отчёт. Код не правишь.
9
+
10
+ ## Вход из сообщения пользователя
11
+
12
+ Текст рядом с вызовом скилла в текущем сообщении пользователя — главный вход. Сначала разбери именно его: URL, endpoint, сценарий, план, ревью, issue, ветку, ограничение по окружению, логин/роль без секретов и прямые указания.
13
+
14
+ Если входа достаточно, продолжай без вопроса. Если входа нет, построй минимальный smoke-чеклист по незакоммиченному `git diff HEAD`, релевантному коду и документации проекта. `AskUserQuestion` задавай только если цель противоречива, найдено несколько равных окружений/URL, нужна авторизация без доступных тестовых данных или есть риск выполнить разрушительное действие. Старое обсуждение в истории не считай входом, если пользователь не связал его с текущим вызовом явно.
15
+
16
+ ## Главные правила
17
+
18
+ 1. **Ручная проверка, не разработка.** Не правь код, не пиши и не обновляй автотесты, не меняй конфиги, не коммить и не пушь.
19
+ 2. **Smoke по умолчанию.** Проверь запуск, основной happy path изменённой области и 1–2 негативных или edge-сценария, которые естественно следуют из задачи.
20
+ 3. **API проверяй запросами.** Используй `curl`, встроенный HTTP-клиент, Node `fetch` или проектные scripts. Фиксируй method, URL, важные headers без секретов, body, status code и ключевые поля ответа.
21
+ 4. **Фронт проверяй браузером.** Если в проекте есть Playwright — используй Playwright. Если Playwright не установлен, используй доступную browser automation хост-агента. Если браузерной автоматизации нет — спроси через `AskUserQuestion`; не устанавливай зависимости молча.
22
+ 5. **Серверы поднимай сам, если это очевидно.** Определи команды по `package.json`, README, docker compose, Makefile или локальным инструкциям. Останавливай только процессы, которые сам запустил.
23
+ 6. **Секреты не трогай.** Используй только уже доступные локальные `.env`, тестовые аккаунты и настройки. Не проси пользователя прислать секреты в чат и не печатай токены, cookies, passwords, API keys или Authorization headers в отчёт.
24
+ 7. **Разрушительное подтверждай.** Реальные платежи, удаление данных, отправку email/SMS/push, изменение production/staging-данных, миграции, очистку БД и похожие действия выполняй только после `AskUserQuestion`.
25
+ 8. **Проверяй фактическое поведение.** Не ограничивайся чтением кода. Если сценарий нельзя выполнить, зафиксируй `blocked` и конкретную причину.
26
+ 9. **Отчёт обязателен.** Сохрани результат в `docs/manual-tests/`, даже если проверка заблокирована или нашла баги.
27
+
28
+ ## Интерактивные вопросы
29
+
30
+ Когда инструкция говорит `AskUserQuestion`, это означает блокирующий интерактивный вопрос.
31
+ - Claude Code: используй `AskUserQuestion`.
32
+ - Codex interactive: если доступен `request_user_input`, используй его. Если tool недоступен, задай один короткий вопрос в чат, дай варианты 1–3, напиши «Ответь номером или своим вариантом. Я продолжу только после ответа.» и остановись.
33
+ - Codex exec / неинтерактивный запуск: не задавай вопросы и не пытайся читать stdin. Если без ответа нельзя безопасно продолжать, заверши работу со статусом `blocked: нужен ответ пользователя`, перечисли вопросы и варианты, не выполняй рискованные действия.
34
+ - Не запускай команды, которые ждут интерактивного ввода в терминале; перед такими командами спроси в хост-интерфейсе или остановись с `blocked`.
35
+
36
+ ## Этапы
37
+
38
+ ### 1. Определить цель проверки
39
+ Разбери вход пользователя. Если указан файл плана, ревью, research, issue или другой артефакт — прочитай его. Если входа нет, изучи `git diff HEAD`, изменённые файлы, README и релевантные роуты/страницы/компоненты.
40
+
41
+ Определи `$TEST_TARGET`: `api`, `frontend`, `fullstack` или `other`. Если цель всё ещё неоднозначна и можно проверить не то окружение или не тот сценарий — спроси через `AskUserQuestion`.
42
+
43
+ ### 2. Прочитать рамку проекта
44
+ Прочитай `docs/rules.md` и `docs/arch.md`, если есть. Найди команды запуска, тестовые URL, API-контракты, seed/test users и ограничения окружения в README, package scripts, docker compose, Makefile, OpenAPI/Swagger/Postman-файлах и существующих e2e-тестах.
45
+
46
+ Не устанавливай Playwright, браузеры, пакеты, docker images или системные зависимости молча. Если без этого проверка невозможна — спроси через `AskUserQuestion` или зафиксируй `blocked` в неинтерактивном режиме.
47
+
48
+ ### 3. Составить smoke-чеклист
49
+ Составь короткий чеклист:
50
+ - запуск приложения или API;
51
+ - основной happy path изменённой области;
52
+ - 1–2 негативных или edge-сценария;
53
+ - явные acceptance criteria из плана или входа пользователя;
54
+ - для фронта: console errors, network errors и видимые regressions на основной странице;
55
+ - для API: status code, схема/ключевые поля ответа, обработка неверного ввода или прав доступа, если это относится к задаче.
56
+
57
+ Не расширяй проверку до полного exploratory QA, если пользователь не попросил.
58
+
59
+ ### 4. Запустить окружение
60
+ Если приложение ещё не запущено и команды очевидны, запусти нужные dev/API-серверы. Дождись готовности по логам, healthcheck, открытому порту или успешному запросу. Если порт занят, проверь, подходит ли уже запущенный сервис; если нет — спроси или выбери очевидный альтернативный порт только когда проект это поддерживает.
61
+
62
+ Фиксируй команды запуска в черновике отчёта. Не заверши свой ответ, пока запущенные тобой процессы, нужные только для проверки, ещё работают.
63
+
64
+ ### 5. Проверить API
65
+ Для API-сценариев выполни реальные запросы. Предпочитай воспроизводимые команды `curl`, но можно использовать Node `fetch` или проектный HTTP-клиент, если так безопаснее.
66
+
67
+ Проверяй:
68
+ - успешный status code и ключевые поля ответа;
69
+ - корректную ошибку для неверного ввода, отсутствующих прав или несуществующей сущности, если это относится к задаче;
70
+ - отсутствие явных server errors, stack traces и утечек секретов в ответе.
71
+
72
+ Секретные headers и cookies в отчёт не вставляй: пиши `<redacted>`.
73
+
74
+ ### 6. Проверить фронт
75
+ Для фронтовых сценариев открой страницу в браузере. Если доступен Playwright, используй его для навигации, кликов, ввода и проверок. Если доступен browser plugin или другой инструмент браузерной автоматизации — используй его. Проверяй фактический UI, а не только DOM-текст.
76
+
77
+ Проверяй:
78
+ - страница загружается без критических console/network errors;
79
+ - основной сценарий пользователя проходит до ожидаемого результата;
80
+ - видимые состояния ошибок, пустых данных или невалидного ввода, если они относятся к задаче;
81
+ - текст и элементы управления не ломаются на очевидном desktop/mobile viewport, если менялась вёрстка.
82
+
83
+ Скриншоты сохраняй только если инструмент это поддерживает и они помогают подтвердить результат или баг. Складывай их рядом с отчётом или в подпапку `docs/manual-tests/assets/`.
84
+
85
+ ### 7. Сохранить отчёт
86
+ Сохрани отчёт в `docs/manual-tests/{YYYY-MM-DD}_{HH-MM}_{slug}.md`.
87
+
88
+ ```markdown
89
+ ---
90
+ date: <YYYY-MM-DD HH:MM>
91
+ source: <text | git diff HEAD | docs/plans/... | docs/reviews/...>
92
+ target: <api | frontend | fullstack | other>
93
+ status: <passed | failed | blocked>
94
+ ---
95
+
96
+ # Ручная проверка: <краткий заголовок>
97
+
98
+ ## Контекст
99
+ <что проверялось и откуда взяты сценарии>
100
+
101
+ ## Окружение
102
+ | Что | Значение |
103
+ |---|---|
104
+ | Команды запуска | `<command>` |
105
+ | URL / endpoint | `<url или endpoint>` |
106
+ | Авторизация | `<не нужна | тестовый пользователь | уже настроена | blocked>` |
107
+
108
+ ## Чеклист
109
+ | # | Сценарий | Способ проверки | Результат | Заметки |
110
+ |---|----------|-----------------|-----------|---------|
111
+ | 1 | ... | `curl ...` / Playwright / browser | ✓ / ✗ / ? | ... |
112
+
113
+ ## Найденные проблемы
114
+ <если нет — «Явных проблем не найдено»; если есть — список с воспроизведением и фактическим/ожидаемым результатом>
115
+
116
+ ## Артефакты
117
+ <ссылки на скриншоты, логи или «Нет»>
118
+
119
+ ## Итог
120
+ <passed / failed / blocked и короткое объяснение>
121
+ ```
122
+
123
+ Если найден баг, статус отчёта `failed`. Если проверка невозможна из-за окружения, авторизации, отсутствующих зависимостей или непонятного риска, статус `blocked`.
124
+
125
+ ### 8. Финал
126
+ Короткое сообщение: путь к отчёту, итог `passed` / `failed` / `blocked`, какие сценарии реально проверены, какие процессы остановлены, состояние git («не закоммичено»). Если итог `failed` или `blocked` — предложи дальше `eda-fix`. Если итог `passed` — предложи дальше `eda-review` или `eda-commit`.
127
+
128
+ ## Чего НЕ делать
129
+ - Править код, конфиги, миграции, seed-данные или документацию проекта, кроме отчёта в `docs/manual-tests/`.
130
+ - Писать или обновлять unit/e2e/autotests. Это работа `eda-fix`, `eda-execute` или отдельной задачи.
131
+ - Устанавливать Playwright, браузеры, npm-пакеты, docker images или системные зависимости без явного подтверждения.
132
+ - Подменять ручную проверку запуском `npm test` без фактического прохождения API/UI-сценария.
133
+ - Проверять production или staging с изменением данных без подтверждения пользователя.
134
+ - Сохранять секреты, cookies, токены или passwords в отчёт.
135
+ - Коммитить, пушить, создавать PR или отправлять ревью.
@@ -0,0 +1,209 @@
1
+ ---
2
+ name: eda-plan-polish
3
+ description: 'Итерационно полирует готовый план из `docs/plans/...` до оценки 95/100 или заданного порога. Сначала основной агент оценивает план по шкале 0–100. Если оценка ниже порога, запускает три изолированных параллельных plan-polish агента, получает конкретные предложения правок, сам принимает или отклоняет замечания, правит только файл плана и пересчитывает оценку. Не создаёт план с нуля, не меняет код, конфиги и зависимости.'
4
+ ---
5
+
6
+ # Скил: Полировка плана (eda-plan-polish)
7
+
8
+ Берёшь готовый план из `docs/plans/`, оцениваешь его по шкале 0–100 и доводишь до качества, достаточного для `eda-execute`. Порог по умолчанию — `95`: если план уже набирает 95 или выше, фиксируешь оценку и ничего не меняешь. Если ниже — запускаешь цикл полировки через три изолированных агента, применяешь принятые замечания, снова оцениваешь план и повторяешь до порога или лимита.
9
+
10
+ Основной агент остаётся редактором: он не вставляет предложения механически, а решает, какие принять, какие отклонить и какие требуют вопроса пользователю.
11
+
12
+ ## Вход из сообщения пользователя
13
+
14
+ Текст рядом с вызовом скилла в текущем сообщении пользователя — главный вход. Сначала разбери именно его: путь к плану, название или часть названия, «последний план», желаемый порог, лимит итераций, ограничения, прямые указания и запреты на типы правок.
15
+
16
+ Если этого входа достаточно, продолжай без вопроса. `AskUserQuestion` задавай только если входа нет, он противоречивый, найдено несколько равных вариантов или есть риск полировать не тот план. Старое обсуждение в истории не считай входом, если пользователь не связал его с текущим вызовом явно.
17
+
18
+ ## Режим запуска
19
+
20
+ Порог качества по умолчанию — `95`. Пользователь может переопределить его в текущем сообщении: `до 90`, `threshold 90`, `цель 90`. Допустимые значения — от `1` до `100`.
21
+
22
+ Лимит по умолчанию — `5` итераций полировки. Пользователь может явно задать меньший или больший лимит словами `лимит 3`, `max iterations 3`, `не больше 3 кругов`.
23
+
24
+ Оценка плана:
25
+ - `95–100` — план готов к исполнению, агенты полировки не нужны;
26
+ - `80–94` — план в целом рабочий, но требует уточнений перед `eda-execute`;
27
+ - `60–79` — план рискован: есть пропуски, общие шаги или слабые критерии готовности;
28
+ - `<60` — план нельзя исполнять без серьёзной переработки или вопросов пользователю.
29
+
30
+ ## Главные правила
31
+
32
+ 1. **Не создаёшь план с нуля.** Входом всегда является уже сохранённый файл `docs/plans/...`.
33
+ 2. **Не правишь код, миграции, конфиги и зависимости.** Можно менять только выбранный файл плана.
34
+ 3. **Сначала оцениваешь план сам.** До запуска агентов поставь текущую оценку 0–100 и коротко зафиксируй причины.
35
+ 4. **Агенты запускаются только если оценка ниже порога.** Если план набрал `threshold` или выше, не запускай изолированные проверки ради формы.
36
+ 5. **Три изолированных plan-polish агента обязательны в каждой итерации ниже порога.** Запусти `completeness-polisher`, `rules-arch-polisher` и `execution-readiness-polisher` параллельно, до чтения любого результата.
37
+ 6. **Главный редактор плана — ты.** Субагенты предлагают конкретные правки; решение применить, отклонить или спросить пользователя принимаешь сам.
38
+ 7. **Не добавляй неподтверждённые существенные решения.** Новые БД/API-контракты, зависимости, архитектурные развилки, auth/permissions/payments/secrets/персональные данные и миграции можно добавить только если они уже подтверждены в плане, research, `docs/rules.md`, `docs/arch.md` или ответом пользователя.
39
+ 8. **План должен остаться планом.** Не превращай его в отчёт ревью: принятые замечания встраивай в целевые разделы, а журнал решений держи коротким в конце.
40
+ 9. **Структуру `eda-plan` сохраняй.** Не удаляй обязательные разделы `Целевой алгоритм`, `Контракты реализации`, `Фазы выполнения`, `Тесты`, `Логирование`, если они есть или должны быть по формату `eda-plan`.
41
+ 10. **Останавливайся на блокерах.** Если качество не растёт два круга подряд, агенты предлагают только неподтверждённые развилки, нужен ответ пользователя или достигнут лимит — остановись и честно назови причину.
42
+
43
+ ## Интерактивные вопросы
44
+
45
+ Когда инструкция говорит `AskUserQuestion`, это означает блокирующий интерактивный вопрос.
46
+ - Claude Code: используй `AskUserQuestion`.
47
+ - Codex interactive: если доступен `request_user_input`, используй его. Если tool недоступен, задай один короткий вопрос в чат, дай варианты 1–3, напиши «Ответь номером или своим вариантом. Я продолжу только после ответа.» и остановись.
48
+ - Codex exec / неинтерактивный запуск: не задавай вопросы и не пытайся читать stdin. Если без ответа нельзя безопасно продолжать, заверши работу со статусом `blocked: нужен ответ пользователя`, перечисли вопросы и варианты, не выполняй рискованные действия.
49
+ - Не запускай команды, которые ждут интерактивного ввода в терминале; перед такими командами спроси в хост-интерфейсе или остановись с `blocked`.
50
+
51
+ ## Этапы
52
+
53
+ ### 1. Выбрать план и прочитать контекст
54
+
55
+ Определи `$PLAN_FILE`:
56
+ - если пользователь указал путь к плану — используй его;
57
+ - если указал название или часть названия — найди совпадение в `docs/plans/`;
58
+ - если написал «последний план» — возьми самый новый файл из `docs/plans/`;
59
+ - если входа нет — `AskUserQuestion` со списком последних файлов из `docs/plans/`;
60
+ - если `docs/plans/` отсутствует или пуста — остановись со статусом `blocked: нужен готовый план`.
61
+
62
+ Прочитай `$PLAN_FILE` целиком. Из front matter извлеки `status`, `mode`, `plan_size`, `test_strategy`, `logging_strategy`, `sources.rules`, `sources.arch`, `sources.research`, `meta_reviewers`.
63
+
64
+ Прочитай `docs/rules.md`, `docs/arch.md`, если они есть. Если в `sources.research` указан файл исследования — прочитай его. Если план ссылается на конкретные файлы, модули, API, миграции или тесты, открой достаточно релевантного кода, чтобы понять реализуемость плана.
65
+
66
+ ### 2. Первичная оценка плана
67
+
68
+ Поставь `$SCORE` по шкале 0–100. Оцени:
69
+ - следование `docs/rules.md` и `docs/arch.md`;
70
+ - отсутствие неподтверждённых существенных решений;
71
+ - конкретность `Целевого алгоритма`;
72
+ - полноту `Контрактов реализации`, особенно БД/API/внешних контрактов;
73
+ - исполнимость фаз: цель, шаги, результат, сценарии тестирования, проверка;
74
+ - применение `test_strategy` и `logging_strategy`;
75
+ - отсутствие альтернатив вида «выбрать», «решить», «уточнить позже»;
76
+ - возможность передать план в `eda-execute` без нового исследования.
77
+
78
+ Если `$SCORE >= threshold`, добавь или обнови в конце плана короткий раздел:
79
+
80
+ ```markdown
81
+ ## Оценка plan-polish
82
+ - **Итоговая оценка:** <score>/100
83
+ - **Порог:** <threshold>/100
84
+ - **Итерации:** 0
85
+ - **Решение:** план уже готов к исполнению, изолированные агенты не запускались.
86
+ ```
87
+
88
+ После этого переходи к финалу.
89
+
90
+ ### 3. Итерационный цикл полировки
91
+
92
+ Если `$SCORE < threshold`, повторяй до достижения порога или лимита.
93
+
94
+ #### 3.1. Запустить три изолированных агента
95
+
96
+ Запусти **в одном сообщении и одним batch** три роли. Не запускай сначала одного агента, не читай его ответ и не стартуй остальных после этого.
97
+
98
+ Роли:
99
+ - `completeness-polisher` — предлагает конкретные правки для пропущенных шагов, состояний UI/API, миграций/backfill/rollback, edge cases, документации и эксплуатационных шагов.
100
+ - `rules-arch-polisher` — предлагает конкретные правки для соответствия `docs/rules.md`, `docs/arch.md`, границам модулей, локальным запретам, архитектурным решениям, API/БД-контрактам и требованиям к проверкам.
101
+ - `execution-readiness-polisher` — предлагает конкретные правки, чтобы `eda-execute` мог выполнить план без нового исследования: фазы, критерии готовности, порядок работ, тестовые сценарии, команды проверки, логирование и удаление альтернатив вида «выбрать» или «решить».
102
+
103
+ Модели:
104
+ - Claude Code: запускай все роли через `Agent` tool, предпочтительно на `model: "sonnet"`.
105
+ - Codex interactive: если доступен инструмент субагентов (`spawn_agent` или аналог), запускай все роли через него, предпочтительно на `gpt-5.3-codex`.
106
+ - Codex exec / неинтерактивный fallback: если инструмента субагентов нет, запускай три `codex exec --model gpt-5.3-codex` параллельно одной Bash-командой с `&` и общим `wait`.
107
+ - Если указанный идентификатор модели недоступен, возьми ближайшую code-capable модель того же уровня. Не используй одну и ту же беседу вместо изолированных агентов.
108
+
109
+ Каждому агенту дай путь к `$PLAN_FILE`, текущий `$SCORE`, `$threshold`, номер итерации, `docs/rules.md`, `docs/arch.md`, `sources.research` при наличии и список релевантных файлов, найденных при чтении плана. Проси открывать код только в рамках своей роли и не править файлы.
110
+
111
+ Формат ответа агентов:
112
+
113
+ ```text
114
+ score: <оценка плана 0–100 по мнению агента>
115
+ + Применить: <конкретная правка и куда встроить>
116
+ ~ Уточнить: <что переформулировать>
117
+ -- Убрать: <что неверно, лишнее или противоречит контексту>
118
+ ? Вопрос: <что нельзя безопасно решить без пользователя>
119
+ ```
120
+
121
+ #### 3.2. Проанализировать замечания
122
+
123
+ Когда все три агента ответили, сгруппируй замечания:
124
+ - **Принять** — подтверждено планом, правилами, архитектурой, research или кодом; улучшает исполнимость без новой развилки.
125
+ - **Отклонить** — противоречит контексту, дублирует уже закрытый пункт, расширяет задачу, требует неподтверждённого существенного решения или выходит за рамки плана.
126
+ - **Спросить** — замечание выглядит существенным и полезным, но требует выбора пользователя или меняет ранее подтверждённое решение.
127
+
128
+ Если есть вопросы класса **Спросить**, задай один сгруппированный `AskUserQuestion` и не редактируй план до ответа. Если вопрос нужен только из-за предложения субагента, которое можно безопасно отклонить как расширение задачи, отклони его и продолжай.
129
+
130
+ #### 3.3. Отредактировать план
131
+
132
+ Внеси принятые замечания в основные разделы плана:
133
+ - конкретизируй `Целевой алгоритм`, если не хватает сквозного поведения;
134
+ - уточни `Контракты реализации`, если БД/API/внешние контракты затронуты, но описаны неполно;
135
+ - дополни фазы шагами, результатами, сценариями тестирования и проверками;
136
+ - приведи `Тесты` и `Логирование` в соответствие с `test_strategy` и `logging_strategy`;
137
+ - убери неподтверждённые альтернативы, общие формулировки и противоречия правилам/архитектуре.
138
+
139
+ Не меняй смысл подтверждённых решений без вопроса. Если план был `short`, не раздувай его больше 2 фаз: лучше заменить общие шаги конкретными, а лишнее отклонить как выход за short-рамку.
140
+
141
+ В конец плана добавь или обнови раздел:
142
+
143
+ ```markdown
144
+ ## Изменения после plan-polish
145
+
146
+ ### Итерация <N>: completeness-polisher / rules-arch-polisher / execution-readiness-polisher
147
+ - **Оценка до:** <score_before>/100
148
+ - **+ Добавлено:** <3–7 главных изменений>
149
+ - **~ Уточнено:** <1–5 важных уточнений>
150
+ - **− Убрано:** <если удалено>
151
+ - **Отклонено:** <существенные отклонённые предложения и причина>
152
+ - **Вопросы пользователя:** <если были, кратко решение>
153
+ ```
154
+
155
+ В front matter добавь фактически запущенные роли в `meta_reviewers`, если поле есть. Если поля нет — не перестраивай весь YAML ради этого, достаточно раздела `Изменения после plan-polish`. Если `status: draft` и после правок не осталось открытых вопросов, поменяй на `status: meta-reviewed`. Если статус уже `meta-reviewed` или `reviewed`, оставь его.
156
+
157
+ #### 3.4. Пересчитать оценку
158
+
159
+ Перечитай изменённый план и поставь новую оценку `$SCORE`.
160
+
161
+ Добавь или обнови в разделе `## Оценка plan-polish`:
162
+
163
+ ```markdown
164
+ ## Оценка plan-polish
165
+ - **Итоговая оценка:** <score>/100
166
+ - **Порог:** <threshold>/100
167
+ - **Итерации:** <N>
168
+ - **Решение:** <готов к исполнению | нужен следующий круг | blocked | достигнут лимит>
169
+ ```
170
+
171
+ Если `$SCORE >= threshold`, останови цикл: план готов. Если оценка не выросла два круга подряд, остановись `blocked: score не растёт`. Если лимит достигнут, остановись и прямо сообщи, что порог не достигнут.
172
+
173
+ ### 4. Финальная самопроверка
174
+
175
+ Перед финалом перечитай изменённый план и проверь:
176
+ - план строго следует `docs/rules.md` и `docs/arch.md`;
177
+ - нет неподтверждённых существенных решений и альтернатив вида «выбрать» / «решить»;
178
+ - БД/API изменения описаны конкретно или явно помечены как `Не затрагивается`;
179
+ - каждая фаза имеет цель, шаги, результат, сценарии тестирования и проверку;
180
+ - `test_strategy` и `logging_strategy` применены в фазах и отдельных разделах;
181
+ - план можно передать в `eda-execute` без нового исследования;
182
+ - журнал `Изменения после plan-polish` не заменяет содержание плана, а только объясняет редакторские решения.
183
+
184
+ Если после самопроверки остаётся блокер, не маскируй его правками: остановись со статусом `blocked` и назови, какой ответ или файл нужен.
185
+
186
+ ### 5. Финал
187
+
188
+ Короткое сообщение:
189
+ - путь к отполированному плану;
190
+ - итоговая оценка и порог;
191
+ - сколько итераций выполнено;
192
+ - какие три агента запускались, если запускались;
193
+ - 3–5 главных принятых изменений;
194
+ - существенные отклонённые замечания, если были;
195
+ - причина остановки: `готов`, `достигнут лимит`, `score не растёт`, `blocked`;
196
+ - следующий шаг при успехе: `eda-execute <PLAN_FILE>`.
197
+
198
+ ## Чего НЕ делать
199
+
200
+ - Создавать новый план вместо полировки существующего.
201
+ - Править код, миграции, конфиги, lock-файлы или зависимости.
202
+ - Запускать агентов, если первичная оценка уже достигла порога.
203
+ - Запускать агентов последовательно и менять промпты следующих агентов после первых ответов.
204
+ - Вставлять все предложения субагентов без анализа.
205
+ - Добавлять новые существенные решения без подтверждения пользователя.
206
+ - Удалять обязательные разделы плана ради краткости.
207
+ - Превращать план в длинный отчёт о ревью.
208
+ - Скрывать, что порог не достигнут.
209
+ - Коммитить, пушить или запускать `eda-execute`.
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  name: eda-start
3
- description: 'Помогает стартовать новый проект: собирает требования, критерии MVP, ограничения и риски; вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Для библиотек, CLI, сервисов и MCP проверяет актуальные стабильные версии по официальным источникам, если они не заданы. Не пишет код и не устанавливает зависимости: сохраняет согласованный стартовый документ в docs/project-starts/ и черновики docs/rules.md / docs/arch.md / AGENTS.md, если пользователь это подтвердил.'
3
+ description: 'Помогает стартовать новый проект: собирает требования, критерии MVP, ограничения и риски; вместе с пользователем выбирает стек, архитектуру, инструменты качества кода, AI-скилы, агентные инструкции, MCP-серверы и правила проекта. Для пакетов всегда ищет последние стабильные версии по официальным источникам; для библиотек, CLI, сервисов и MCP проверяет актуальные стабильные версии, если они не заданы. Не пишет код и не устанавливает зависимости: сохраняет согласованный стартовый документ в docs/project-starts/ и черновики docs/rules.md / docs/arch.md / AGENTS.md, если пользователь это подтвердил.'
4
4
  ---
5
5
 
6
6
  # Скил: Старт проекта (eda-start)
@@ -21,10 +21,11 @@ description: 'Помогает стартовать новый проект: с
21
21
  4. **Стек подбирается под задачу.** Не навязывай любимые технологии. Для каждого ключевого выбора дай 2–3 реалистичных варианта, рекомендацию и причину.
22
22
  5. **Инструменты качества обязательны для выбранного стека.** Подбери форматтер, линтер, статанализатор/typecheck, тестовый стек, coverage, dependency/security audit, pre-commit и CI-проверки, если они есть и уместны в выбранной экосистеме.
23
23
  6. **MCP и скилы — только по делу.** Рекомендуй MCP-сервер или скил, когда он закрывает реальную нехватку контекста, интеграцию, повторяемый процесс или качество агентной работы.
24
- 7. **Версии проверяй.** Если предлагаешь пакеты, CLI, фреймворки, сервисы или MCP-серверы, а версия не зафиксирована пользователем, проверь актуальную стабильную версию через context7, если он доступен, или через web search по официальным источникам.
25
- 8. **Архитектура должна быть объяснима.** Выбранная архитектура обязана соответствовать масштабу MVP, рискам, команде и будущему росту. Не предлагай сложность без причины.
26
- 9. **Правила должны быть применимы.** Каждое правило должно отвечать на конкретный риск проекта и иметь понятную проверку: автоматическую, ревью-проверку или договорённость в `docs/rules.md`.
27
- 10. **Простой язык. Таблицы** используй для сравнений стека, инструментов, MCP, скилов, правил и архитектурных вариантов.
24
+ 7. **Версии пакетов проверяй всегда.** Если предлагаешь npm/pip/gem/cargo/go/composer-пакет или пакет из другой экосистемы, найди последнюю стабильную версию через context7, если он доступен, или через web search по официальной документации, registry, release notes или репозиторию проекта. Не пиши `latest` без конкретной версии и источника. Если пользователь явно зафиксировал другую версию, не меняй её молча: покажи текущую стабильную, зафиксированную пользователем и причину расхождения.
25
+ 8. **Версии ПО тоже проверяй.** Если предлагаешь CLI, фреймворки, сервисы или MCP-серверы, а версия не зафиксирована пользователем, проверь актуальную стабильную версию через context7, если он доступен, или через web search по официальным источникам.
26
+ 9. **Архитектура должна быть объяснима.** Выбранная архитектура обязана соответствовать масштабу MVP, рискам, команде и будущему росту. Не предлагай сложность без причины.
27
+ 10. **Правила должны быть применимы.** Каждое правило должно отвечать на конкретный риск проекта и иметь понятную проверку: автоматическую, ревью-проверку или договорённость в `docs/rules.md`.
28
+ 11. **Простой язык. Таблицы** используй для сравнений стека, инструментов, MCP, скилов, правил и архитектурных вариантов.
28
29
 
29
30
  ## Интерактивные вопросы
30
31
 
@@ -65,6 +66,11 @@ description: 'Помогает стартовать новый проект: с
65
66
 
66
67
  Для выбранного стека зафиксируй конкретные версии основных компонентов или источник версии: runtime, framework, БД, ORM, тестовый фреймворк, build tool, package manager, контейнеры и ключевые сервисы.
67
68
 
69
+ Для каждого выбранного пакета отдельно зафиксируй:
70
+ - последнюю стабильную версию;
71
+ - источник версии и дату проверки;
72
+ - если версия зафиксирована пользователем и отличается от последней стабильной — обе версии и причину, почему остаёмся на pinned-версии или почему предлагаем обновление.
73
+
68
74
  ### 3. Подобрать инструменты качества
69
75
 
70
76
  Для выбранного стека подбери инструменты с обоснованием:
@@ -195,7 +201,8 @@ Quality gate перед сохранением:
195
201
  - есть список AI-скилов, агентных инструкций или ролей с назначением, источником и артефактом, подобранный под выбранную архитектуру и правила;
196
202
  - MCP-серверы имеют обоснование, права и риски, связанные с выбранной архитектурой, данными и интеграциями;
197
203
  - все значимые решения имеют подтверждение пользователя или явно помечены как автономная рекомендация;
198
- - версии пакетов/ПО проверены или объяснено, почему это не требуется.
204
+ - для каждого выбранного пакета указана последняя стабильная версия и источник; если используется не последняя стабильная версия, причина явно записана;
205
+ - версии другого ПО проверены или объяснено, почему это не требуется.
199
206
 
200
207
  ### 8. Создать черновики правил и архитектуры
201
208