|
|
2 weeks ago | |
|---|---|---|
| .. | ||
| app | 2 weeks ago | |
| .dockerignore | 2 weeks ago | |
| .env.example | 2 weeks ago | |
| Dockerfile | 2 weeks ago | |
| README.md | 2 weeks ago | |
| requirements.txt | 2 weeks ago | |
| run.py | 2 weeks ago | |
README.md
Flask-контур тестирования (тот же стек, отдельный деплой)
Здесь — новое приложение на Python / Flask в духе HR_TG_Bot/tgFlaskForm (шаблоны + серверный рендер, без React). Старый стек (backend/ + frontend/) пока не удаляется: оба контура могут существовать параллельно, пока не зафиксирована политика «один источник записи» и cutover.
Запуск в Docker (рекомендуется)
Из корня репозитория TestingWebApp. Сервис не зависит от testing-backend и не требует внешней сети Postgres для старта (только внутренняя сеть compose).
docker compose -f docker-compose.dev.yml up -d --build testing-flask
Когда подключите БД из контейнера к hr_postgres_dev / clinic_tests, в docker-compose.dev.yml у сервиса testing-flask добавьте сеть postgres (как у testing-backend).
- URL: http://localhost:3108
- Проверка: http://localhost:3108/health
Вместе со старым UI и API:
docker compose -f docker-compose.dev.yml up -d --build
Тогда Node-интерфейс остаётся на http://localhost:3107, Flask — на 3108.
Запуск локально (без Docker)
cd flask_app
python3 -m venv .venv
source .venv/bin/activate # Windows: .venv\Scripts\activate
pip install -r requirements.txt
cp .env.example .env # при необходимости поправьте PORT
python run.py
По умолчанию: http://127.0.0.1:3108 , проверка: http://127.0.0.1:3108/health
Для режима как в Docker (waitress): в .env задайте WEB_USE_WAITRESS=1.
Зачем отдельная папка
- Один стек с кабинетом / мини-приложением — проще переносить экраны и запросы из
HR_TG_Bot/tgFlaskForm/webApp/interfaces/testing/. - Отдельный процесс и порт — без риска сломать текущий
docker-compose.dev.ymlс Node до готовности.
Дальнейшие шаги (код)
Этот каталог — место разработки Этапа 1 (migration-final.md).
- Подключить БД
clinic_tests(схема не меняется), psycopg2-пул в стилеtgFlaskForm/db/. - Перенести 22 эндпоинта Express из
backend/в blueprint'ы Flask, ориентируясь на чек-лист в migration-final-inventory.md. - Перенести экраны React (
frontend/src/pages/*) в Jinja-шаблоныapp/templates/, повторяя мобильный UX Спринта 3. - Когда паритет закрыт —
docker-compose.dev.ymlуказывает на этот сервис как основной,backend/иfrontend/уходят.
ETL clinic_tests → hr_bot_test и слияние с tgFlaskForm — это Этап 2, на будущее (migration-to-tgflaskform.md).
Связанные документы
- docs/migration-final.md — главный трекер двух этапов.
- docs/migration-final-inventory.md — карта Express-функционала, чек-лист Этапа 1.
- docs/migration-to-tgflaskform.md — план Этапа 2.
- README корня репозитория