From 81bf1f11957e916afea482385f7d6f194076becd Mon Sep 17 00:00:00 2001 From: Sina Atalay Date: Sat, 18 Nov 2023 17:51:13 +0100 Subject: [PATCH] fix tests --- rendercv/rendering.py | 49 +++++++++++++++++++++++-------------------- tests/test_cli.py | 42 ++++++++++++++++++++----------------- 2 files changed, 49 insertions(+), 42 deletions(-) diff --git a/rendercv/rendering.py b/rendercv/rendering.py index e0358d8..2267a18 100644 --- a/rendercv/rendering.py +++ b/rendercv/rendering.py @@ -500,22 +500,25 @@ def run_latex(latex_file_path: str) -> str: ) # Run TinyTeX: - with subprocess.Popen( - [ - executable, - f"{latex_file_name}", - "&&", - executable, - f"{latex_file_name}", - ], - cwd=os.path.dirname(latex_file_path), - stdout=subprocess.PIPE, - stdin=subprocess.DEVNULL, # don't allow TinyTeX to ask for user input - text=True, - shell=True, - ) as latex_process: - output, error = latex_process.communicate() + def run(): + with subprocess.Popen( + [ + executable, + f"{latex_file_name}", + ], + cwd=os.path.dirname(latex_file_path), + stdout=subprocess.PIPE, + stdin=subprocess.DEVNULL, # don't allow TinyTeX to ask for user input + text=True, + ) as latex_process: + output, error = latex_process.communicate() + if latex_process.returncode != 0: + # Find the error line: + for line in output.split("\n"): + if line.startswith("! "): + error_line = line.replace("! ", "") + break if latex_process.returncode != 0: # Find the error line: for line in output.split("\n"): @@ -523,16 +526,16 @@ def run_latex(latex_file_path: str) -> str: error_line = line.replace("! ", "") break - raise RuntimeError( - "Running TinyTeX has failed with the following error:", - f"{error_line}", - "If you can't solve the problem, please try to re-install RenderCV," - " or open an issue on GitHub.", - ) + raise RuntimeError( + "Running TinyTeX has failed with the following error:", + f"{error_line}", + "If you can't solve the problem, please try to re-install RenderCV," + " or open an issue on GitHub.", + ) run() - run() # run twice for cross-references - + run() # run twice for cross-references + # check if the PDF file is generated: if not os.path.exists(output_file_path): raise FileNotFoundError( diff --git a/tests/test_cli.py b/tests/test_cli.py index 0fb086d..3c516ed 100644 --- a/tests/test_cli.py +++ b/tests/test_cli.py @@ -12,16 +12,17 @@ class TestCLI(unittest.TestCase): # Change the working directory to the root of the project: workspace_path = os.path.dirname(os.path.dirname(__file__)) - test_input_file_path = os.path.join( - workspace_path, - "tests", - "reference_files", - "John_Doe_CV_yaml_reference.yaml", - ) - subprocess.run( - [sys.executable, "-m", "rendercv", "render", test_input_file_path], - check=True, - ) + with self.subTest(msg="Correct input"): + test_input_file_path = os.path.join( + workspace_path, + "tests", + "reference_files", + "John_Doe_CV_yaml_reference.yaml", + ) + subprocess.run( + [sys.executable, "-m", "rendercv", "render", test_input_file_path], + check=True, + ) # Read the necessary information and remove the output directory: output_file_path = os.path.join(workspace_path, "output", "John_Doe_CV.pdf") @@ -32,15 +33,18 @@ class TestCLI(unittest.TestCase): # Check if the output file exists: self.assertTrue(file_exists, msg="PDF file couldn't be generated.") - # Compare the pdf file with the reference pdf file: - reference_pdf_file = os.path.join( - workspace_path, "tests", "reference_files", "John_Doe_CV_pdf_reference.pdf" - ) - reference_pdf_file_size = os.path.getsize(reference_pdf_file) - ratio = min(reference_pdf_file_size, pdf_file_size) / max( - reference_pdf_file_size, pdf_file_size - ) - self.assertTrue(ratio > 0.98, msg="PDF file didn't match the reference.") + # Compare the pdf file with the reference pdf file: + reference_pdf_file = os.path.join( + workspace_path, + "tests", + "reference_files", + "John_Doe_CV_pdf_reference.pdf", + ) + reference_pdf_file_size = os.path.getsize(reference_pdf_file) + ratio = min(reference_pdf_file_size, pdf_file_size) / max( + reference_pdf_file_size, pdf_file_size + ) + self.assertTrue(ratio > 0.98, msg="PDF file didn't match the reference.") # Wrong input: with self.subTest(msg="Wrong input"):