mirror of
https://github.com/Nikolay-Shirokov/cc-1c-skills.git
synced 2026-06-10 08:04:56 +03:00
docs(web-test): README с CLI флагами, опциями стенда, известными нюансами
tests/web-test/README.md — практический mini-doc по запуску регресса:
- Запуск (полный / один файл / по тегам / по grep)
- CLI флаги runner'а (--tags, --grep, --bail, --retry, --timeout, --report,
--format, --screenshot, --report-dir, --record)
- Опции стенда после `--` (--rebuild-config, --reload-data, --rebuild-epf,
--rebuild-stand)
- Когда пересобирать стенд (warm-старт vs триггеры авто-пересборки vs
ручные сценарии)
- Конфигурация (webtest.config.mjs с contexts a/b, isolation модели)
- Env переменные (WEB_TEST_PRESERVE_CLIPBOARD, WEBTEST_HOOKS_RUNTIME)
- Артефакты (error-*.png, _allure/, lockfiles)
- Известные нюансы:
* 15-multi-context-handover накапливает Контрагентов между прогонами —
`02-crud` ловит «`ООО Север` должен быть в списке» когда total>20.
Лечится `-- --rebuild-stand`.
* 04-selectvalue auto-history шаг делает warm-up для детерминизма.
* --screenshot=every-step для full-trace.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,101 @@
|
||||
# Регресс-тесты web-test
|
||||
|
||||
E2E-тесты движка `web-test` (Playwright + изолированная синтетическая БД 1С), запускаются через `node .claude/skills/web-test/scripts/run.mjs test`.
|
||||
|
||||
## Запуск
|
||||
|
||||
```bash
|
||||
# Полный регресс (все 20 тестов)
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/
|
||||
|
||||
# Один файл
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/02-crud.test.mjs
|
||||
|
||||
# Несколько по фильтру тегов
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ --tags=table,smoke
|
||||
|
||||
# По regex имени теста
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ --grep=multi
|
||||
```
|
||||
|
||||
URL не указываем — берётся из `webtest.config.mjs` (`contexts.a.url` = `http://localhost:9191/webtest-runner/ru_RU`).
|
||||
|
||||
Exit code: 0 = все прошли, 1 = есть падения.
|
||||
|
||||
## CLI флаги runner'а
|
||||
|
||||
| Флаг | Описание |
|
||||
|---|---|
|
||||
| `--tags=A,B` | Запустить только тесты с одним из тегов |
|
||||
| `--grep=regex` | Фильтр по имени теста |
|
||||
| `--bail` | Остановиться на первой ошибке |
|
||||
| `--retry=N` | Перепрогон упавших тестов N раз |
|
||||
| `--timeout=ms` | Таймаут одного теста (default 30000) |
|
||||
| `--report=path` | Сохранить отчёт в файл |
|
||||
| `--format=json\|allure\|junit` | Формат отчёта |
|
||||
| `--report-dir=path` | Корень для Allure/JUnit артефактов |
|
||||
| `--screenshot=on-failure\|every-step\|off` | Когда снимать скриншоты |
|
||||
| `--record` | Включить запись MP4 (CDP screencast → ffmpeg) |
|
||||
|
||||
## Опции стенда (после `--`)
|
||||
|
||||
`_hooks.mjs` поднимает изолированный стенд (Apache на `:9191`, своя БД, отдельный набор EPF). По умолчанию работает в smart-режиме: пересборка только когда поменялся `config-hash` / `epf-hash`. Принудительно — через флаги после `--`:
|
||||
|
||||
```bash
|
||||
# Принудительно пересобрать XML + БД + EPF
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ -- --rebuild-stand
|
||||
|
||||
# Точечно — только пересобрать БД из существующего XML (свежая синтетика)
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ -- --reload-data
|
||||
|
||||
# Только пересобрать XML (когда хочется новой конфигурации)
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ -- --rebuild-config
|
||||
|
||||
# Только EPF (внешние обработки для openFile)
|
||||
node .claude/skills/web-test/scripts/run.mjs test tests/web-test/ -- --rebuild-epf
|
||||
```
|
||||
|
||||
| Флаг | Что делает |
|
||||
|---|---|
|
||||
| `--rebuild-stand` | Эквивалент всех трёх ниже |
|
||||
| `--rebuild-config` | XML-исходники + БД |
|
||||
| `--reload-data` | Только БД (drop+create+load+update) |
|
||||
| `--rebuild-epf` | Только EPF-обработки |
|
||||
|
||||
## Когда пересобирать стенд
|
||||
|
||||
**Warm-старт (~200 ms):** lockfile + probe Apache, БД жива, EPF на диске — ничего не делаем.
|
||||
|
||||
**Триггеры авто-пересборки** (без флагов):
|
||||
- Изменился `config-hash` синтетической XML — пересобирается конфигурация + БД.
|
||||
- Изменился `epf-hash` исходников EPF — пересобираются EPF.
|
||||
|
||||
**Когда нужен `--rebuild-stand` вручную:**
|
||||
- БД накопила «мусорных» данных от write-сценариев. `15-multi-context-handover` создаёт нового Контрагента каждый прогон с unique-именем — со временем `02-crud` начнёт падать (Контрагент `ООО Север` уезжает за `maxRows=20`).
|
||||
- Подозрение что Apache держит зависший процесс — `--rebuild-stand` делает `web-stop` + `web-publish`.
|
||||
|
||||
## Конфигурация
|
||||
|
||||
`tests/web-test/webtest.config.mjs` задаёт:
|
||||
- **`contexts.a` / `contexts.b`** — два независимых 1C-сеанса (разные cookies) на той же URL. Тесты с `multi-context` тегом используют оба.
|
||||
- **`defaultContext: 'a'`** — большинство тестов работают в одном контексте.
|
||||
- **`isolation: 'tab'`** — вкладки в одном окне (default). Альтернатива `'window'` — отдельный BrowserContext (полная изоляция cookies).
|
||||
|
||||
## Env переменные
|
||||
|
||||
| Переменная | Значение |
|
||||
|---|---|
|
||||
| `WEB_TEST_PRESERVE_CLIPBOARD=0` | Отключить save/restore буфера обмена вокруг `pasteText` |
|
||||
| `WEBTEST_HOOKS_RUNTIME=python` | Использовать py-версии скиллов вместо ps1 (для не-Windows) |
|
||||
|
||||
## Артефакты
|
||||
|
||||
- `tests/web-test/error-*.png` — скриншоты упавших шагов (auto на `--screenshot=on-failure`)
|
||||
- `tests/web-test/_allure/` — Allure-результаты (на `--format=allure`)
|
||||
- `tests/skills/.cache/webtest-stand/` — lockfiles стенда (config-hash, epf-hash, data-hash)
|
||||
|
||||
## Известные нюансы
|
||||
|
||||
- **`15-multi-context-handover`** создаёт `unique`-Контрагента и **сохраняет** — за серию прогонов накапливаются «лишние» записи. Если `02-crud` начал падать на «`ООО Север` должен быть в списке» — это симптом, лечится `-- --rebuild-stand`.
|
||||
- **`04-selectvalue` auto-history шаг** — в изоляции делает warm-up через двойной `selectValue('Менеджер', 'ООО Юг')` чтобы наполнить history, иначе первый вызов идёт через `method:form`, а тест ожидает `method:dropdown`. Не зависит от других файлов.
|
||||
- **Скриншот ошибки только на последнем падении** — `--screenshot=on-failure` (default) делает один кадр в момент исключения. Для full-trace используй `--screenshot=every-step`.
|
||||
Reference in New Issue
Block a user