- Created package.json with Vitest and Playwright dependencies - Configured vitest.config.js with happy-dom environment - Configured playwright.config.js with Chromium browser - Created test directory structure (tests/frontend/unit and e2e) - Added setup.test.js with 10 Vitest validation tests - Added setup.spec.js with 6 Playwright E2E validation tests - Created FRONTEND_SETUP.md with Node.js installation guide - Updated instructions.md marking task complete Note: Requires Node.js installation before running tests
Aniworld Download Manager
A web-based anime download manager with REST API, WebSocket real-time updates, and a modern web interface.
Features
- Web interface for managing anime library
- REST API for programmatic access
- WebSocket real-time progress updates
- Download queue with priority management
- Automatic library scanning for missing episodes
- NFO metadata management with TMDB integration
- Automatic poster/fanart/logo downloads
- JWT-based authentication
- SQLite database for persistence
Quick Start
Prerequisites
- Python 3.10+
- Conda (recommended) or virtualenv
Installation
- Clone the repository:
git clone https://github.com/your-repo/aniworld.git
cd aniworld
- Create and activate conda environment:
conda create -n AniWorld python=3.10
conda activate AniWorld
- Install dependencies:
pip install -r requirements.txt
- Start the server:
python -m uvicorn src.server.fastapi_app:app --host 127.0.0.1 --port 8000
- Open http://127.0.0.1:8000 in your browser
First-Time Setup
- Navigate to http://127.0.0.1:8000/setup
- Set a master password (minimum 8 characters, mixed case, number, special character)
- Configure your anime directory path
- (Optional) Configure NFO settings with your TMDB API key
- Login with your master password
NFO Metadata Setup (Optional)
For automatic NFO file generation with metadata and images:
- Get a free TMDB API key from https://www.themoviedb.org/settings/api
- Go to Configuration → NFO Settings in the web interface
- Enter your TMDB API key and click "Test Connection"
- Enable auto-creation and select which images to download
- NFO files will be created automatically during downloads
Documentation
| Document | Description |
|---|---|
| docs/API.md | REST API and WebSocket reference |
| docs/ARCHITECTURE.md | System architecture and design |
| docs/CONFIGURATION.md | Configuration options |
| docs/DATABASE.md | Database schema |
| docs/DEVELOPMENT.md | Developer setup guide |
| docs/TESTING.md | Testing guidelines |
Project Structure
src/
+-- cli/ # CLI interface (legacy)
+-- config/ # Application settings
+-- core/ # Domain logic
| +-- SeriesApp.py # Main application facade
| +-- SerieScanner.py # Directory scanning
| +-- entities/ # Domain entities
| +-- providers/ # External provider adapters
+-- server/ # FastAPI web server
+-- api/ # REST API endpoints
+-- services/ # Business logic
+-- models/ # Pydantic models
+-- database/ # SQLAlchemy ORM
+-- middleware/ # Auth, rate limiting
API Endpoints
| Endpoint | Description |
|---|---|
POST /api/auth/login |
Authenticate and get JWT token |
GET /api/anime |
List anime with missing episodes |
GET /api/anime/search?query= |
Search for anime |
POST /api/queue/add |
Add episodes to download queue |
POST /api/queue/start |
Start queue processing |
GET /api/queue/status |
Get queue status |
GET /api/nfo/check |
Check NFO status for anime |
POST /api/nfo/create |
Create NFO files |
WS /ws/connect |
WebSocket for real-time updates |
See docs/API.md for complete API reference.
Configuration
Environment variables (via .env file):
| Variable | Default | Description |
|---|---|---|
JWT_SECRET_KEY |
(random) | Secret for JWT signing |
DATABASE_URL |
sqlite:///./data/aniworld.db |
Database connection |
ANIME_DIRECTORY |
(empty) | Path to anime library |
TMDB_API_KEY |
(empty) | TMDB API key for metadata |
LOG_LEVEL |
INFO |
Logging level |
See docs/CONFIGURATION.md for all options.
Running Tests
The project includes a comprehensive test suite with 535 tests and 91.24% average coverage:
# Run all tests
conda run -n AniWorld python -m pytest tests/ -v
# Run unit tests only
conda run -n AniWorld python -m pytest tests/unit/ -v
# Run integration tests
conda run -n AniWorld python -m pytest tests/integration/ -v
# Run with coverage report
conda run -n AniWorld python -m pytest tests/ --cov --cov-report=html
Test Coverage:
- ✅ 535 tests across 11 test suites (532 passed, 3 skipped)
- ✅ 91.24% average code coverage
- ✅ Unit tests: Security Middleware, Notifications, Database, NFO, Cache, Error Tracking, Settings
- ✅ Integration tests: End-to-end workflows, API endpoints, Download flows
See TESTING_SUMMARY.md for detailed testing documentation.
Technology Stack
- Web Framework: FastAPI 0.104.1
- Database: SQLite + SQLAlchemy 2.0
- Auth: JWT (python-jose) + passlib
- Validation: Pydantic 2.5
- Logging: structlog
- Testing: pytest + pytest-asyncio
Application Lifecycle
Initialization
On first startup, the application performs a one-time sync of series from data files to the database:
- FastAPI lifespan starts
- Database is initialized
sync_series_from_data_files()reads all data files from the anime directory (creates temporary SeriesApp)- Series metadata is synced to the database
- DownloadService initializes (triggers main
SeriesAppcreation) SeriesApploads series from database via service layer (not from files)
On subsequent startups, the same flow applies but the sync finds no new series. SeriesApp always initializes with an empty series list (skip_load=True) and loads data from the database on demand, avoiding redundant file system scans.
Adding New Series
When adding a new series:
- Series is added to the database via
AnimeService - Data file is created in the anime directory
- In-memory
SerieListis updated viaload_series_from_list()
License
MIT License