WIP: dd1a0c0 feat(#6): Implement full CRUD for Locations and Labels

This commit is contained in:
2025-09-05 11:17:02 +03:00
parent dd1a0c0c51
commit af5c9be9d1
5 changed files with 112 additions and 315 deletions

View File

@@ -1,129 +1,84 @@
<GITEA_ISSUE_DRIVEN_PROTOCOL>
<META>
<PURPOSE>Определить единый, отказоустойчивый и полностью автоматизированный протокол для межагентной коммуникации, постановки задач и управления жизненным циклом кода. Gitea служит центральной коммуникационной шиной и системой контроля версий. Взаимодействие с Gitea осуществляется через утилиту командной строки 'tea-cli'.</PURPOSE>
<VERSION>3.0</VERSION>
<PURPOSE>Определить единый, отказоустойчивый и полностью автоматизированный протокол для межагентной коммуникации, основанный на использовании высокоуровневого клиента 'gitea-client.zsh'.</PURPOSE>
<VERSION>4.0</VERSION>
</META>
<CORE_PRINCIPLES>
<PRINCIPLE name="Gitea_As_The_System_Bus">
<DESCRIPTION>Gitea Issues и Pull Requests являются единственным каналом для асинхронной коммуникации между AI-агентами. Взаимодействие происходит через 'tea-cli'.</DESCRIPTION>
<PRINCIPLE name="Abstraction_Is_Mandatory">
<DESCRIPTION>**КЛЮЧЕВОЕ ИЗМЕНЕНИЕ:** Все взаимодействия с Gitea **ОБЯЗАНЫ** осуществляться исключительно через `gitea-client.zsh`. Прямые вызовы `tea` или `git` в рамках жизненного цикла задачи запрещены, чтобы гарантировать предсказуемость и централизованное управление логикой.</DESCRIPTION>
</PRINCIPLE>
<PRINCIPLE name="Automated_Context_Discovery">
<DESCRIPTION>Клиент `gitea-client.zsh` автоматически определяет репозиторий (`{repo_slug}`) при инициализации. Агентам не нужно управлять этим состоянием. Роль (`{role_name}`) передается как первый аргумент при каждом вызове.</DESCRIPTION>
</PRINCIPLE>
<PRINCIPLE name="Human_Out_Of_The_Loop">
<DESCRIPTION>Человек взаимодействует с системой исключительно через диалог с Агентом-Архитектором. Gitea используется как "закулисный" механизм, и человек не должен создавать, комментировать или назначать Issues вручную.</DESCRIPTION>
<DESCRIPTION>Человек взаимодействует с системой исключительно через диалог с Агентом-Архитектором, который инициирует весь воркфлоу.</DESCRIPTION>
</PRINCIPLE>
<PRINCIPLE name="Pull_Request_As_The_Unit_Of_Work">
<DESCRIPTION>Конечным продуктом работы Агента-Разработчика является не просто ветка с кодом, а формальный Pull Request (PR). Именно PR является объектом верификации для QA-Агента и точкой слияния в основную ветку.</DESCRIPTION>
</PRINCIPLE>
<PRINCIPLE name="Traceability_Is_Paramount">
<DESCRIPTION>Каждое действие в системе должно быть отслеживаемым. Это достигается за счет неразрывной связи: `GiteaIssue ID` <-> `Имя ветки` <-> `Pull Request ID`.</DESCRIPTION>
</PRINCIPLE>
<PRINCIPLE name="Initial_Check">
<DESCRIPTION>Перед началом работы проверь логин tea-cli whoami. Логин должен соответствовать твоей роли агента</DESCRIPTION>
<DESCRIPTION>Конечным продуктом работы Агента-Разработчика является формальный Pull Request (PR), который является основой для проверки и слияния.</DESCRIPTION>
</PRINCIPLE>
</CORE_PRINCIPLES>
<CLI_COMMANDS name="tea-cli">
<COMMAND name="create_issue">
<SYNTAX>`tea-cli issues create --title "{title}" --body "{body}" --assignee "{assignee}" --labels "{labels}"`</SYNTAX>
<DESCRIPTION>Создает новое Issue.</DESCRIPTION>
<CLIENT_API name="gitea-client.zsh">
<SYNTAX>`./gitea-client.zsh {role_name} {command} [options]`</SYNTAX>
<COMMAND name="create-task">
<SIGNATURE>`create-task --title "..." --body "..." --assignee "..." --labels "..."`</SIGNATURE>
<PURPOSE>Создание новой задачи в Gitea.</PURPOSE>
</COMMAND>
<COMMAND name="list_issues">
<SYNTAX>`tea-cli issues list --assignee "{assignee}" --labels "{labels}" --state "open"`</SYNTAX>
<RATIONALE>ВНИМАНИЕ: Фильтрация по assignee и labels в tea-cli может работать некорректно. Агент должен самостоятельно фильтровать полученный список задач.</RATIONALE>
<DESCRIPTION>Ищет открытые Issues по исполнителю и меткам.</DESCRIPTION>
<COMMAND name="find-tasks">
<SIGNATURE>`find-tasks --type "{label_name}"`</SIGNATURE>
<PURPOSE>Поиск открытых задач с нужным типом и статусом 'pending'.</PURPOSE>
</COMMAND>
<COMMAND name="update_issue">
<SYNTAX>`tea-cli issues edit {issue-id} --add-labels "{labels_to_add}" --remove-labels "{labels_to_remove}" --title "{title}" --assignee "{assignee}"`</SYNTAX>
<DESCRIPTION>Редактирует существующее Issue, в основном для смены статуса и исполнителя.</DESCRIPTION>
<COMMAND name="update-task-status">
<SIGNATURE>`update-task-status --issue-id ID --old "{label}" --new "{label}"`</SIGNATURE>
<PURPOSE>Атомарное изменение статуса задачи (например, с 'pending' на 'in-progress').</PURPOSE>
</COMMAND>
<COMMAND name="close_issue">
<SYNTAX>`tea-cli issues close {issue-id}`</SYNTAX>
<DESCRIPTION>Закрывает Issue.</DESCRIPTION>
<COMMAND name="create-pr">
<SIGNATURE>`create-pr --title "..." --body "..." --head "{branch}" --base "{target_branch}"`</SIGNATURE>
<PURPOSE>Создание Pull Request.</PURPOSE>
</COMMAND>
<COMMAND name="create_pr">
<SYNTAX>`tea-cli pull-request create --title "{title}" --body "{body}" --head "{branch_name}" --base "main"`</SYNTAX>
<DESCRIPTION>Создает Pull Request.</DESCRIPTION>
<COMMAND name="merge-and-complete">
<SIGNATURE>`merge-and-complete --issue-id ID --pr-id ID --branch "{branch_to_delete}"`</SIGNATURE>
<PURPOSE>Атомарная операция: слияние PR, удаление ветки и закрытие связанной задачи.</PURPOSE>
</COMMAND>
<COMMAND name="merge_pr">
<SYNTAX>`tea-cli pull-request merge {pr-id}`</SYNTAX>
<DESCRIPTION>Сливает Pull Request.</DESCRIPTION>
<COMMAND name="return-to-dev">
<SIGNATURE>`return-to-dev --issue-id ID --pr-id ID --report "{defect_report_text}"`</SIGNATURE>
<PURPOSE>Атомарная операция: отклонение PR, добавление комментария с отчетом и переназначение задачи разработчику.</PURPOSE>
</COMMAND>
<COMMAND name="close_pr">
<SYNTAX>`tea-cli pull-request close {pr-id}`</SYNTAX>
<DESCRIPTION>Отклоняет (закрывает) Pull Request.</DESCRIPTION>
</COMMAND>
</CLI_COMMANDS>
<SYSTEM_SPECIFICATIONS>
<SPECIFICATION name="Label_Taxonomy">
<DESCRIPTION>Строгая система меток для управления статусом и типом задач.</DESCRIPTION>
<SCHEMA>
<CATEGORY prefix="status::">
<LABEL name="status::pending">Задача ожидает исполнителя.</LABEL>
<LABEL name="status::in-progress">Задача в работе.</LABEL>
<LABEL name="status::completed">Задача успешно выполнена и закрыта.</LABEL>
<LABEL name="status::failed">Выполнение провалено, задача возвращена на доработку.</LABEL>
</CATEGORY>
<CATEGORY prefix="type::">
<LABEL name="type::development">Задача для Агента-Разработчика.</LABEL>
<LABEL name="type::quality-assurance">Задача для QA-Агента.</LABEL>
</CATEGORY>
</SCHEMA>
</SPECIFICATION>
<SPECIFICATION name="Branch_Naming_Convention">
<DESCRIPTION>Единый формат для всех веток, создаваемых AI-агентами.</DESCRIPTION>
<TEMPLATE>`{type}/{issue-id}/{kebab-case-description}`</TEMPLATE>
<COMPONENTS>
<COMPONENT name="type">'feature' для новой разработки, 'fix' для исправлений.</COMPONENT>
<COMPONENT name="issue-id">Номер Gitea Issue, инициировавшего создание ветки.</COMPONENT>
<COMPONENT name="kebab-case-description">Машиночитаемый заголовок Issue.</COMPONENT>
</COMPONENTS>
<EXAMPLE>`feature/123/implement-user-authentication-flow`</EXAMPLE>
</SPECIFICATION>
</SYSTEM_SPECIFICATIONS>
</CLIENT_API>
<MASTER_WORKFLOW name="Automated_Feature_Lifecycle">
<STEP id="1" name="Initiation (Human <-> Architect)">
<ACTION>Человек в диалоге ставит цель Архитектору. Архитектор проводит анализ, предлагает план и получает вербальное одобрение "Выполняй".</ACTION>
<STEP id="1" name="Initiation (Architect Agent)">
<ACTION>1. Архитектор, после согласования с человеком, создает задачу для Разработчика.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-architect create-task --title "Реализовать модуль X" --body "..." --assignee "agent-developer" --labels "type::development,status::pending"`</CLIENT_CALL>
</STEP>
<STEP id="2" name="Chain_Genesis (Architect -> Gitea -> Developer)">
<ACTION>Архитектор создает **первое Issue** в Gitea, используя команду `create_issue`.</ACTION>
<CLI_CALL>`tea-cli issues create --title "[ARCHITECT -> DEV] {Feature Summary}" --body "{XML Work Orders}" --assignee "agent-developer" --labels "status::pending,type::development"`</CLI_CALL>
<STEP id="2" name="Implementation (Developer Agent)">
<ACTION>1. Разработчик находит назначенную ему задачу.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-developer find-tasks --type "type::development"`</CLIENT_CALL>
<ACTION>2. Берет задачу в работу.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-developer update-task-status --issue-id {issue-id} --old "status::pending" --new "status::in-progress"`</CLIENT_CALL>
<ACTION>3. После написания кода и локальных тестов создает Pull Request.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-developer create-pr --title "feat: Реализован модуль X" --body "Closes #{issue-id}" --head "feature/{issue-id}-module-x"`</CLIENT_CALL>
<ACTION>4. Создает задачу для QA-агента, передавая ему контекст (ID задачи и PR).</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-developer create-task --title "QA: Проверить реализацию модуля X" --body "PR: #{pr-id}\nIssue: #{issue-id}" --assignee "agent-qa" --labels "type::quality-assurance,status::pending"`</CLIENT_CALL>
</STEP>
<STEP id="3" name="Development_And_PR_Creation (Developer)">
<ACTION>1. Разработчик находит Issue (`list_issues`), меняет его статус на `status::in-progress` (`update_issue`).</ACTION>
<CLI_CALL>`tea-cli issues edit {issue-id} --remove-labels "status::pending" --add-labels "status::in-progress"`</CLI_CALL>
<ACTION>2. Создает ветку согласно **Branch Naming Convention**.</ACTION>
<ACTION>3. Реализует код, коммитит его, проверяет сборку (`./gradlew build`).</ACTION>
<ACTION>4. Создает **Pull Request** в Gitea (`create_pr`).</ACTION>
<CLI_CALL>`tea-cli pull-request create --title "PR for Issue #{issue-id}: {Feature Summary}" --body "Fixes #{issue-id}" --head "{branch_name}" --base "main"`</CLI_CALL>
<ACTION>5. Создает **новое Issue** для QA-Агента (`create_issue`).</ACTION>
<CLI_CALL>`tea-cli issues create --title "[DEV -> QA] Verify & Merge PR #{pr-id}: {Feature Summary}" --body "<PULL_REQUEST_ID>{pr-id}</PULL_REQUEST_ID>" --assignee "agent-qa" --labels "status::pending,type::quality-assurance"`</CLI_CALL>
<ACTION>6. Закрывает **свой** Issue (`close_issue`).</ACTION>
<CLI_CALL>`tea-cli issues close {issue-id}`</CLI_CALL>
</STEP>
<STEP id="4" name="Verification_And_Merge (QA Agent)">
<ACTION>1. QA-Агент находит Issue (`list_issues`), меняет статус на `status::in-progress` (`update_issue`).</ACTION>
<CLI_CALL>`tea-cli issues edit {issue-id} --remove-labels "status::pending" --add-labels "status::in-progress"`</CLI_CALL>
<ACTION>2. Извлекает `PULL_REQUEST_ID` и проводит полный аудит кода в PR.</ACTION>
<ACTION>3. **ЕСЛИ УСПЕШНО:**</ACTION>
<SUCCESS_PATH>
<SUB_STEP>a. Сливает (Merge) Pull Request в `main` (`merge_pr`).</SUB_STEP>
<CLI_CALL>`tea-cli pull-request merge {pr-id}`</CLI_CALL>
<SUB_STEP>b. Удаляет feature-ветку.</SUB_STEP>
<SUB_STEP>c. Закрывает свой Issue (`close_issue`). **Цикл завершен.**</SUB_STEP>
<CLI_CALL>`tea-cli issues close {issue-id}`</CLI_CALL>
<STEP id="3" name="Verification_And_Merge (QA Agent)">
<ACTION>1. QA-Агент находит свою задачу.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-qa find-tasks --type "type::quality-assurance"`</CLIENT_CALL>
<ACTION>2. Берет задачу в работу.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-qa update-task-status --issue-id {qa-issue-id} --old "status::pending" --new "status::in-progress"`</CLIENT_CALL>
<ACTION>3. Извлекает `PULL_REQUEST_ID` и `DEVELOPER_ISSUE_ID` из тела задачи и проводит аудит кода.</ACTION>
<SUCCESS_PATH name="If Audit Passed">
<ACTION>Выполняет единую команду для слияния PR, удаления ветки и закрытия исходной задачи разработчика.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-qa merge-and-complete --issue-id {developer-issue-id} --pr-id {pr-id} --branch "feature/{issue-id}-module-x"`</CLIENT_CALL>
</SUCCESS_PATH>
<ACTION>4. **ЕСЛИ ПРОВАЛ:**</ACTION>
<FAILURE_PATH>
<SUB_STEP>a. Отклоняет Pull Request (`close_pr`).</SUB_STEP>
<CLI_CALL>`tea-cli pull-request close {pr-id}`</CLI_CALL>
<SUB_STEP>b. **Обновляет свой Issue**, возвращая его Разработчику (`update_issue`).</SUB_STEP>
<CLI_CALL>`tea-cli issues edit {issue-id} --title "[QA -> DEV] FAILED: Fix Defects in PR #{pr-id}" --assignee "agent-developer" --remove-labels "status::in-progress,type::quality-assurance" --add-labels "status::failed,type::development"`</CLI_CALL>
<RATIONALE>Это создает итеративный цикл исправления ошибок в рамках одной и той же ветки и PR.</RATIONALE>
<FAILURE_PATH name="If Audit Failed">
<ACTION>Выполняет единую команду для отклонения PR и возврата задачи разработчику с отчетом.</ACTION>
<CLIENT_CALL>`./gitea-client.zsh agent-qa return-to-dev --issue-id {developer-issue-id} --pr-id {pr-id} --report "Найдены следующие дефекты: ..."`</CLIENT_CALL>
</FAILURE_PATH>
</STEP>
</MASTER_WORKFLOW>