- Schema version (x_schema_version, schema_hash) в prompt/trace - Кеш read/search/logs/env (ContextCache) в plan-цикле - Контекст-диета: MAX_FILES=8, MAX_FILE_CHARS=20k, MAX_TOTAL_CHARS=120k - Plan→Apply двухфазность, NO_CHANGES, path sanitization - Protected paths, content validation, EOL normalization - Trace (PAPAYU_TRACE), redaction (PAPAYU_TRACE_RAW) - Preview diff, undo/redo, transactional apply Co-authored-by: Cursor <cursoragent@cursor.com>
62 lines
2.1 KiB
Markdown
62 lines
2.1 KiB
Markdown
# PAPA YU Tests
|
|
|
|
## Структура
|
|
|
|
```
|
|
tests/
|
|
├── README.md # Этот файл
|
|
└── fixtures/ # Тестовые фикстуры (минимальные проекты)
|
|
├── minimal-node/ # Node.js проект без README
|
|
└── minimal-rust/ # Rust проект без README
|
|
```
|
|
|
|
## Юнит-тесты (Rust)
|
|
|
|
Запуск всех юнит-тестов:
|
|
|
|
```bash
|
|
cd src-tauri
|
|
cargo test
|
|
```
|
|
|
|
Текущие тесты покрывают:
|
|
- `detect_project_type` — определение типа проекта
|
|
- `get_project_limits` — лимиты по типу проекта
|
|
- `is_protected_file` — защита служебных файлов
|
|
- `is_text_allowed` — фильтр текстовых файлов
|
|
- `settings_export` — экспорт/импорт настроек
|
|
|
|
## E2E сценарий (ручной)
|
|
|
|
См. `docs/E2E_SCENARIO.md` для пошагового сценария:
|
|
|
|
1. Запустить приложение: `npm run tauri dev`
|
|
2. Выбрать одну из фикстур (например, `tests/fixtures/minimal-node`)
|
|
3. Запустить анализ
|
|
4. Применить рекомендованные исправления
|
|
5. Проверить, что README.md создан
|
|
6. Откатить изменения (Undo)
|
|
7. Проверить, что README.md удалён
|
|
|
|
## Тестовые фикстуры
|
|
|
|
### minimal-node
|
|
|
|
Минимальный Node.js проект:
|
|
- `package.json` — манифест пакета
|
|
- `index.js` — точка входа
|
|
- **Нет README** — должен быть предложен при анализе
|
|
|
|
### minimal-rust
|
|
|
|
Минимальный Rust проект:
|
|
- `Cargo.toml` — манифест пакета
|
|
- `src/main.rs` — точка входа
|
|
- **Нет README** — должен быть предложен при анализе
|
|
|
|
## Автоматизация E2E (будущее)
|
|
|
|
Планируется использовать:
|
|
- **Tauri test** — для тестирования команд
|
|
- **Playwright** — для тестирования UI
|