A panel for django-debug-toolbar that allows for viewing of recently sent email.
Project description
Django Debug Toolbar - Mail Panel
Testing and debugging e-mail while developing a Django app has never been pleasant. Sending e-mail to a file-based backend requires a user to click through obtusely-named files and does not provide a way to preview rendered HTML. Sending e-mail to a valid mailbox incurs a delay as the message is processed though a mail server, and clutters a developer's inbox.
The mail panel attempts to address these problems by providing a way to preview emails within the browser using django-debug-toolbar.
This mail panel is released under the Apache license. If you like it, please consider contributing!
Special thanks to @ShawnMilo for the code review.
Installation
To install the mail panel, first install this package with pip install django-mail-panel
. Then add the mail_panel
app after debug_toolbar
to the INSTALLED_APPS
setting:
INSTALLED_APPS = (
...
'debug_toolbar',
'mail_panel',
)
and add the panel DEBUG_TOOLBAR_PANELS
:
DEBUG_TOOLBAR_PANELS = (
...
'mail_panel.panels.MailToolbarPanel',
)
Collect static and you'll be good to go.
./manage.py collectstatic
Configuration
After installation, you now need to redirect mail to the mail toolbar. Change your email backend to the following:
EMAIL_BACKEND = 'mail_panel.backend.MailToolbarBackend'
Important: This plugin uses Django's cache backend to store messages. If you are using DummyCache
, the mail panel will use a local memory cache, and will reset messages when the server is restarted.
[Optional] By default, mail toolbar stores messages for one day before removing them from cache. You can change this with the following setting:
MAIL_TOOLBAR_TTL = 86400 # 1 Day
[Optional]
If you use the DEBUG_TOOLBAR_PANELS
to custom order your panels:
DEBUG_TOOLBAR_PANELS = [
"debug_toolbar.panels.history.HistoryPanel",
"debug_toolbar.panels.versions.VersionsPanel",
"debug_toolbar.panels.timer.TimerPanel",
"debug_toolbar.panels.settings.SettingsPanel",
"debug_toolbar.panels.headers.HeadersPanel",
"debug_toolbar.panels.request.RequestPanel",
"debug_toolbar.panels.sql.SQLPanel",
"debug_toolbar.panels.staticfiles.StaticFilesPanel",
"debug_toolbar.panels.templates.TemplatesPanel",
"debug_toolbar.panels.cache.CachePanel",
"debug_toolbar.panels.signals.SignalsPanel",
"debug_toolbar.panels.logging.LoggingPanel",
"debug_toolbar.panels.redirects.RedirectsPanel",
"debug_toolbar.panels.profiling.ProfilingPanel",
"mail_panel.panels.MailToolbarPanel", # reposition to desired location
]
Testing
To preview emails sent from your test suite, add the email backend override to your tests with the following:
from django.test.utils import override_settings
@override_settings(EMAIL_BACKEND='mail_panel.backend.MailToolbarBackend')
def test_send_email(self):
# your code here
The backend works similarly to the standard email backend and code should not need to be reworked when using the MailToolbarBackend.
from django.core import mail
original_outbox = len(mail.outbox)
# Send mail ...
assert(len(mail.outbox) == original_outbox + 1)
Shameless Plugs
Like Django Mail Panel? Be sure to check out and support these other tools for Mac that will improve your workflow:
Kubermagic - Automate, and script away tedious kubectl commands with Kubermagic; a UI for developers, QA teams, and those starting to learn the ins-and-outs of Kubernetes.
Red - A visual and interactive Redis client, featuring live updating keys, an interactive console, pub/sub, lua script support and much more.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django_mail_panel-4.0.4.tar.gz
.
File metadata
- Download URL: django_mail_panel-4.0.4.tar.gz
- Upload date:
- Size: 16.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.7 Darwin/22.4.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 032c75a9588efe051a758404f2a68cf29b620e024d44cf40acd4a9b6639206fc |
|
MD5 | f2ba9982b9e6d651bfb79572819f7d91 |
|
BLAKE2b-256 | dba27d33feae8e1ed1470c0c944a2974fd4d1a48503ec9d944e997d92a9096af |
File details
Details for the file django_mail_panel-4.0.4-py3-none-any.whl
.
File metadata
- Download URL: django_mail_panel-4.0.4-py3-none-any.whl
- Upload date:
- Size: 17.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.7 Darwin/22.4.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 440fe6c60bedc9bc4c4a2d9931ac9582d81f5d4c7e976eca7a48e8fc2d758a12 |
|
MD5 | d74a719649db72cc93e0eba9f971084d |
|
BLAKE2b-256 | 2bac5ad026422748ec916a269111d7e7cdf9ab36c34711faacaf71ad13d569e0 |