docs(stage): пункт 2 done — каталог CRUD + multi-tenant зелёный, 2 фикса

This commit is contained in:
nns 2026-05-29 16:46:32 +05:00
parent d54e1cb968
commit 4c2841db5b

View file

@ -19,7 +19,7 @@
## Чек-лист ## Чек-лист
- [x] **1. Smoke + signup flow** — signup создаёт org "TestStage", bootstrap (магазин/роли/единицы/группа "Все товары"), логин даёт access+refresh. *(stage-smoke.yml: 5/5 ✓)* - [x] **1. Smoke + signup flow** — signup создаёт org "TestStage", bootstrap (магазин/роли/единицы/группа "Все товары"), логин даёт access+refresh. *(stage-smoke.yml: 5/5 ✓)*
- [ ] **2. Каталог (товары/группы/контрагенты)** — UI CRUD, дубликаты, дочерние группы, FK-защита, multi-tenant изоляция (2 org). - [x] **2. Каталог (товары/группы/контрагенты)** — UI CRUD, дубликаты, дочерние группы, FK-защита, multi-tenant изоляция (2 org). *(stage-catalog.yml: 6/6 ✓, 2 фикса)*
- [ ] **3. Склад. Enter (Оприходование)** — UI создание/проведение/Unpost → Stock + StockMovement; RowVersion concurrency; multi-tenant. - [ ] **3. Склад. Enter (Оприходование)** — UI создание/проведение/Unpost → Stock + StockMovement; RowVersion concurrency; multi-tenant.
- [ ] **4. Loss (Списание)** — UI + LossReason; запрет списания больше остатка; multi-tenant. - [ ] **4. Loss (Списание)** — UI + LossReason; запрет списания больше остатка; multi-tenant.
- [ ] **5. Transfer (Перемещение)** — два склада, From!=To, atomic post, Unpost без orphan-движений; multi-tenant. - [ ] **5. Transfer (Перемещение)** — два склада, From!=To, atomic post, Unpost без orphan-движений; multi-tenant.
@ -40,6 +40,14 @@
- Проверена доступность `https://test.admin.food-market.kz/health/ready` → 200. - Проверена доступность `https://test.admin.food-market.kz/health/ready` → 200.
- Создан этот файл из задания. - Создан этот файл из задания.
### 2026-05-29 — пункт 2 ✓ (2 фикса в проде)
- Сценарий `stage-catalog` (6 шагов): 2 org через signup, продукты CRUD, контрагенты CRUD, multi-tenant изоляция.
- **Bug fix #1 — PUT product с новым barcode'ом валился 409.** Тот же EF8-баг что в TD-6 на документах: nav-collection.Add при наличии client-side Id даёт UPDATE 0 affected. Чиним паттерном ExecuteDelete+DbSet.Add — как в Supplies/Demands/RetailSales. Воспроизведение: создал продукт с 1 barcode → PUT с 2 barcodes → 409. Фикс → 204.
- **Bug fix #2 — IX_products_OrganizationId_Article не уникальный.** Контроллер ловил нарушение по имени индекса (`catch (DbUpdateException ex) when (...Contains("IX_products_..."))`), но индекс был неуникальным. Дубликаты артикулов проскакивали. Миграция Phase8d делает индекс UNIQUE; existing-дубликаты нумеруются `-2/-3/…`.
- Multi-tenant изоляция строгая: org B → 404 на products/counterparties org A (GET/PUT/DELETE), списки пустые.
- Commit `d54e1cb`. Deploy на stage прошёл, retest зелёный.
### 2026-05-29 — пункт 1 ✓ ### 2026-05-29 — пункт 1 ✓
- Сценарий `stage-smoke` (5 шагов): `tests/e2e/scenarios/stage-smoke.{yml,steps.ts}`. - Сценарий `stage-smoke` (5 шагов): `tests/e2e/scenarios/stage-smoke.{yml,steps.ts}`.