blob: 9d3ce0e3abf3806b138adf44bdbb6808a9acdf89 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
# -*- test-case-name: twisted.logger.test.test_capture -*-
# Copyright (c) Twisted Matrix Laboratories.
# See LICENSE for details.
"""
Context manager for capturing logs.
"""
from contextlib import contextmanager
from typing import Iterator, List, Sequence, cast
from twisted.logger import globalLogPublisher
from ._interfaces import ILogObserver, LogEvent
@contextmanager
def capturedLogs() -> Iterator[Sequence[LogEvent]]:
events: List[LogEvent] = []
observer = cast(ILogObserver, events.append)
globalLogPublisher.addObserver(observer)
yield events
globalLogPublisher.removeObserver(observer)
|