mirror of
https://github.com/element-hq/synapse.git
synced 2024-11-27 03:58:06 +03:00
49a683d871
Use `PreserveLoggingContext()` to ensure that logging contexts are not lost when exiting a read/write lock. When exiting a read/write lock, callbacks on a `Deferred` are triggered as a signal to any waiting coroutines. Any waiting coroutine that becomes runnable is likely to follow the Synapse logging context rules and will restore its own logging context, then either run to completion or await another `Deferred`, resetting the logging context in the process.
1 line
84 B
Text
1 line
84 B
Text
Fix a long-standing bug where `ReadWriteLock`s could drop logging contexts on exit.
|