Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
d345bb4d
Commit
d345bb4d
authored
Sep 25, 2018
by
Cheryl Sabella
Committed by
Vinay Sajip
Sep 26, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-34334: Don't log traceback twice in QueueHandler (GH-9537)
parent
fad6af27
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
23 additions
and
5 deletions
+23
-5
Doc/library/logging.handlers.rst
Doc/library/logging.handlers.rst
+3
-3
Lib/logging/handlers.py
Lib/logging/handlers.py
+3
-2
Lib/test/test_logging.py
Lib/test/test_logging.py
+15
-0
Misc/NEWS.d/next/Library/2018-09-25-08-42-34.bpo-34334.rSPBW9.rst
...S.d/next/Library/2018-09-25-08-42-34.bpo-34334.rSPBW9.rst
+2
-0
No files found.
Doc/library/logging.handlers.rst
View file @
d345bb4d
...
@@ -973,9 +973,9 @@ possible, while any potentially slow operations (such as sending an email via
...
@@ -973,9 +973,9 @@ possible, while any potentially slow operations (such as sending an email via
Prepares a record for queuing. The object returned by this
Prepares a record for queuing. The object returned by this
method is enqueued.
method is enqueued.
The base implementation formats the record to merge the message
The base implementation formats the record to merge the message
,
a
nd arguments, and removes unpickleable items from the record
a
rguments, and exception information, if present. It also
in-place.
removes unpickleable items from the record
in-place.
You might want to override this method if you want to convert
You might want to override this method if you want to convert
the record to a dict or JSON string, or send a modified copy
the record to a dict or JSON string, or send a modified copy
...
...
Lib/logging/handlers.py
View file @
d345bb4d
...
@@ -1374,13 +1374,14 @@ class QueueHandler(logging.Handler):
...
@@ -1374,13 +1374,14 @@ class QueueHandler(logging.Handler):
# (if there's exception data), and also returns the formatted
# (if there's exception data), and also returns the formatted
# message. We can then use this to replace the original
# message. We can then use this to replace the original
# msg + args, as these might be unpickleable. We also zap the
# msg + args, as these might be unpickleable. We also zap the
# exc_info a
ttribute, as it's no longer needed and, if not None,
# exc_info a
nd exc_text attributes, as they are no longer
# will typically not be pickleable.
#
needed and, if not None,
will typically not be pickleable.
msg
=
self
.
format
(
record
)
msg
=
self
.
format
(
record
)
record
.
message
=
msg
record
.
message
=
msg
record
.
msg
=
msg
record
.
msg
=
msg
record
.
args
=
None
record
.
args
=
None
record
.
exc_info
=
None
record
.
exc_info
=
None
record
.
exc_text
=
None
return
record
return
record
def
emit
(
self
,
record
):
def
emit
(
self
,
record
):
...
...
Lib/test/test_logging.py
View file @
d345bb4d
...
@@ -3345,6 +3345,21 @@ class QueueHandlerTest(BaseTest):
...
@@ -3345,6 +3345,21 @@ class QueueHandlerTest(BaseTest):
self.assertFalse(handler.matches(levelno=logging.WARNING, message='4'))
self.assertFalse(handler.matches(levelno=logging.WARNING, message='4'))
self.assertFalse(handler.matches(levelno=logging.ERROR, message='5'))
self.assertFalse(handler.matches(levelno=logging.ERROR, message='5'))
self.assertTrue(handler.matches(levelno=logging.CRITICAL, message='6'))
self.assertTrue(handler.matches(levelno=logging.CRITICAL, message='6'))
handler.close()
@unittest.skipUnless(hasattr(logging.handlers, 'QueueListener'),
'logging.handlers.QueueListener required for this test')
def test_queue_listener_with_StreamHandler(self):
# Test that traceback only appends once (bpo-34334).
listener = logging.handlers.QueueListener(self.queue, self.root_hdlr)
listener.start()
try:
1 / 0
except ZeroDivisionError as e:
exc = e
self.que_logger.exception(self.next_message(), exc_info=exc)
listener.stop()
self.assertEqual(self.stream.getvalue().strip().count('Traceback'), 1)
if hasattr(logging.handlers, 'QueueListener'):
if hasattr(logging.handlers, 'QueueListener'):
import multiprocessing
import multiprocessing
...
...
Misc/NEWS.d/next/Library/2018-09-25-08-42-34.bpo-34334.rSPBW9.rst
0 → 100644
View file @
d345bb4d
In :class:`QueueHandler`, clear `exc_text` from :class:`LogRecord` to
prevent traceback from being written twice.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment