import logging.config
def main(q):
config = {
'version': 1,
'handlers': {
'sink': {
'class': 'logging.handlers.QueueHandler',
'queue': q,
},
},
'root': {
'handlers': ['sink'],
},
}
logging.config.dictConfig(config)
if __name__ == '__main__':
import multiprocessing as mp
main(mp.Manager().Queue())
#import asyncio
#main(asyncio.Queue()) # broken too
Traceback (most recent call last):
File "/usr/lib/python3.12/logging/config.py", line 581, in configure
handler = self.configure_handler(handlers[name])
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/lib/python3.12/logging/config.py", line 801, in configure_handler
raise TypeError('Invalid queue specifier %r' % qspec)
TypeError: Invalid queue specifier <AutoProxy[Queue] object, typeid 'Queue' at 0x7f8b07189d90>
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
File "/home/xxx/logging-queue-handler-bug.py", line 33, in <module>
main(mp.Manager().Queue())
File "/home/xxx/logging-queue-handler-bug.py", line 29, in main
logging.config.dictConfig(config)
File "/usr/lib/python3.12/logging/config.py", line 914, in dictConfig
dictConfigClass(config).configure()
File "/usr/lib/python3.12/logging/config.py", line 588, in configure
raise ValueError('Unable to configure handler '
ValueError: Unable to configure handler 'sink'
or just focus on handling special cases: str and dict, while leaving other cases un-checked (e.g., queue.Queue, multiprocessing.queues.Queue).
Bug report
Bug description:
Related bug: #111615
Related pull: #111638
Related codes:
cpython/Lib/logging/config.py
Lines 789 to 804 in bd0d97c
reproducible example using Python 3.12.3
error:
Queue classes to check for logging QueueHandler
<queue.Queue at 0x7fb86eeef170>, works.<multiprocessing.queues.Queue at 0x7fb871790500>, works.<AutoProxy[Queue] object, typeid 'Queue' at 0x7fb86ef4a840>, broken.Its class is
multiprocessing.managers.AutoProxy[Queue], a subclass ofmultiprocessing.managers.BaseProxy.<Queue at 0x7fb86f0be4e0 maxsize=0>, broken.discuss: how to fix
Check all Queue classes mentioned above in
cpython/Lib/logging/config.py
Line 792 in bd0d97c
or just focus on handling special cases: str and dict, while leaving other cases un-checked (e.g., queue.Queue, multiprocessing.queues.Queue).
CPython versions tested on:
3.12
Operating systems tested on:
Linux
Linked PRs