A Django email backend for hijacking email sending in a test environment.
Clone or download
vkurup Merge pull request #27 from 153957/patch-1
It is required to add bandit to INSTALLED_APPS
Latest commit edee00a Jan 26, 2018



Build Status

master:Build Status
develop:Build Status

A Django email backend for hijacking email sending in a staging/test environment. It extends the default SMTP backend to intercept outgoing emails and instead send them to a single email address that you specify. It does not intercept emails going to the site admins (as defined by the ADMINS setting) so it will not interfere with 500 error emails.

You can also configure the hijacked emails to be logged through standard Python logging. Mixin classes are provided to use the same hijack logic for any existing email backend such as django-ses.


  • Python 2.7 or 3.5+
  • Django >= 1.8 (supported versions)


To install django-email-bandit via pip:

pip install django-email-bandit

Add django-email-bandit to your installed apps:


For your test environment you should enable the backend:

EMAIL_BACKEND = 'bandit.backends.smtp.HijackSMTPBackend'

and set the email which will receive all of the emails:

BANDIT_EMAIL = 'bandit@example.com'

or even multiple addresses:

BANDIT_EMAIL = ['bandit@example.com', 'accomplice@example.com']

It's also possible to whitelist certain email addresses and domains:

    'iloveemail@example.com',  # Just this specific email address
    'example.net'   # All email addresses @example.net


Full project documentation is on Read the Docs.

Questions or Issues?

If you have questions, issues or requests for improvements please let us know on Github.

Development sponsored by Caktus Consulting Group, LLC.