Section | Description |
---|---|
Project Description | Overview of the project and its features |
Technologies Used | List of technologies utilized in the project |
Features | Functionalities provided by the system |
Setup & Installation | Steps to set up and run the project |
Testing | Instructions for running tests and linting |
Project Structure | Folder structure explanation |
Usage Presentation | Presentation of Service Work and API usage |
Contacts | Developer contact information |
This project is a Django-based web application that includes:
- π‘ Celery for background task processing.
- πΊ PostgreSQL with PostGIS for geospatial data.
- π₯ Redis as a message broker for Celery.
- β SMTP4Dev for local email testing.
- π³ Docker Compose for easy setup and deployment.
- π Flower for monitoring Celery tasks.
- β
CRUD operations for news with fields:
- Title
- Main image (auto-generates preview)
- Rich-text content (via Summernote)
- Publication date
- Author
- β Admin panel with rich-text editor for news editing
- β Automatic preview image generation (200px on the shortest side)
- β Scheduled Celery task to send daily emails about published news.
- β
Configurable email settings via Django Constance:
- Recipient list
- Email subject
- Email body
- Scheduled sending time
- β
Import places from an XLSX file, including:
- Name
- Geo-coordinates (PointField)
- Rating (0 to 25)
- β Admin panel integration with a map widget for coordinate selection
- β Scheduled Celery task to fetch weather data for all places.
- β Configurable task frequency from the admin panel (default: every hour).
- β Weather data provider: Open-Meteo API
- β
Stored weather data includes:
- Temperature (Β°C)
- Humidity (%)
- Atmospheric pressure (mmHg)
- Wind direction
- Wind speed (m/s)
- β Weather records are immutable once saved
- β Admin panel filter for places and date selection
- β Export weather data to XLSX format
- β Dockerized setup for easy deployment
- β Celery task monitoring with Flower
- β Mail monitoring with SMTP4Dev (only docker-compose run)
- β Testing with Pytest & Tox
Follow the steps below to set up and run the project locally.
Clone the repository to your local machine:
git clone https://github.com/arielen/test_CifraK.git
cd test_CifraK
Create a .env
file in the root directory by copying the example file:
cp .env.example .env
Then, update the .env
file according to your configuration.
You can run the project using one of the following methods:
If you have Docker installed, use Docker Compose to build and run all services (Django, Celery, Redis, PostgreSQL, and SMTP4Dev). All migrations will be executed automatically:
docker-compose up -d --build
-
Running the Django Application
Create a virtual environment, install dependencies, perform migrations, create a superuser, and run the development server:
python -m venv .venv source .venv/bin/activate # On Windows use: .venv\Scripts\activate pip install -r backend/requirements.txt python backend/manage.py makemigrations python backend/manage.py migrate python backend/manage.py createsuperuser python backend/manage.py runserver
-
Running Celery Worker & Beat
Navigate to the
backend
directory and start Celery with the worker and Beat:cd backend celery -A config worker -B -l info
-
(Optional) Running Celery Flower
To monitor Celery tasks, you can use Flower. Run the following command:
celery -A config flower --port=5555
Flower will be available at http://localhost:5555.
- Admin Interface: http://localhost:8000/admin
- API Schema: http://localhost:8000/api/schema/
- Swagger UI: http://localhost:8000/api/schema/swagger-ui/
- Redoc: http://localhost:8000/api/schema/redoc/
To run tests with tox
:
tox # run all tests, coverage and lint
or
tox -e coverage # run target only coverage
tox -e lint # run target only lint with ruff
Test coverage must be at least 95%. If the code is not 95% covered, the overall coverage will drop.
π backend
βββ π config # Django settings & Celery config
βββ π news # News app (models, views, tasks)
βββ π places # Places app (geospatial data, weather tasks)
βββ π templates # Custom admin templates
βββ π manage.py # Django entry point
βββ π requirements.txt # Dependencies
βββ π Dockerfile # Dockerfile for Django
βββ π __main__.py # Main script
βββ π create_admin.py # Superuser creation script
βββ π tests # Test cases
π .env.example # Example environment variables
π docker-compose.yml # Docker Compose setup
π pyproject.toml # Configuration for ruff & pytest
π tox.ini # Testing configuration
π README.md # Project documentation
The project uses smtp4dev
for testing email functionality. Access the UI at:
http://localhost:8025
Access Flower to monitor Celery tasks: http://localhost:5555
π» Developer: arielen
π§ Email: pavlov_zv@mail.ru
π§ TG: 1 0