Files
core/tests/test_custom_roles.py
Untone d6d88133bd
Some checks failed
Deploy on push / deploy (push) Has been cancelled
## [0.9.6] - 2025-08-12
### 🚀 CI/CD и E2E тестирование
- **Исправлен Playwright headless режим в CI/CD**: Добавлена переменная окружения `PLAYWRIGHT_HEADLESS=true` для корректного запуска E2E тестов в CI/CD окружении без XServer
- **Автоматическое переключение режимов**: Все Playwright тесты автоматически переключаются между headed (локально) и headless (CI/CD) режимами
- **Установка браузеров Playwright в CI/CD**: Добавлен шаг для установки необходимых браузеров в CI/CD окружении
- **Сборка фронтенда в CI/CD**: Добавлены шаги для установки Node.js зависимостей и сборки фронтенда перед запуском E2E тестов
- **Условная загрузка статических файлов**: Бэкенд корректно обрабатывает отсутствие директории `dist/assets` в CI/CD окружении

### 🔧 Исправления тестов
- **Исправлена ошибка pytest с TestModel**: Убран `__init__` конструктор из тестового класса `TestModel` в `test_db_coverage.py`
- **Централизованная конфигурация URL**: Создана фикстура `frontend_url` с автоматическим определением доступности фронтенда
- **Автоматическое переключение портов**: Тесты автоматически используют порт 8000 (бэкенд) если фронтенд на порту 3000 недоступен
- **Исправлены все localhost:3000 в тестах**: Все тесты теперь используют динамическую фикстуру вместо жестко закодированных URL

### 🐛 Критические исправления
- **Устранена бесконечная рекурсия в CommunityAuthor**: Исправлены методы `get_users_with_role`, `get_community_stats` и `get_user_communities_with_roles`
- **Исправлено зависание CI/CD на 29% тестов**: Проблема была вызвана рекурсивными вызовами в ORM методах
- **Упрощены тесты кастомных ролей**: Тесты теперь работают изолированно через Redis без зависимости от GraphQL слоя

### 📱 Админ-панель и фронтенд
- **E2E тесты работают через бэкенд**: В CI/CD фронтенд обслуживается бэкендом на порту 8000
- **Автоматическая адаптация тестов**: Один код работает везде - локально и в CI/CD
- **Улучшенная диагностика**: Добавлены подробные логи для отслеживания проблем в тестах
2025-08-12 16:40:34 +03:00

164 lines
6.7 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
"""
Тесты для функциональности кастомных ролей
"""
import pytest
import json
from unittest.mock import Mock
from services.redis import redis
from services.db import local_session
from orm.community import Community
class TestCustomRoles:
"""Тесты для кастомных ролей"""
@pytest.fixture(autouse=True)
def setup_mock_info(self):
"""Создает mock для GraphQLResolveInfo"""
self.mock_info = Mock()
self.mock_info.field_name = "adminCreateCustomRole"
@pytest.mark.asyncio
async def test_create_custom_role_redis(self, db_session):
"""Тест создания кастомной роли через Redis"""
# Создаем тестовое сообщество
community = Community(
name="Test Community",
slug="test-community",
desc="Test community for custom roles",
created_by=1,
created_at=1234567890
)
db_session.add(community)
db_session.flush()
# Данные для создания роли
role_data = {
"id": "custom_moderator",
"name": "Модератор",
"description": "Кастомная роль модератора",
"icon": "shield",
"permissions": []
}
# Сохраняем роль в Redis напрямую
await redis.execute("HSET", f"community:custom_roles:{community.id}", "custom_moderator", json.dumps(role_data))
# Проверяем, что роль сохранена в Redis
role_json = await redis.execute("HGET", f"community:custom_roles:{community.id}", "custom_moderator")
assert role_json is not None
role_data_redis = json.loads(role_json)
assert role_data_redis["id"] == "custom_moderator"
assert role_data_redis["name"] == "Модератор"
assert role_data_redis["description"] == "Кастомная роль модератора"
assert role_data_redis["icon"] == "shield"
assert role_data_redis["permissions"] == []
@pytest.mark.asyncio
async def test_create_duplicate_role_redis(self, db_session):
"""Тест создания дублирующей роли через Redis"""
# Создаем тестовое сообщество
community = Community(
name="Test Community 2",
slug="test-community-2",
desc="Test community for duplicate roles",
created_by=1,
created_at=1234567890
)
db_session.add(community)
db_session.flush()
# Данные для создания роли
role_data = {
"id": "duplicate_role",
"name": "Дублирующая роль",
"description": "Тестовая роль",
"permissions": []
}
# Создаем роль первый раз
await redis.execute("HSET", f"community:custom_roles:{community.id}", "duplicate_role", json.dumps(role_data))
# Проверяем, что роль создана
role_json = await redis.execute("HGET", f"community:custom_roles:{community.id}", "duplicate_role")
assert role_json is not None
# Пытаемся создать роль с тем же ID - должно перезаписаться
await redis.execute("HSET", f"community:custom_roles:{community.id}", "duplicate_role", json.dumps(role_data))
# Проверяем, что роль все еще существует
role_json2 = await redis.execute("HGET", f"community:custom_roles:{community.id}", "duplicate_role")
assert role_json2 is not None
@pytest.mark.asyncio
async def test_delete_custom_role_redis(self, db_session):
"""Тест удаления кастомной роли через Redis"""
# Создаем тестовое сообщество
community = Community(
name="Test Community 3",
slug="test-community-3",
desc="Test community for role deletion",
created_by=1,
created_at=1234567890
)
db_session.add(community)
db_session.flush()
# Создаем роль
role_data = {
"id": "role_to_delete",
"name": "Роль для удаления",
"description": "Тестовая роль",
"permissions": []
}
# Сохраняем роль в Redis
await redis.execute("HSET", f"community:custom_roles:{community.id}", "role_to_delete", json.dumps(role_data))
# Проверяем, что роль создана
role_json = await redis.execute("HGET", f"community:custom_roles:{community.id}", "role_to_delete")
assert role_json is not None
# Удаляем роль из Redis
await redis.execute("HDEL", f"community:custom_roles:{community.id}", "role_to_delete")
# Проверяем, что роль удалена из Redis
role_json_after = await redis.execute("HGET", f"community:custom_roles:{community.id}", "role_to_delete")
assert role_json_after is None
@pytest.mark.asyncio
async def test_get_roles_with_custom_redis(self, db_session):
"""Тест получения ролей с кастомными через Redis"""
# Создаем тестовое сообщество
community = Community(
name="Test Community 4",
slug="test-community-4",
desc="Test community for role listing",
created_by=1,
created_at=1234567890
)
db_session.add(community)
db_session.flush()
# Создаем кастомную роль
role_data = {
"id": "test_custom_role",
"name": "Тестовая кастомная роль",
"description": "Описание тестовой роли",
"permissions": []
}
# Сохраняем роль в Redis
await redis.execute("HSET", f"community:custom_roles:{community.id}", "test_custom_role", json.dumps(role_data))
# Проверяем, что роль сохранена
role_json = await redis.execute("HGET", f"community:custom_roles:{community.id}", "test_custom_role")
assert role_json is not None
role_data_redis = json.loads(role_json)
assert role_data_redis["id"] == "test_custom_role"
assert role_data_redis["name"] == "Тестовая кастомная роль"
assert role_data_redis["description"] == "Описание тестовой роли"