predixy/test/logger_thread_init.py
2026-01-15 13:00:16 +01:00

48 lines
1.5 KiB
Python

#!/usr/bin/env python3
#
# Build and run the Logger thread init test.
#
import os
import subprocess
import tempfile
from test_util import parse_args, exit_with_result
def run_test(project_root):
src = os.path.join(project_root, "test", "logger_thread_init.cpp")
if not os.path.exists(src):
print("FAIL: logger_thread_init.cpp not found")
return False
with tempfile.TemporaryDirectory() as tmp:
exe = os.path.join(tmp, "logger_thread_init")
cmd = [
"g++",
"-std=c++11",
src,
os.path.join(project_root, "src", "Logger.cpp"),
os.path.join(project_root, "src", "LogFileSink.cpp"),
os.path.join(project_root, "src", "Timer.cpp"),
"-o",
exe,
]
try:
subprocess.check_call(cmd, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
except Exception as exc:
print("FAIL: compile logger_thread_init:", exc)
return False
try:
subprocess.check_call([exe], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
except subprocess.CalledProcessError as exc:
print("FAIL: logger_thread_init returned", exc.returncode)
return False
return True
if __name__ == "__main__":
_ = parse_args("Logger thread init test")
root = os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))
success = run_test(root)
exit_with_result(success, "logger thread init", "logger thread init")