Mini Shell
# 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)
Zerion Mini Shell 1.0