108 lines
6.1 KiB
Markdown
108 lines
6.1 KiB
Markdown
|
# Отчет о прогрессе - 19 декабря 2024 (E2E тест с браузером)
|
|||
|
|
|||
|
## Задача: Исправление E2E теста удаления сообщества с браузером
|
|||
|
|
|||
|
### 🔄 ТЕКУЩИЙ СТАТУС: В РАБОТЕ
|
|||
|
|
|||
|
E2E тест `test_community_delete_e2e_browser.py` запускается и работает частично, но **основная цель не достигнута**.
|
|||
|
|
|||
|
### ✅ ЧТО РАБОТАЕТ:
|
|||
|
|
|||
|
#### 1. **Серверы запускаются корректно**
|
|||
|
- ✅ Бэкенд сервер (порт 8000) запускается через `python3 dev.py`
|
|||
|
- ✅ Фронтенд сервер (порт 3000) запускается через `npm run dev`
|
|||
|
- ✅ Оба сервера отвечают на запросы
|
|||
|
|
|||
|
#### 2. **Исправлены проблемы с импортами**
|
|||
|
- ✅ Исправлен циклический импорт `CommunityAuthor` в `auth/internal.py`
|
|||
|
- ✅ Исправлен импорт в `resolvers/community.py`
|
|||
|
- ✅ Сервер запускается без ошибок импорта
|
|||
|
|
|||
|
#### 3. **Исправлена передача author_id в контекст**
|
|||
|
- ✅ Добавлен `author_id` в контекст GraphQL в `auth/handler.py`
|
|||
|
- ✅ RBAC система теперь может получить `author_id` для проверки прав
|
|||
|
- ✅ Исправлена ошибка "author_id не найден ни в context.author, ни в scope.auth"
|
|||
|
|
|||
|
#### 4. **Добавлены права доступа**
|
|||
|
- ✅ Пользователь `welcome@discours.io` получил права администратора в сообществе "Test Community"
|
|||
|
- ✅ Создана запись `CommunityAuthor` с ролями `admin,editor,author`
|
|||
|
|
|||
|
#### 5. **E2E тест работает частично**
|
|||
|
- ✅ Браузер запускается корректно
|
|||
|
- ✅ Авторизация в админ-панели работает
|
|||
|
- ✅ Навигация на страницу сообществ работает
|
|||
|
- ✅ Таблица сообществ загружается (57 строк)
|
|||
|
- ✅ Сообщество "Test Community" находится в таблице
|
|||
|
- ✅ Кнопка удаления находится и нажимается
|
|||
|
- ✅ Модальное окно подтверждения открывается
|
|||
|
- ✅ Кнопка подтверждения находится и нажимается
|
|||
|
|
|||
|
### ❌ ПРОБЛЕМЫ:
|
|||
|
|
|||
|
#### 1. **Основная проблема: Сообщество не удаляется**
|
|||
|
- ❌ После нажатия кнопки подтверждения сообщество остается в таблице
|
|||
|
- ❌ GraphQL мутация `delete_community` не выполняется или не удаляет сообщество
|
|||
|
- ❌ Сообщество остается в базе данных
|
|||
|
|
|||
|
#### 2. **Проблема с авторизацией**
|
|||
|
- ❌ Логин через GraphQL возвращает `success: False`
|
|||
|
- ❌ Токен не генерируется при авторизации
|
|||
|
- ❌ Это может блокировать выполнение мутации удаления
|
|||
|
|
|||
|
### 🔍 Диагностика:
|
|||
|
|
|||
|
#### Проверка GraphQL API:
|
|||
|
```bash
|
|||
|
# GraphQL запрос работает
|
|||
|
curl -X POST http://localhost:8000/graphql \
|
|||
|
-H "Content-Type: application/json" \
|
|||
|
-d '{"query": "query { get_communities_all { id name slug } }"}'
|
|||
|
# ✅ Возвращает 57 сообществ
|
|||
|
```
|
|||
|
|
|||
|
#### Проверка авторизации:
|
|||
|
```bash
|
|||
|
# Авторизация не работает
|
|||
|
curl -X POST http://localhost:8000/graphql \
|
|||
|
-H "Content-Type: application/json" \
|
|||
|
-d '{"query": "mutation Login($email: String!, $password: String!) { login(email: $email, password: $password) { token success } }", "variables": {"email": "welcome@discours.io", "password": "password123"}}'
|
|||
|
# ❌ Возвращает {"data": {"login": {"token": null, "success": false}}}
|
|||
|
```
|
|||
|
|
|||
|
### 📋 Следующие шаги:
|
|||
|
|
|||
|
1. **Исправить авторизацию**:
|
|||
|
- Разобраться почему логин возвращает `success: False`
|
|||
|
- Проверить хеширование паролей
|
|||
|
- Возможно создать нового пользователя для тестирования
|
|||
|
|
|||
|
2. **Проверить логи сервера**:
|
|||
|
- Запустить сервер в режиме отладки
|
|||
|
- Посмотреть что происходит при выполнении мутации `delete_community`
|
|||
|
|
|||
|
3. **Тестировать удаление напрямую**:
|
|||
|
- Использовать валидный токен для тестирования GraphQL мутации
|
|||
|
- Проверить что сообщество действительно удаляется из БД
|
|||
|
|
|||
|
4. **Исправить E2E тест**:
|
|||
|
- Убедиться что авторизация работает в браузере
|
|||
|
- Проверить что GraphQL запросы проходят через прокси
|
|||
|
|
|||
|
### 📁 Измененные файлы:
|
|||
|
|
|||
|
1. **`auth/handler.py`** - добавлен `author_id` в контекст GraphQL
|
|||
|
2. **`auth/internal.py`** - исправлен циклический импорт `CommunityAuthor`
|
|||
|
3. **`resolvers/community.py`** - исправлен импорт `CommunityAuthor`
|
|||
|
4. **`test_delete.py`** - создан файл для тестирования удаления через GraphQL
|
|||
|
|
|||
|
### 🚀 Статус: 🔄 В РАБОТЕ
|
|||
|
|
|||
|
**E2E тест запускается и работает частично, но основная цель (удаление сообщества) не достигнута.**
|
|||
|
|
|||
|
Ключевые проблемы:
|
|||
|
- ❌ Авторизация не работает (`success: False`)
|
|||
|
- ❌ Сообщество не удаляется из таблицы после подтверждения
|
|||
|
- ❌ GraphQL мутация `delete_community` не выполняется корректно
|
|||
|
|
|||
|
Нужно исправить авторизацию и проверить логи сервера для диагностики проблемы с удалением.
|