Skip to content
Snippets Groups Projects
Commit 2672448e authored by Grégoire Kubler's avatar Grégoire Kubler
Browse files

feat : enhanced test to allow printing stdout & stderr of subprocess calls.

parent 015593e4
No related branches found
No related tags found
2 merge requests!212Version 0.3.0,!116feat/release_pip
Pipeline #50948 failed
...@@ -15,6 +15,8 @@ import os ...@@ -15,6 +15,8 @@ import os
import sys import sys
import subprocess import subprocess
import shutil import shutil
import queue
import threading
def initFiller(model): def initFiller(model):
...@@ -42,6 +44,59 @@ def initFiller(model): ...@@ -42,6 +44,59 @@ def initFiller(model):
pass pass
def enqueue_output(stream, queue):
for line in iter(stream.readline, ""):
queue.put(line)
stream.close()
def run_command(command : list[str], cwd : pathlib.Path):
"""
This function has the job to run a command and return stdout and stderr that are not shown
by subprocess :
Arg:
command : written with the same syntax as subprocess.call
"""
process = subprocess.Popen(
command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True
)
stdout_queue = queue.Queue()
stderr_queue = queue.Queue()
stdout_thread = threading.Thread(
target=enqueue_output, args=(process.stdout, stdout_queue)
)
stderr_thread = threading.Thread(
target=enqueue_output, args=(process.stderr, stderr_queue)
)
stdout_thread.start()
stderr_thread.start()
while (
stdout_thread.is_alive()
or stderr_thread.is_alive()
or not stdout_queue.empty()
or not stderr_queue.empty()
):
try:
stdout_line = stdout_queue.get_nowait()
yield stdout_line
except queue.Empty:
pass
try:
stderr_line = stderr_queue.get_nowait()
yield stderr_line
except queue.Empty:
pass
return_code = process.wait()
if return_code != 0:
raise subprocess.CalledProcessError(return_code, command)
def clean_dir(dir: pathlib.Path) -> None: def clean_dir(dir: pathlib.Path) -> None:
if not dir.is_dir(): if not dir.is_dir():
print(f"Error : directory {dir} doesn't exist. Exiting clean_dir().") print(f"Error : directory {dir} doesn't exist. Exiting clean_dir().")
...@@ -108,23 +163,43 @@ class test_export(unittest.TestCase): ...@@ -108,23 +163,43 @@ class test_export(unittest.TestCase):
self.EXPORT_PATH / "main.cpp", self.EXPORT_PATH / "main.cpp",
) )
subprocess.check_call( ##########################
[ # CMAKE EXPORT
"cmake", try:
str(self.EXPORT_PATH.absolute()), for std_line in run_command(
"-DPYBIND=1", [
f"-DCMAKE_INSTALL_PREFIX:PATH={install_path}", "cmake",
], str(self.EXPORT_PATH.absolute()),
cwd=str(self.BUILD_DIR), "-DPYBIND=1",
) f"-DCMAKE_INSTALL_PREFIX:PATH={install_path}",
subprocess.check_call( ],
["cmake", "--build", "."], cwd=str(self.BUILD_DIR),
cwd=str(self.BUILD_DIR), ):
) print(std_line, end="")
subprocess.check_call( except subprocess.CalledProcessError as e:
["cmake", "--install", "."], print(f"An error occurred: {e}\nFailed to configure export.")
cwd=str(self.BUILD_DIR),
) ##########################
# BUILD EXPORT
try:
for std_line in run_command(
["cmake", "--build", "."],
cwd=str(self.BUILD_DIR),
):
print(std_line, end="")
except subprocess.CalledProcessError as e:
print(f"An error occurred: {e}\nFailed to build export.")
##########################
# INSTALL EXPORT
try:
for std_line in run_command(
["cmake", "--install", "."],
cwd=str(self.BUILD_DIR),
):
print(std_line, end="")
except subprocess.CalledProcessError as e:
print(f"An error occurred: {e}\nFailed to install export.")
if __name__ == "__main__": if __name__ == "__main__":
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment