|
|
- # noinspection PyUnresolvedReferences
- import future
- import socket
-
- from http.server import BaseHTTPRequestHandler, HTTPServer
- from threading import Thread
- from .logsList import logs_list
- from .persistentFlags import persistent_flags
-
-
- class ListenerHandler(BaseHTTPRequestHandler):
- def do_POST(self):
- try:
- content_length = int(self.headers.get("Content-Length"))
- all_logs = self.rfile.read(content_length).decode("utf-8").split('\n')
- if len(all_logs) == 0:
- self._set_response(400, "Bad Request", b"Bad request you got there, pal")
- return
-
- for log in all_logs:
- if log != "":
- if persistent_flags.get_server_error():
- self._set_response(500, "Issue!!!!!!!", b"Not good, not good at all.")
- return
-
- logs_list.list.append(log)
-
- self._set_response(200, "OK", b"Shabam! got logs.")
- return
-
- except IndexError:
- self._set_response(400, "Bad Request", b"Bad request you got there, pal")
- return
-
- def _set_response(self, http_code, http_description, byte_body):
- self.send_response(http_code, http_description)
- self.send_header('Content-type', 'text/html')
- self.end_headers()
- self.wfile.write(byte_body)
-
-
- class MockLogzioListener:
- def __init__(self):
- self.port = _find_available_port()
- self.host = "localhost"
-
- self.server = HTTPServer((self.host, self.port), ListenerHandler)
-
- self.listening_thread = Thread(target=self._start_listening)
- self.listening_thread.daemon = True
- self.listening_thread.name = "mock-logzio-listener"
- self.listening_thread.start()
- self.logs_list = logs_list.list
- self.persistent_flags = persistent_flags
-
- def _start_listening(self):
- self.server.serve_forever()
-
- def get_port(self):
- return self.port
-
- def get_host(self):
- return self.host
-
- def find_log(self, search_log):
- for current_log in self.logs_list:
- if search_log in current_log:
- return True
-
- return False
-
- def get_number_of_logs(self):
- return len(self.logs_list)
-
- def clear_logs_buffer(self):
- self.logs_list = []
-
- def set_server_error(self):
- self.persistent_flags.set_server_error()
-
- def clear_server_error(self):
- self.persistent_flags.clear_server_error()
-
-
- def _find_available_port():
- sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
- sock.bind(("", 0))
- sock.listen(1)
- port = sock.getsockname()[1]
- sock.close()
- return port
|