X-Git-Url: http://www.average.org/gitweb/?a=blobdiff_plain;f=test%2Ftest_fuzz.py;h=4ac6f894482343c69df858d901eb87978538f56f;hb=9bdfa9b4a1890f81c4ef1d37db68e81bb17a1b14;hp=0456fda0352ddede2b315fb351bf431b500929ba;hpb=f075dbd6eea0e7326d68fd15a103d668baf67c10;p=loctrkd.git diff --git a/test/test_fuzz.py b/test/test_fuzz.py index 0456fda..4ac6f89 100644 --- a/test/test_fuzz.py +++ b/test/test_fuzz.py @@ -1,11 +1,10 @@ """ Send junk to the collector """ from random import Random -from socket import getaddrinfo, socket, AF_INET6, MSG_DONTWAIT, SOCK_STREAM +from socket import getaddrinfo, socket, AF_INET, SOCK_STREAM from time import sleep -from typing import Optional import unittest -from .common import TestWithServers +from .common import send_and_drain, TestWithServers REPEAT: int = 1000000 @@ -15,41 +14,33 @@ class Fuzz(TestWithServers): super().setUp("collector") self.rnd = Random() for fam, typ, pro, cnm, skadr in getaddrinfo( - "::1", + "127.0.0.1", self.conf.getint("collector", "port"), - family=AF_INET6, + family=AF_INET, type=SOCK_STREAM, ): break # Just take the first element - self.sock = socket(AF_INET6, SOCK_STREAM) + self.sock = socket(AF_INET, SOCK_STREAM) self.sock.connect(skadr) def tearDown(self) -> None: sleep(1) # give collector some time - self._send_and_drain(None) + send_and_drain(self.sock, None) self.sock.close() - print("finished fuzzing") + sleep(1) # Let the server close their side super().tearDown() - def _send_and_drain(self, buf: Optional[bytes]) -> None: - if buf is not None: - self.sock.send(buf) - try: - self.sock.recv(4096, MSG_DONTWAIT) - except BlockingIOError: - pass - def test_stream(self) -> None: for _ in range(REPEAT): size = self.rnd.randint(1, 5000) buf = self.rnd.randbytes(size) - self._send_and_drain(buf) + send_and_drain(self.sock, buf) def test_msgs(self) -> None: for _ in range(REPEAT): size = self.rnd.randint(0, 300) buf = b"xx" + self.rnd.randbytes(size) + b"\r\n" - self._send_and_drain(buf) + send_and_drain(self.sock, buf) if __name__ == "__main__":