Skip to main content

Class-based emails including a test suite for Django

Project description

PyPI release Downloads Coverage Linting Coding Style Documentation Status

Welcome to the django-pony-express - class-based emails for Django shipping with a full test suite.

Similar to class-based view in Django core, this package provides a neat, DRY and testable (!) way to handle your emails in Django.

PyPI | GitHub | Full documentation

Creator & Maintainer: Ambient Digital

Features

  • Class-based structure for emails
    • Avoid duplicate low-level setup
    • Utilise inheritance and OOP benefits
    • No duplicated templates for HTML and plain-text
  • Test suite to write proper unit-tests for your emails
    • Access your test outbox like a Django queryset

Etymology

The Pony Express was an American express mail service that used relays of horse-mounted riders. [...] During its 18 months of operation, the Pony Express reduced the time for messages to travel between the east and west US coast to about 10 days.

https://en.wikipedia.org/wiki/Pony_Express

The name of this package combines the Django mascot (a pony) with a once quite successful mail service in the US. Ingenious, right?

Installation

  • Install the package via pip:

    pip install django-pony-express

    or via uv:

    uv add django-pony-express

  • Add module to INSTALLED_APPS within the main django settings.py:

INSTALLED_APPS = (
    # ...
    "django_pony_express",
)

Publish to ReadTheDocs.io

  • Fetch the latest changes in GitHub mirror and push them
  • Trigger new build at ReadTheDocs.io (follow instructions in admin panel at RTD) if the GitHub webhook is not yet set up.

Preparation and building

This package uses uv for dependency management and building.

  • Update documentation about new/changed functionality

  • Update the CHANGES.md

  • Increment version in main __init__.py

  • Create pull request / merge to "master"

  • This project uses uv to publish to PyPI. This will create distribution files in the dist/ directory.

    uv build
    

Publishing to PyPI

To publish to the production PyPI:

uv publish

To publish to TestPyPI first (recommended for testing):

uv publish --publish-url https://test.pypi.org/legacy/

You can then test the installation from TestPyPI:

uv pip install --index-url https://test.pypi.org/simple/ ambient-package-update

Maintenance

Please note that this package supports the ambient-package-update. So you don't have to worry about the maintenance of this package. This updater is rendering all important configuration and setup files. It works similar to well-known updaters like pyupgrade or django-upgrade.

To run an update, refer to the documentation page of the "ambient-package-update".

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

django_pony_express-2.7.5.tar.gz (90.9 kB view details)

Uploaded Source

Built Distribution

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

django_pony_express-2.7.5-py3-none-any.whl (14.9 kB view details)

Uploaded Python 3

File details

Details for the file django_pony_express-2.7.5.tar.gz.

File metadata

  • Download URL: django_pony_express-2.7.5.tar.gz
  • Upload date:
  • Size: 90.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.1

File hashes

Hashes for django_pony_express-2.7.5.tar.gz
Algorithm Hash digest
SHA256 c1d6a28ea26a62652a1b38c1ada4298433451105a0b08045b6667fe2256bca7b
MD5 ef37df89cef1d7a78cd9f1a494eecb5b
BLAKE2b-256 77d55bd1ca46c486e99a778804116ae7e0775a14a1329095b580f2a03b397a52

See more details on using hashes here.

File details

Details for the file django_pony_express-2.7.5-py3-none-any.whl.

File metadata

File hashes

Hashes for django_pony_express-2.7.5-py3-none-any.whl
Algorithm Hash digest
SHA256 204970bfb9631250d336cbdf8b0f6e27bfd1835a581c2646d8ab53506ac5e4ba
MD5 af9b7ddd7962ff379bb93afbc8b86475
BLAKE2b-256 e83c4c145a4d4536345c3a12f54e308a78f84f3874c9d732e067d63f42622d73

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