Skip to content

Quality Report

Protean is built with a strong emphasis on code quality, test coverage, and long-term maintainability. This page documents the engineering practices and metrics behind the framework.


At a Glance

Metric Value
Tests 3,826
Test-to-Code Ratio 3.5:1
Linting Violations 0 (Ruff)
Avg Cyclomatic Complexity 2.97 (A grade)
Maintainability Index A rank (97% of files)
Python Versions 3.11, 3.12, 3.13, 3.14
CI Backing Services PostgreSQL, Redis, Elasticsearch, MessageDB, MSSQL
Releases 46
Project Age Since July 2018
License BSD 3-Clause

Test Suite

Protean has a comprehensive test suite of 3,826 tests covering domain logic, application services, infrastructure adapters, and integration scenarios.

Test Breakdown

Metric Count
Total Tests 3,826
Test Functions 3,736
Test Classes 646
Pytest Fixtures 377
Parametrized Tests 41

Core vs. Integration

Category Tests Share
Core tests (in-memory, no infrastructure) 2,723 71%
Adapter/integration tests ~1,103 29%

Core tests run entirely in-memory with no external dependencies, making them fast and reliable for local development. Integration tests exercise real databases and message brokers.

Infrastructure Coverage

Every commit is tested against real backing services:

Technology Marked Tests
Redis 123
Database (generic) 56
Event Store 48
PostgreSQL 26
Elasticsearch 19
SQLite 14

Branch coverage is enabled, and results are reported to Codecov on every CI run.


Code Quality

Linting

Protean uses Ruff for both linting and formatting. The codebase has zero linting violations. Pre-commit hooks enforce this on every commit:

  • ruff check --fix (linting with auto-fix)
  • ruff format (consistent formatting)

Cyclomatic Complexity

Measured with Radon:

Metric Value
Average complexity 2.97
Blocks at A grade (1-5, simple) 1,089 (78%)
Total blocks analyzed 1,399

An average complexity under 5 indicates straightforward, easy-to-follow code paths throughout the framework.

Maintainability Index

Rank Files Share
A (very maintainable, 20-100) 94 97%
B (moderate, 10-19) 3 3%
C (low, 0-9) 0 0%

Average Maintainability Index: 66.73 (on a scale of 0-100).

97% of source files score in the highest maintainability tier.


Codebase Structure

Size

Area Python Files Lines of Code Documentation Lines
Source (src/protean/) 97 12,894 6,604
Tests (tests/) 572 45,613 7,611
Total 669 58,507 14,215

Architecture

Protean's source is organized into 10 top-level packages:

Package Purpose
core/ Domain elements (aggregates, entities, value objects, commands, events, handlers, services, repositories)
adapters/ Infrastructure implementations (database, broker, event store, cache)
port/ Port interfaces that adapters implement
fields/ Field system for domain element attributes
domain/ Domain class and element registration
server/ Async message processing engine
cli/ Command-line tools
ext/ Extensions (e.g., mypy plugin)
utils/ Shared utilities (outbox, eventing, mixins)
template/ Project scaffolding templates

Domain Elements and Adapters

Category Count
Domain element types 18 (Aggregate, Entity, Value Object, Command, Event, Domain Service, Command Handler, Event Handler, Application Service, Subscriber, Projection, Projector, Repository, Database Model, and more)
Port interfaces 5 (Provider, Broker, Event Store, Cache, DAO)
Adapter implementations 12 (Memory, SQLAlchemy, Elasticsearch, Redis Stream, Redis PubSub, Inline, MessageDB, SendGrid, and more)

CI/CD Pipeline

Test Matrix

Every pull request and push to main triggers the full CI pipeline:

  • 4 Python versions: 3.11, 3.12, 3.13, 3.14
  • 5 backing services (started as Docker containers):
    • PostgreSQL 11
    • Redis
    • Elasticsearch 7.12
    • MessageDB 1.2.6
    • MSSQL Server 2022

This means every change is validated against 4 Python versions with all infrastructure adapters exercised.

Pipeline Steps

  1. Start all 5 backing service containers
  2. Install dependencies via Poetry
  3. Run the full test suite (protean test -c FULL)
  4. Upload coverage to Codecov
  5. Deploy documentation (on merge to main)

Documentation

Documentation is built with MkDocs Material and automatically deployed to docs.proteanhq.com on every merge to main.


Dependencies

Protean maintains a lean dependency footprint:

Category Count
Required runtime dependencies 14
Optional extras (adapters) 8 groups
Dev dependencies 7
Test dependencies 8

All database and message broker drivers are optional extras -- the core framework installs only what's needed for in-memory development. Infrastructure dependencies are added when you're ready to deploy:

pip install protean[postgresql]   # Adds SQLAlchemy + psycopg2
pip install protean[redis]        # Adds redis-py
pip install protean[elasticsearch] # Adds elasticsearch + elasticsearch-dsl

Project History

Metric Value
First commit July 15, 2018
Total commits 1,404
Commits since Jan 2024 432
Contributors 12
Published releases 46
Current version 0.14.2
Latest releases v0.14.0, v0.14.1, v0.14.2

Tools and Practices

Practice Tool
Linting & formatting Ruff (pre-commit + CI)
Type checking mypy (with custom Protean plugin)
Test framework pytest (with pytest-asyncio)
Coverage coverage.py + Codecov
Complexity analysis Radon
Dependency management Poetry
Multi-version testing Nox
CI/CD GitHub Actions
Documentation MkDocs Material

Last updated: February 2026