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.6.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.6-py3-none-any.whl (14.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django_pony_express-2.7.6.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.6.tar.gz
Algorithm Hash digest
SHA256 982ae845ced9fe2f810f87edb4caa0cfe0a13a86b604190c8bb64c6cb39ac00e
MD5 30928c34c3782328f5abbe1c895265de
BLAKE2b-256 0ac8f6254a300b9f135f2be1232fa745a15ba93b07d951f543830b17bc399df2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_pony_express-2.7.6-py3-none-any.whl
Algorithm Hash digest
SHA256 af14dacd9c81c9e36ceb388b52c1740bbe009f21244f999a11a26c07cd80ad28
MD5 e252211869387e66eab6585120730894
BLAKE2b-256 6bbcd634fd7a47d6fecc6dbc4cd18c0f8a856db9c85ced9e868a9505aa2b9db7

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