mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-08 18:11:54 +00:00
6ee70f196a
Checking is done inline and asynchronously, every log message should be explicitly expected, otherwise it's reported. It also has an implicit timeout of 1s for the log message to appear, otherwise it fails as well.
75 lines
2.0 KiB
Python
75 lines
2.0 KiB
Python
import asyncio
|
|
import re
|
|
|
|
from python.asyncinotify.src.asyncinotify import Inotify, Mask
|
|
|
|
class UnexpectedLogException(Exception):
|
|
pass
|
|
|
|
class LogSeen:
|
|
lino: int
|
|
buf: str
|
|
groups: object
|
|
|
|
class LogExpectedStub:
|
|
def __init__(self, pattern):
|
|
self.pattern = re.compile(pattern) if type(pattern) is str else pattern
|
|
self.seen = []
|
|
|
|
def check(self, buf):
|
|
return self.pattern.match(buf)
|
|
|
|
def store(self, data):
|
|
self.seen.append(data)
|
|
|
|
class LogExpectedFuture(LogExpectedStub):
|
|
def __init__(self, pattern):
|
|
super().__init__(pattern)
|
|
self.done = asyncio.Future()
|
|
|
|
def store(self, data):
|
|
self.done.set_result(data)
|
|
|
|
class LogChecker:
|
|
def __init__(self, name, expected=None):
|
|
self.name = name
|
|
self.expected = [
|
|
LogExpectedStub(e) if isinstance(e, str) else e
|
|
for e in expected
|
|
] if expected is not None else []
|
|
self.task = None
|
|
|
|
def check(self, buf):
|
|
for p in self.expected:
|
|
if (g := p.check(buf)) is not None:
|
|
p.store(g)
|
|
return
|
|
|
|
raise UnexpectedLogException(buf)
|
|
|
|
async def run(self):
|
|
with (Inotify() as inot, open(self.name, "r") as f):
|
|
inot.add_watch(self.name, Mask.MODIFY)
|
|
buf = None
|
|
while True:
|
|
buf = f.readline()
|
|
if len(buf) > 0 and buf[-1] == "\n":
|
|
self.check(buf)
|
|
else:
|
|
break
|
|
|
|
async for event in inot:
|
|
while True:
|
|
buf += f.readline()
|
|
if len(buf) > 0 and buf[-1] == "\n":
|
|
self.check(buf)
|
|
buf = ""
|
|
else:
|
|
break
|
|
|
|
def append(self, pat):
|
|
if type(pat) is str:
|
|
self.expected.append(LogExpectedStub(pat))
|
|
else:
|
|
self.expected.append(pat)
|