Skip to main content

Runtime type checking decorators with sync and async support.

Project description

typesentinel

typesentinel

typesentinel is a lightweight, dependency-free library for runtime type checking of Python function arguments. It supports both synchronous and asynchronous functions, Union types, custom failure handlers, and signature-aware error messages.

pip install typesentinel

🧠 Why typesentinel?

Other libraries like Pydantic, Beartype, Enforce, or typeguard offer runtime validation, but often come with heavy dependencies, global monkey-patching, performance costs, or complicated configuration.

typesentinel focuses on one thing and does it well:

  • Minimal — zero dependencies, tiny footprint
  • Explicit — works only where you decorate; never global
  • Async-friendly — supports async functions & async failure handlers
  • Precise errors — error messages include the real parameter names
  • Flexible — annotations, shorthand, or explicit TypeCheck objects
  • Safe — never mutates your function’s signature or typing info

If you want simple, predictable runtime validation with no overhead, typesentinel is built for you.


🚀 Quick Start

Type checking from function annotations

from typesentinel.decorator import type_check

@type_check
def greet(name: str, excited: bool = False):
    return f"Hello, {name}{'!' if excited else ''}"

greet("Alice")       # OK
greet(123)           # ❌ Invalid type for argument 'name': expected str, got int

Shorthand keyword type checks

@type_check(name=str, times=int)
async def repeat(name, times):
    return ", ".join(name for _ in range(times))

🔍 Union Type Support

from typing import Union

@type_check(a=Union[int, str])
def fn(a):
    return a

@type_check(a=int | str)
def fn(a):
    return a

Error message:

Invalid type for argument 'a': expected int | str, got float

🛠 Custom Failure Handling

from typesentinel.decorator import type_check
from typesentinel.type_check import TypeCheckResult

async def capture(*fails: TypeCheckResult):
    raise ValueError("validation failed")

@type_check(a=int, on_failure=capture)
async def double(a):
    return a * 2

🧩 Explicit TypeCheck Objects

from typesentinel.decorator import type_check
from typesentinel.type_check import TypeCheck, ArgKind

checks = [
    TypeCheck(0, int, ArgKind.POSITIONAL),
    TypeCheck("label", str, ArgKind.KEYWORD, message="label must be a string"),
]

@type_check(checks)
def render(value, *, label):
    return f"{label}: {value}"

🧪 Testing

python -m pytest

📄 License

MIT License. See LICENSE for details.


---

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

typesentinel-0.2.2.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

typesentinel-0.2.2-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file typesentinel-0.2.2.tar.gz.

File metadata

  • Download URL: typesentinel-0.2.2.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for typesentinel-0.2.2.tar.gz
Algorithm Hash digest
SHA256 93c578569a23a3eb1bd78d25bf344fe4841e555ab78c95856eda25ed81684f76
MD5 457c85b1245099c1bb99860d19eff218
BLAKE2b-256 821536e5f0ae49a4169f9e0d893467d177188818177619c7754770a709a5033b

See more details on using hashes here.

File details

Details for the file typesentinel-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: typesentinel-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for typesentinel-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6e20651215ab7072b9d39334495a199243d4d51d00e0475dfacca5cdb00ceed6
MD5 03636c520e6978bcafb7e85b6037ddc4
BLAKE2b-256 4f5ca06078b4d6f9b84ed8fe756470ea37d5f64c2def5d4919f1c4bacc805631

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page