From: Christian Heller Date: Sun, 22 Feb 2015 12:03:17 +0000 (+0100) Subject: Server/py: Add server_test() remake. X-Git-Tag: tce~497 X-Git-Url: https://plomlompom.com/repos/%7B%7B%20web_path%20%7D%7D/decks/%7B%7Bdb.prefix%7D%7D/%7B%7Bprefix%7D%7D/day?a=commitdiff_plain;h=76180c99a9cf02004faaf1fb70e79a41228c7746;p=plomrogue Server/py: Add server_test() remake. --- diff --git a/plomrogue-server.py b/plomrogue-server.py index 671edd0..df0c211 100755 --- a/plomrogue-server.py +++ b/plomrogue-server.py @@ -28,6 +28,7 @@ def setup_server_io(io_db): os.makedirs(io_dir, exist_ok=True) io_db["file_out"] = open(io_db["path_out"], "w") io_db["file_out"].write(io_db["teststring"] + "\n") + io_db["file_out"].flush() if os.access(io_db["path_in"], os.F_OK): os.remove(io_db["path_in"]) io_db["file_in"] = open(io_db["path_in"], "w") @@ -129,6 +130,20 @@ def parse_command_line_arguments(): return opts +def server_test(io_db): + """Check for valid server out file belonging to current process.""" + if not os.access(io_db["path_out"], os.F_OK): + raise SystemExit("Server output file has disappeared.") + file = open(io_db["path_out"], "r") + test = file.readline().rstrip("\n") + file.close() + print(str(test) + " == " + io_db["teststring"] + " ?") + if test != io_db["teststring"]: + msg = "Server test string in server output file does not match. This" \ + " indicates that the current server process has been " \ + "superseded by another one." + raise SystemExit(msg) + io_db = {} world_db = {} try: