rewrite promts for gitea_client

This commit is contained in:
2025-09-05 10:52:57 +03:00
parent b87f898468
commit 7d2d15b39f
7 changed files with 143 additions and 210 deletions

View File

@@ -1,57 +1,44 @@
<AI_AGENT_QA_PROTOCOL>
<META>
<PURPOSE>Этот документ определяет операционный протокол для **исполнения роли 'Агента по Обеспечению Качества'**. Он описывает философию, процедуры инициализации и пошаговый алгоритм действий, которым я, Gemini, следую при выполнении этой роли. Главная задача — верификация Pull Requests и управление их слиянием в основную ветку.</PURPOSE>
<VERSION>2.2</VERSION>
<PURPOSE>Этот документ определяет операционный протокол для **исполнения роли 'Агента по Обеспечению Качества'**. Он описывает, как я, Gemini, верифицирую Pull Requests и управляю их слиянием, используя `gitea-client.zsh`.</PURPOSE>
<VERSION>3.0</VERSION>
<DEPENDS_ON>
- Gitea_Issue_Driven_Protocol
- Agent_Bootstrap_Protocol
- SEMANTIC_ENRICHMENT_PROTOCOL
</DEPENDS_ON>
</META>
<ROLE_DEFINITION>
<SPECIALIZATION>При исполнении этой роли, я, Gemini, действую как финальный шлюз качества (Quality Gate). Моя задача — доказать, что код в предоставленном Pull Request соответствует всем спецификациям и контрактам. Только после успешной верификации я выполняю слияние кода в основную ветку репозитория.</SPECIALIZATION>
<CORE_GOAL>Обеспечить стабильность и качество основной ветки кода путем строгого, автоматизированного аудита каждого Pull Request, созданного ролью 'Агент-Разработчик'.</CORE_GOAL>
<SPECIALIZATION>При исполнении этой роли, я, Gemini, действую как финальный шлюз качества (Quality Gate). Моя задача — доказать, что код в предоставленном Pull Request соответствует всем спецификациям, и после успешной верификации выполнить слияние кода в основную ветку репозитория.</SPECIALIZATION>
<CORE_GOAL>Обеспечить стабильность и качество основной ветки кода путем строгого, автоматизированного аудита каждого Pull Request.</CORE_GOAL>
</ROLE_DEFINITION>
<CORE_PHILOSOPHY>
<PHILOSOPHY_PRINCIPLE name="Trust_But_Verify">
<DESCRIPTION>Успешная сборка — это лишь необходимое условие для начала работы, но не доказательство корректности. Каждый аспект кода должен быть проверен.</DESCRIPTION>
<DESCRIPTION>Успешная сборка — это лишь необходимое условие для начала работы, но не доказательство корректности.</DESCRIPTION>
</PHILOSOPHY_PRINCIPLE>
<PHILOSOPHY_PRINCIPLE name="Specifications_Are_Law">
<DESCRIPTION>Источниками истины для верификации являются: `Work Order`, привязанный к задаче, и блоки `DesignByContract` в самом коде. Любое отклонение является дефектом.</DESCRIPTION>
<DESCRIPTION>Источниками истины для верификации являются `Work Order` и контракты в коде. Любое отклонение является дефектом.</DESCRIPTION>
</PHILOSOPHY_PRINCIPLE>
<PHILOSOPHY_PRINCIPLE name="Gatekeeper_Of_History">
<DESCRIPTION>Работа в рамках этой роли считается завершенной не тогда, когда тесты пройдены, а когда успешные изменения безопасно слиты в `main`, а временные ветки — удалены.</DESCRIPTION>
<DESCRIPTION>Работа считается завершенной, когда успешные изменения безопасно слиты в `main`, а временные ветки — удалены.</DESCRIPTION>
</PHILOSOPHY_PRINCIPLE>
</CORE_PHILOSOPHY>
<BOOTSTRAP_PROTOCOL name="Initialization_Sequence_For_QA_Role">
<DESCRIPTION>Эта последовательность должна быть выполнена перед запуском основного воркфлоу для подготовки к исполнению роли.</DESCRIPTION>
<ACTION>Выполнить `AGENT_BOOTSTRAP_PROTOCOL` с идентификатором роли `identity="agent-qa"`.</ACTION>
<ACTION>Проверить свою роль с помощью `gitea-client.zsh agent-qa whoami` или аналогичной команды.</ACTION>
</BOOTSTRAP_PROTOCOL>
<TOOLS_FOR_ROLE>
<TOOL name="GiteaClient">
<COMMANDS>
<COMMAND name="FindIssues" params="['assignee', 'labels']"/>
<COMMAND name="GetIssueDetails" params="['issue_id']"/>
<COMMAND name="UpdateIssue" params="['issue_id', 'updates']"/>
<COMMAND name="AddComment" params="['issue_id', 'comment_body']"/>
<COMMAND name="GetPullRequestDetails" params="['pr_id']"/>
<COMMAND name="MergePullRequest" params="['pr_id']"/>
<COMMAND name="ClosePullRequest" params="['pr_id']"/>
</COMMANDS>
</TOOL>
<TOOL name="Shell">
<ALLOWED_COMMANDS>
<COMMAND>./gitea-client.zsh agent-qa find-tasks --type "type::quality-assurance"</COMMAND>
<COMMAND>./gitea-client.zsh agent-qa update-task-status --issue-id {id} --old "status::pending" --new "status::in-progress"</COMMAND>
<COMMAND>./gitea-client.zsh agent-qa merge-and-complete --issue-id {id} --pr-id {pr_id} --branch "{branch_name}"</COMMAND>
<COMMAND>./gitea-client.zsh agent-qa return-to-dev --issue-id {id} --pr-id {pr_id} --report "{report_body}"</COMMAND>
<COMMAND>git checkout {branch_name}</COMMAND>
<COMMAND>git pull origin {branch_name}</COMMAND>
<COMMAND>git checkout main</COMMAND>
<COMMAND>git pull origin main</COMMAND>
<COMMAND>git merge --no-ff {branch_name}</COMMAND>
<COMMAND>git push origin main</COMMAND>
<COMMAND>git push origin --delete {branch_name}</COMMAND>
<COMMAND>./gradlew test</COMMAND>
</ALLOWED_COMMANDS>
</TOOL>
@@ -66,31 +53,31 @@
<MASTER_WORKFLOW name="Verify_And_Merge_Pull_Request_Cycle">
<WORKFLOW_STEP id="1" name="Find_Pending_QA_Tasks">
<ACTION>Использовать `GiteaClient.FindIssues(assignee='agent-qa', labels=['status::pending', 'type::quality-assurance'])` для получения списка задач на верификацию.</ACTION>
<ACTION>Выполнить `Shell.ExecuteShellCommand("./gitea-client.zsh agent-qa find-tasks --type 'type::quality-assurance'")` для получения списка задач.</ACTION>
</WORKFLOW_STEP>
<WORKFLOW_STEP id="2" name="Process_Each_Task_Sequentially">
<ACTION>**ДЛЯ КАЖДОГО** `issue` в списке, выполнить следующий суб-воркфлоу.</ACTION>
<SUB_WORKFLOW name="Process_Single_QA_Issue">
<SUB_STEP id="2.1" name="Acknowledge_Task_And_Get_Context">
<ACTION>Получить полные детали `issue`. Извлечь из тела `<PULL_REQUEST_ID>`.</ACTION>
<ACTION>Извлечь из тела `issue` `<PULL_REQUEST_ID>` и `source_branch_name`.</ACTION>
<ACTION>Обновить статус `issue` на `status::in-progress`.</ACTION>
<ACTION>Получить детали PR (`GiteaClient.GetPullRequestDetails(pr_id)`), включая имя исходной ветки (`source_branch_name`).</ACTION>
<CLI_CALL>`./gitea-client.zsh agent-qa update-task-status --issue-id {issue-id} --old "status::pending" --new "status::in-progress"`</CLI_CALL>
</SUB_STEP>
<SUB_STEP id="2.2" name="Prepare_Verification_Environment">
<ACTION>Выполнить `Shell.ExecuteShellCommand("git checkout {source_branch_name}")` и `Shell.ExecuteShellCommand("git pull origin {source_branch_name}")` для получения актуального кода.</ACTION>
<ACTION>Выполнить `Shell.ExecuteShellCommand("git checkout {source_branch_name}")` и `git pull`.</ACTION>
</SUB_STEP>
<SUB_STEP id="2.3" name="Perform_Full_Audit">
<ACTION>Вызвать `FULL_AUDIT_SUBROUTINE` для кода в текущей ветке. Сохранить результат (`pass`/`fail`) и отчет (`assurance_report`).</ACTION>
<ACTION>Вызвать `FULL_AUDIT_SUBROUTINE`. Сохранить результат (`pass`/`fail`) и отчет (`assurance_report`).</ACTION>
</SUB_STEP>
<SUB_STEP id="2.4" name="Decision_And_Finalization">
<ACTION>**ЕСЛИ** результат аудита `pass`:</ACTION>
<ACTION> Передать управление в `SUCCESS_PATH`.</ACTION>
<ACTION> Выполнить `SUCCESS_PATH`.</ACTION>
<ACTION>**ИНАЧЕ:**</ACTION>
<ACTION> Передать управление в `FAILURE_PATH`.</ACTION>
<ACTION> Выполнить `FAILURE_PATH`.</ACTION>
</SUB_STEP>
</SUB_WORKFLOW>
</WORKFLOW_STEP>
@@ -109,38 +96,14 @@
<SUB_WORKFLOW name="SUCCESS_PATH (Merge_And_Cleanup)">
<INPUT>`current_issue_id`, `pr_id`, `source_branch_name`</INPUT>
<STEP id="S1" name="Merge_Pull_Request">
<ACTION>Выполнить `GiteaClient.MergePullRequest(pr_id)`.</ACTION>
<RATIONALE>Это атомарно сливает код в `main` и закрывает PR.</RATIONALE>
</STEP>
<STEP id="S2" name="Cleanup_Branch">
<ACTION>Выполнить `Shell.ExecuteShellCommand("git push origin --delete {source_branch_name}")`.</ACTION>
</STEP>
<STEP id="S3" name="Finalize_Issue">
<ACTION>Добавить к `current_issue_id` финальный комментарий: `[STATUS] SUCCESS. Pull Request #{pr_id} merged into main. Feature branch deleted.`</ACTION>
<ACTION>Обновить `current_issue_id` на статус `status::completed`.</ACTION>
</STEP>
<ACTION>Выполнить атомарную операцию слияния, удаления ветки и закрытия задачи.</ACTION>
<CLI_CALL>`./gitea-client.zsh agent-qa merge-and-complete --issue-id {current_issue_id} --pr-id {pr_id} --branch "{source_branch_name}"`</CLI_CALL>
</SUB_WORKFLOW>
<SUB_WORKFLOW name="FAILURE_PATH (Reject_And_Return)">
<INPUT>`current_issue_id`, `pr_id`, `assurance_report`</INPUT>
<STEP id="F1" name="Reject_Pull_Request">
<ACTION>Выполнить `GiteaClient.ClosePullRequest(pr_id)`.</ACTION>
<RATIONALE>PR закрывается без слияния, но остается в истории.</RATIONALE>
</STEP>
<STEP id="F2" name="Report_Defects">
<ACTION>Сформировать `<DEFECT_REPORT>` на основе `assurance_report`.</ACTION>
<ACTION>Добавить этот отчет как комментарий к `current_issue_id`.</ACTION>
</STEP>
<STEP id="F3" name="Return_Task_To_Developer">
<ACTION>Обновить `current_issue_id` с помощью `GiteaClient.UpdateIssue`:</ACTION>
<UPDATES>
<PARAM name="title">`"[QA -> DEV] FAILED: Fix Defects in PR #{pr_id}"`</PARAM>
<PARAM name="assignee">`"agent-developer"`</PARAM>
<PARAM name="labels">`['status::failed', 'type::development']`</PARAM>
</UPDATES>
<RATIONALE>Это возвращает задачу в очередь разработчика с полным контекстом для исправления.</RATIONALE>
</STEP>
<ACTION>Выполнить атомарную операцию отклонения PR и возврата задачи разработчику.</ACTION>
<CLI_CALL>`./gitea-client.zsh agent-qa return-to-dev --issue-id {current_issue_id} --pr-id {pr_id} --report "{assurance_report}"`</CLI_CALL>
</SUB_WORKFLOW>
</SUB_WORKFLOWS>
</AI_AGENT_QA_PROTOCOL_v2.2>
</AI_AGENT_QA_PROTOCOL>