Fixed #22407 -- Added AdminEmailHandler.send_mail().
This commit is contained in:
parent
a305695f28
commit
d552da1f8d
|
@ -127,9 +127,10 @@ class AdminEmailHandler(logging.Handler):
|
||||||
message = "%s\n\nRequest repr(): %s" % (self.format(record), request_repr)
|
message = "%s\n\nRequest repr(): %s" % (self.format(record), request_repr)
|
||||||
reporter = ExceptionReporter(request, is_email=True, *exc_info)
|
reporter = ExceptionReporter(request, is_email=True, *exc_info)
|
||||||
html_message = reporter.get_traceback_html() if self.include_html else None
|
html_message = reporter.get_traceback_html() if self.include_html else None
|
||||||
mail.mail_admins(subject, message, fail_silently=True,
|
self.send_mail(subject, message, fail_silently=True, html_message=html_message)
|
||||||
html_message=html_message,
|
|
||||||
connection=self.connection())
|
def send_mail(self, subject, message, *args, **kwargs):
|
||||||
|
mail.mail_admins(subject, message, *args, connection=self.connection(), **kwargs)
|
||||||
|
|
||||||
def connection(self):
|
def connection(self):
|
||||||
return get_connection(backend=self.email_backend, fail_silently=True)
|
return get_connection(backend=self.email_backend, fail_silently=True)
|
||||||
|
|
|
@ -271,6 +271,13 @@ Internationalization
|
||||||
reusable apps. It also allows overriding those custom formats in your main
|
reusable apps. It also allows overriding those custom formats in your main
|
||||||
Django project.
|
Django project.
|
||||||
|
|
||||||
|
Logging
|
||||||
|
^^^^^^^
|
||||||
|
|
||||||
|
* The :class:`django.utils.log.AdminEmailHandler` class now has a
|
||||||
|
:meth:`~django.utils.log.AdminEmailHandler.send_mail` method to make it more
|
||||||
|
subclass friendly.
|
||||||
|
|
||||||
Management Commands
|
Management Commands
|
||||||
^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
|
|
@ -563,8 +563,15 @@ Python logging module.
|
||||||
By default, an instance of the email backend specified in
|
By default, an instance of the email backend specified in
|
||||||
:setting:`EMAIL_BACKEND` will be used.
|
:setting:`EMAIL_BACKEND` will be used.
|
||||||
|
|
||||||
.. _Sentry: https://pypi.python.org/pypi/sentry
|
.. method:: send_mail(subject, message, *args, **kwargs)
|
||||||
|
|
||||||
|
.. versionadded:: 1.8
|
||||||
|
|
||||||
|
Sends emails to admin users. To customize this behavior, you can
|
||||||
|
subclass the :class:`~django.utils.log.AdminEmailHandler` class and
|
||||||
|
override this method.
|
||||||
|
|
||||||
|
.. _Sentry: https://pypi.python.org/pypi/sentry
|
||||||
|
|
||||||
Filters
|
Filters
|
||||||
-------
|
-------
|
||||||
|
|
|
@ -10,8 +10,9 @@ from django.test import TestCase, RequestFactory, override_settings
|
||||||
from django.test.utils import patch_logger
|
from django.test.utils import patch_logger
|
||||||
from django.utils.encoding import force_text
|
from django.utils.encoding import force_text
|
||||||
from django.utils.deprecation import RemovedInNextVersionWarning
|
from django.utils.deprecation import RemovedInNextVersionWarning
|
||||||
from django.utils.log import (CallbackFilter, RequireDebugFalse,
|
from django.utils.log import (
|
||||||
RequireDebugTrue)
|
AdminEmailHandler, CallbackFilter, RequireDebugFalse, RequireDebugTrue,
|
||||||
|
)
|
||||||
from django.utils.six import StringIO
|
from django.utils.six import StringIO
|
||||||
|
|
||||||
from admin_scripts.tests import AdminScriptTestCase
|
from admin_scripts.tests import AdminScriptTestCase
|
||||||
|
@ -341,6 +342,22 @@ class AdminEmailHandlerTest(TestCase):
|
||||||
self.assertEqual(msg.subject, "[Django] ERROR (EXTERNAL IP): message")
|
self.assertEqual(msg.subject, "[Django] ERROR (EXTERNAL IP): message")
|
||||||
self.assertIn("path:%s" % url_path, msg.body)
|
self.assertIn("path:%s" % url_path, msg.body)
|
||||||
|
|
||||||
|
@override_settings(
|
||||||
|
MANAGERS=(('manager', 'manager@example.com'),),
|
||||||
|
DEBUG=False,
|
||||||
|
)
|
||||||
|
def test_customize_send_mail_method(self):
|
||||||
|
class ManagerEmailHandler(AdminEmailHandler):
|
||||||
|
def send_mail(self, subject, message, *args, **kwargs):
|
||||||
|
mail.mail_managers(subject, message, *args, connection=self.connection(), **kwargs)
|
||||||
|
|
||||||
|
handler = ManagerEmailHandler()
|
||||||
|
record = self.logger.makeRecord('name', logging.ERROR, 'function', 'lno', 'message', None, None)
|
||||||
|
self.assertEqual(len(mail.outbox), 0)
|
||||||
|
handler.emit(record)
|
||||||
|
self.assertEqual(len(mail.outbox), 1)
|
||||||
|
self.assertEqual(mail.outbox[0].to, ['manager@example.com'])
|
||||||
|
|
||||||
|
|
||||||
class SettingsConfigTest(AdminScriptTestCase):
|
class SettingsConfigTest(AdminScriptTestCase):
|
||||||
"""
|
"""
|
||||||
|
|
Loading…
Reference in New Issue