Viewing file: test_buffer.py (1.78 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
# Copyright (c) Twisted Matrix Laboratories. # See LICENSE for details.
""" Test cases for L{twisted.logger._buffer}. """
from typing import List, cast
from zope.interface.exceptions import BrokenMethodImplementation from zope.interface.verify import verifyObject
from twisted.trial import unittest from .._buffer import LimitedHistoryLogObserver from .._interfaces import ILogObserver, LogEvent
class LimitedHistoryLogObserverTests(unittest.TestCase): """ Tests for L{LimitedHistoryLogObserver}. """
def test_interface(self) -> None: """ L{LimitedHistoryLogObserver} provides L{ILogObserver}. """ observer = LimitedHistoryLogObserver(0) try: verifyObject(ILogObserver, observer) except BrokenMethodImplementation as e: self.fail(e)
def test_order(self) -> None: """ L{LimitedHistoryLogObserver} saves history in the order it is received. """ size = 4 events = [dict(n=n) for n in range(size // 2)] observer = LimitedHistoryLogObserver(size)
for event in events: observer(event)
outEvents: List[LogEvent] = [] observer.replayTo(cast(ILogObserver, outEvents.append)) self.assertEqual(events, outEvents)
def test_limit(self) -> None: """ When more events than a L{LimitedHistoryLogObserver}'s maximum size are buffered, older events will be dropped. """ size = 4 events = [dict(n=n) for n in range(size * 2)] observer = LimitedHistoryLogObserver(size)
for event in events: observer(event)
outEvents: List[LogEvent] = [] observer.replayTo(cast(ILogObserver, outEvents.append)) self.assertEqual(events[-size:], outEvents)
|