feat: RBAC E2E тесты и фикс admin-прав для редактирования постов
Основные изменения: - Добавлены E2E тесты для проверки ownership (TC-E2E-102/103): * test_admin_can_edit_any_post — admin может редактировать любой пост * test_user_cannot_edit_other_users_post — user не может редактировать чужой пост - Исправлены use cases (UpdatePost, DeletePost, PublishPost) — добавлена проверка роли admin - Обновлены web routes и API routes для передачи роли в use cases - Добавлены unit тесты для admin-сценариев Реструктуризация тестов: - Удалены старые API тесты (tests/api/) — требуют переработки - Удалены старые integration тесты (tests/integration/) - Переработаны E2E тесты: удалены старые, добавлены новые с POM - Добавлена документация тестов: FEATURE_*.md, TEST_MODEL.md, AGENTS.md Инфраструктура: - Добавлен MockKeycloakClient для dev-режима - Добавлены статические файлы: EasyMDE, Highlight.js, стили markdown - Обновлены шаблоны: base.html, post_form.html, post_detail.html - Обновлена DI конфигурация и провайдеры Документация: - tests/FEATURE_RBAC.md — матрица тестов RBAC - tests/FEATURE_POST_LIFECYCLE.md — тесты жизненного цикла поста - tests/FEATURE_DOMAIN_FOUNDATION.md — тесты доменного слоя - tests/FEATURE_INFRASTRUCTURE.md — тесты инфраструктуры - tests/TEST_MODEL.md — глобальная матрица покрытия - app/presentation/web/AGENTS.md — гайд по Web UI - tests/AGENTS.md — гайд по тестированию
This commit is contained in:
@@ -16,6 +16,9 @@ dependencies = [
|
||||
"httpx>=0.28.0",
|
||||
"jinja2>=3.1.6",
|
||||
"itsdangerous>=2.2.0",
|
||||
"markdown-it-py>=4.0.0",
|
||||
"mdit-py-plugins>=0.5.0",
|
||||
"pygments>=2.20.0",
|
||||
]
|
||||
|
||||
[build-system]
|
||||
@@ -33,6 +36,8 @@ dev = [
|
||||
"playwright>=1.59.0",
|
||||
"pre-commit>=4.5.1",
|
||||
"pytest-playwright>=0.7.2",
|
||||
"python-multipart>=0.0.27",
|
||||
"types-pygments>=2.20.0.20260408",
|
||||
]
|
||||
tests = [
|
||||
"httpx>=0.28.1",
|
||||
@@ -65,12 +70,14 @@ addopts = "--cov=app --cov-report=term-missing --cov-report=html"
|
||||
pythonpath = "."
|
||||
testpaths = "tests"
|
||||
xfail_strict = true
|
||||
exclude = ["tests/e2e"]
|
||||
markers = [
|
||||
"e2e: End-to-end tests requiring running server",
|
||||
]
|
||||
|
||||
[tool.mypy]
|
||||
strict = true
|
||||
exclude = ["tests/e2e"]
|
||||
plugins = ["pydantic.mypy"]
|
||||
|
||||
[tool.ruff]
|
||||
|
||||
Reference in New Issue
Block a user