test-execution

$npx mdskill add SteelMorgan/1c-agent-based-dev-framework/test-execution

Executes YaxUnit tests, analyzes failures, and links them to code for debugging and validation.

  • Helps automate test runs and identify issues after code changes or before commits.
  • Integrates with YaxUnit testing framework and project build tools.
  • Decides actions based on triggers like post-implementation or test scope requirements.
  • Presents results through logs and error details, guiding fixes in context files.

SKILL.md

.github/skills/test-executionView on GitHub ↗
---
name: test-execution
description: Запуск и анализ тестов (Test Execution). Навык учит агента **запускать тесты YaxUnit, анализировать результаты и связывать падения тестов с кодом**.
---

# Запуск и анализ тестов (Test Execution)

Написание тестов — навык `test-writing`. Справочник API YaxUnit — `test-writing/references/yaxunit-cheatsheet.md`.

Тест упал → оцени: виноваты твои правки или нет. Если да — исправь, build, перезапусти. Если нет — зафиксируй причину в `<role>-context.md`.

## Расположение тестов

```
exts/TESTS/CommonModules/<ИмяМодуля>/Module.bsl
```

При `navigate_symbol` — файл в `exts/TESTS/src/CommonModules/`, не в основном `src/`.

## Обязательный порядок: Build → Tests

1. Менялись файлы (BSL, XML, тесты) → `build_project` → `run_tests`
2. Без изменений → `run_tests` напрямую

## Когда применять

| Триггер | Действие |
|---------|----------|
| После реализации | `build_project` → `run_tests` |
| Тесты модуля X | `build_project` → `run_tests(scope: "X")` |
| После рефакторинга | `build_project` → все тесты |
| Перед коммитом | `build_project` → `run_tests(scope: "all")` → `check_syntax` |

## Анализ падений

1. `errors[].module`, `errors[].test`, `errors[].message` — детали.
2. `navigate_symbol` → падающий тест → тестируемый код → исправить → перезапустить.

### Извлечение причины из логов (при `failedTests > 0`)

Порядок источников (строго по очереди, следующий — если текущий не дал причины):

1. **`logFile`**: строки `[ERR]` → многострочный блок до таймштампа → `Exception|Исключение|Assertion|expected|actual|stack`
2. **Журнал регистрации**: последние N записей об ошибках
3. **`enterpriseLogPath`**: маркеры `Ошибка|Исключение|Exception|Critical|Fatal|failed|assert` → блок 0..15 строк до пустой строки или таймштампа

## Интерпретация результатов

| Поле | Действие |
|------|----------|
| `success: true` | Все тесты пройдены |
| `success: false` | Анализировать `errors` |
| `failedTests > 0` | Извлекать причины из логов (см. выше) |

Legacy-синонимы: `total`/`totalTests`, `passed`/`passedTests`, `failed`/`failedTests`.

## Capabilities

| Capability | Назначение |
|------------|------------|
| `run_tests` | Запуск тестов YaxUnit |
| `build_project` | Сборка перед тестами |
| `navigate_symbol` | Переход к тесту и тестируемому коду |
| `check_syntax` | Проверка синтаксиса |

## Типичные ошибки

| Ошибка | Обходной путь |
|--------|---------------|
| Ошибка сборки | `build_project` → `check_syntax` → исправить |
| `run_tests` недоступен | Зафиксировать причину, сообщить пользователю |
| Модуль не найден | Проверить `scope`, sourceSet |
| Падения из-за данных ИБ | Уточнить настройки; отдельная тестовая ИБ |
| Долгое выполнение | `scope: "ИмяМодуля"` при итеративной разработке |

---
depends_on:
  - framework/skills/bsl-practices/test-writing/SKILL.md
---

More from SteelMorgan/1c-agent-based-dev-framework

SkillDescription
1c-ai-agent-cliCLI 1C BSL Agent Framework — tools/install.py (clone, install). Используй при клонировании репозитория, установке компонентов в проект, настройке IDE (Cursor, Claude Code, Windsurf, VS Code+Continue).
agent-debugПаттерн отладочных сообщений для 1С BSL. Используй, когда стандартная диагностика (event-log, скриншоты) не даёт понять фактическое поведение системы — нужно вставить временные точки логирования в код, запустить тест и проанализировать записи ЖР.
agent-developmentCreate custom subagents for specialized AI tasks. Use when the user wants to create a new type of subagent, set up task-specific agents, configure code reviewers, debuggers, or domain-specific assistants with custom prompts.
agent-development-ext>
agent-git-workflowStandardizes git workflow for the AI agent in the sandbox devcontainer: work in agent/<task>-<yyyymmdd>, integrate via agent, never push to main/master, open PRs via GitHub CLI. Use when the user asks to create branches, push changes, open PRs, or follow this sandbox repo setup.
auto-skill-bootstrapDeterministic helper to inventory existing project skills, detect missing capability coverage, search skills.sh via Skills CLI, and (optionally) install missing skills under a trust policy. Uses skills-manifest.json + state.json to stay idempotent across changing requirements.
code-navigationНавигация по коду (Code Navigation). Навык учит агента **эффективно перемещаться по BSL-коду** с помощью LSP (Language Server Protocol).
config-operationsОперации с конфигурацией 1С (CF) — init, info, edit, validate. Используй при создании конфигурации, анализе структуры, изменении свойств и ChildObjects, валидации Configuration.xml.
epf-buildСобрать EPF/ERF из XML-исходников. Используй после внесения временных диагностических правок в разобранную обработку.
epf-dumpРазобрать EPF/ERF в XML-исходники. Используй, когда нужно быстро получить исходный код внешней обработки или отчета для анализа и временной модификации.