From b0b1ff27dfab00d00103508c2f926354c615dc56 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ole=20Andr=C3=A9=20Vadla=20Ravn=C3=A5s?= Date: Sat, 21 Sep 2024 00:42:55 +0200 Subject: [PATCH] meson: Dump stdout and stderr when npm fails --- agents/build.py | 8 +++++++- apps/build.py | 12 +++++++++++- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/agents/build.py b/agents/build.py index be106177..1ae04a1d 100644 --- a/agents/build.py +++ b/agents/build.py @@ -15,6 +15,10 @@ def main(argv: list[str]): try: build(npm, inputs, output_js, priv_dir) + except subprocess.CalledProcessError as e: + print(e, file=sys.stderr) + print("Output:\n\t| " + "\n\t| ".join(e.output.strip().split("\n")), file=sys.stderr) + sys.exit(1) except Exception as e: print(e, file=sys.stderr) sys.exit(1) @@ -35,7 +39,9 @@ def build(npm: Path, inputs: list[Path], output_js: Path, priv_dir: Path): shutil.copy(srcfile, dstfile) - subprocess.run([npm, "install"], capture_output=True, cwd=priv_dir, check=True) + subprocess.run( + [npm, "install"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, encoding="utf-8", cwd=priv_dir, check=True + ) frida_compile = priv_dir / "node_modules" / ".bin" / f"frida-compile{script_suffix()}" subprocess.run([frida_compile, entrypoint, "-c", "-o", output_js], cwd=priv_dir, check=True) diff --git a/apps/build.py b/apps/build.py index 8089c1f4..672cd73f 100644 --- a/apps/build.py +++ b/apps/build.py @@ -15,6 +15,10 @@ def main(argv: list[str]): try: build(npm, inputs, output_zip, priv_dir) + except subprocess.CalledProcessError as e: + print(e, file=sys.stderr) + print("Output:\n\t| " + "\n\t| ".join(e.output.strip().split("\n")), file=sys.stderr) + sys.exit(1) except Exception as e: print(e, file=sys.stderr) sys.exit(1) @@ -34,7 +38,13 @@ def build(npm: Path, inputs: list[Path], output_zip: Path, priv_dir: Path): shutil.copy(srcfile, dstfile) - npm_opts = {"cwd": priv_dir, "capture_output": True, "check": True} + npm_opts = { + "cwd": priv_dir, + "stdout": subprocess.PIPE, + "stderr": subprocess.STDOUT, + "encoding": "utf-8", + "check": True, + } subprocess.run([npm, "install"], **npm_opts) subprocess.run([npm, "run", "build"], **npm_opts)