From cdacbdfb41fe3b791dd68046fb24a15ab9f4c224 Mon Sep 17 00:00:00 2001 From: Sebastian Schleemilch Date: Thu, 24 Oct 2024 13:47:56 +0200 Subject: [PATCH] Switched tests from stdout to log-file parsing Signed-off-by: Sebastian Schleemilch --- src/vss_tools/exporters/ddsidl.py | 4 +- tests/vspec/test_allowed/test_allowed.py | 7 +- .../test_datatypes_error.py | 21 ++--- .../test_default_unit/test_default_units.py | 5 +- tests/vspec/test_extended/test_extended.py | 10 ++- .../test_faulty_type/test_faulty_type.py | 11 +-- tests/vspec/test_overlay/test_overlay.py | 29 ++++--- .../test_static_uids/test_static_uids.py | 83 ++++++++++--------- tests/vspec/test_strict/test_strict.py | 16 +--- .../test_structs/test_data_type_parsing.py | 48 +++++------ .../vspec/test_type_error/test_type_error.py | 28 ++++--- tests/vspec/test_units/test_units.py | 21 ++--- .../test_units_no_quantity.py | 10 +-- 13 files changed, 142 insertions(+), 151 deletions(-) diff --git a/src/vss_tools/exporters/ddsidl.py b/src/vss_tools/exporters/ddsidl.py index 90728418..00afd6f7 100644 --- a/src/vss_tools/exporters/ddsidl.py +++ b/src/vss_tools/exporters/ddsidl.py @@ -226,8 +226,8 @@ def export_node(node: VSSNode, generate_all_idl_features: bool) -> None: idl_file_buffer.append("};") allowed_values = str(allowed) else: - print( - f"Warning: VSS2IDL can only handle allowed values for string type, " + log.warning( + f"VSS2IDL can only handle allowed values for string type, " f"signal {node.name} has type {datatype}" ) diff --git a/tests/vspec/test_allowed/test_allowed.py b/tests/vspec/test_allowed/test_allowed.py index 22bdbd3e..124ae794 100644 --- a/tests/vspec/test_allowed/test_allowed.py +++ b/tests/vspec/test_allowed/test_allowed.py @@ -18,13 +18,14 @@ def run_exporter(exporter, argument, tmp_path): spec = HERE / "test.vspec" output = tmp_path / f"out.{exporter}" - cmd = f"vspec export {exporter}{argument} --vspec {spec} " + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export {exporter}{argument} --vspec {spec} " if exporter in ["apigear"]: cmd += f"--output-dir {output}" else: cmd += f"--output {output}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + process = subprocess.run(cmd.split()) assert process.returncode == 0 expected = HERE / f"expected.{exporter}" if exporter in ["apigear"]: @@ -37,7 +38,7 @@ def run_exporter(exporter, argument, tmp_path): # ddsidl can not handle float and integer # Some other tools ignore "allowed" all together if exporter in ["ddsidl"]: - assert "can only handle allowed values for string type" in process.stdout + assert "can only handle allowed values for string type" in log.read_text() def test_allowed(tmp_path): diff --git a/tests/vspec/test_datatypes_error/test_datatypes_error.py b/tests/vspec/test_datatypes_error/test_datatypes_error.py index 21a99b42..5e6340f8 100644 --- a/tests/vspec/test_datatypes_error/test_datatypes_error.py +++ b/tests/vspec/test_datatypes_error/test_datatypes_error.py @@ -6,7 +6,6 @@ # # SPDX-License-Identifier: MPL-2.0 -import os import subprocess from pathlib import Path @@ -18,21 +17,23 @@ def test_datatype_error(tmp_path): spec = HERE / "test.vspec" output = tmp_path / "out.json" - cmd = f"vspec export json --pretty -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + log = tmp_path / "log.txt" + cmd = ( + f"vspec --log-file {log} export json --pretty -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" + ) + process = subprocess.run(cmd.split()) assert process.returncode != 0 print(process.stdout) - assert "'uint7' is not a valid datatype" in process.stdout + assert "'uint7' is not a valid datatype" in log.read_text() def test_datatype_branch(tmp_path): spec = HERE / "test_datatype_branch.vspec" output = tmp_path / "out.json" - cmd = f"vspec export json --pretty -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output} --strict" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json --pretty -u {TEST_UNITS} -q {TEST_QUANT}" + cmd += f" --vspec {spec} --output {output} --strict" + process = subprocess.run(cmd.split()) assert process.returncode != 0 - print(process.stdout) - assert "Unknown extra attribute: 'A':'datatype'" in process.stdout + assert "Unknown extra attribute: 'A':'datatype'" in log.read_text() diff --git a/tests/vspec/test_default_unit/test_default_units.py b/tests/vspec/test_default_unit/test_default_units.py index ab9f6b4c..79fee1be 100644 --- a/tests/vspec/test_default_unit/test_default_units.py +++ b/tests/vspec/test_default_unit/test_default_units.py @@ -24,10 +24,11 @@ def run_unit(vspec_file, unit_argument, expected_file, tmp_path): def run_unit_error(vspec_file, unit_argument, check_message, tmp_path): output = tmp_path / "out.json" - cmd = f"vspec export json --pretty --vspec {vspec_file} {unit_argument} --output {output}" + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json --pretty --vspec {vspec_file} {unit_argument} --output {output}" process = subprocess.run(cmd.split(), capture_output=True, text=True) assert process.returncode != 0 - assert check_message in process.stdout + assert check_message in log.read_text() def test_default_ok(tmp_path): diff --git a/tests/vspec/test_extended/test_extended.py b/tests/vspec/test_extended/test_extended.py index e3c12740..cefb68cd 100644 --- a/tests/vspec/test_extended/test_extended.py +++ b/tests/vspec/test_extended/test_extended.py @@ -52,9 +52,10 @@ def test_extended_ok( cmd += f" -q {TEST_QUANT} {extended_args} -s {TEST_FILE} -o {output}" # Make sure there is no line break that affects compare - os.environ["COLUMNS"] = "120" + env = os.environ.copy() + env["COLUMNS"] = "120" - process = subprocess.run(cmd.split(), capture_output=True, check=True, text=True) + process = subprocess.run(cmd.split(), capture_output=True, check=True, text=True, env=env) if known_extended is not None: print(process.stdout) @@ -84,8 +85,9 @@ def test_extended_error(extended_args: str, tmp_path): cmd += f" -q {TEST_QUANT} {extended_args} -s {TEST_FILE} -o {output}" # Make sure there is no line break that affects compare - os.environ["COLUMNS"] = "120" + env = os.environ.copy() + env["COLUMNS"] = "120" - process = subprocess.run(cmd.split(), stdout=subprocess.PIPE, text=True, stderr=subprocess.STDOUT) + process = subprocess.run(cmd.split(), stdout=subprocess.PIPE, text=True, stderr=subprocess.STDOUT, env=env) assert process.returncode != 0 assert "not allowed" in process.stdout diff --git a/tests/vspec/test_faulty_type/test_faulty_type.py b/tests/vspec/test_faulty_type/test_faulty_type.py index 58d1e3be..3402c5b3 100644 --- a/tests/vspec/test_faulty_type/test_faulty_type.py +++ b/tests/vspec/test_faulty_type/test_faulty_type.py @@ -17,9 +17,10 @@ def test_error(tmp_path): spec = HERE / "test.vspec" output = tmp_path / "out.json" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" + process = subprocess.run(cmd.split()) assert process.returncode != 0 - print(process.stdout) - assert "input': 'bosch'" in process.stdout - assert "Input should be 'branch'" in process.stdout + log_content = log.read_text() + assert "input': 'bosch'" in log_content + assert "Input should be 'branch'" in log_content diff --git a/tests/vspec/test_overlay/test_overlay.py b/tests/vspec/test_overlay/test_overlay.py index 4ee36894..939ffda6 100644 --- a/tests/vspec/test_overlay/test_overlay.py +++ b/tests/vspec/test_overlay/test_overlay.py @@ -6,7 +6,6 @@ # # SPDX-License-Identifier: MPL-2.0 import filecmp -import os import subprocess from pathlib import Path @@ -48,29 +47,29 @@ def test_no_type(tmp_path): def test_overlay_error(tmp_path): overlay = HERE / "overlay_error.vspec" output = tmp_path / "out.json" + log = tmp_path / "log.txt" spec = HERE / "test.vspec" - cmd = f"vspec export json --pretty -u {TEST_UNITS}" + cmd = f"vspec --log-file {log} export json --pretty -u {TEST_UNITS}" cmd += f" -q {TEST_QUANT} -l {overlay} --vspec {spec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "300" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split()) assert process.returncode != 0 - print(process.stdout) - assert "'A.SignalXXXX' has 1 model error(s)" in process.stdout - assert "'type': 'missing'" in process.stdout - assert "datatype" in process.stdout + log_content = log.read_text() + assert "'A.SignalXXXX' has 1 model error(s)" in log_content + assert "'type': 'missing'" in log_content + assert "datatype" in log_content def test_overlay_branch_error(tmp_path): overlay = HERE / "overlay_implicit_branch_no_description.vspec" output = tmp_path / "out.json" + log = tmp_path / "log.txt" spec = HERE / "test.vspec" - cmd = f"vspec export json --pretty -u {TEST_UNITS}" + cmd = f"vspec --log-file {log} export json --pretty -u {TEST_UNITS}" cmd += f" -q {TEST_QUANT} -l {overlay} --vspec {spec} --output {output}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + process = subprocess.run(cmd.split()) assert process.returncode != 0 - print(process.stdout) - assert "'A.AB' has 1 model error(s)" in process.stdout - assert "'type': 'missing'" in process.stdout - assert "description" in process.stdout + log_content = log.read_text() + assert "'A.AB' has 1 model error(s)" in log_content + assert "'type': 'missing'" in log_content + assert "description" in log_content diff --git a/tests/vspec/test_static_uids/test_static_uids.py b/tests/vspec/test_static_uids/test_static_uids.py index e1ebfa37..d0d8aa68 100644 --- a/tests/vspec/test_static_uids/test_static_uids.py +++ b/tests/vspec/test_static_uids/test_static_uids.py @@ -10,7 +10,6 @@ # Convert vspec files to various other formats # -import os import shlex import subprocess from pathlib import Path @@ -197,77 +196,84 @@ def test_full_script(caplog: pytest.LogCaptureFixture, tmp_path): def test_semantic(caplog: pytest.LogCaptureFixture, validation_file: str, tmp_path): spec = HERE / "test_vspecs/test.vspec" output = tmp_path / "out.vspec" + log = tmp_path / "log.txt" validation = HERE / validation_file - args = f"vspec export id --vspec {spec} --output {output}" + args = f"vspec --log-file {log} export id --vspec {spec} --output {output}" args += f" --validate-static-uid {validation} -q {TEST_QUANT}" - process = subprocess.run(args.split(), capture_output=True, text=True) - assert "SEMANTIC NAME CHANGE" in process.stdout + subprocess.run(args.split()) + assert "SEMANTIC NAME CHANGE" in log.read_text() def test_vss_path(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_vss_path.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd, capture_output=True, text=True, env=env) - assert "PATH CHANGE" in process.stdout + subprocess.run(cmd) + assert "PATH CHANGE" in log.read_text() def test_unit(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_unit.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "BREAKING CHANGE" in process.stdout + subprocess.run(cmd, capture_output=True, text=True) + assert "BREAKING CHANGE" in log.read_text() def test_datatype(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_datatype.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "BREAKING CHANGE" in process.stdout + subprocess.run(cmd) + assert "BREAKING CHANGE" in log.read_text() def test_name_datatype(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_name_datatype.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "ADDED ATTRIBUTE" in process.stdout - assert "DELETED ATTRIBUTE" in process.stdout + subprocess.run(cmd) + log_content = log.read_text() + assert "ADDED ATTRIBUTE" in log_content + assert "DELETED ATTRIBUTE" in log_content def test_deprecation(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_deprecation.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "DEPRECATION MSG CHANGE" in process.stdout + subprocess.run(cmd) + assert "DEPRECATION MSG CHANGE" in log.read_text() def test_description(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_description.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "DESCRIPTION MISMATCH" in process.stdout + subprocess.run(cmd) + assert "DESCRIPTION MISMATCH" in log.read_text() def test_added_attribute(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_added_attribute.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "ADDED ATTRIBUTE" in process.stdout + subprocess.run(cmd) + assert "ADDED ATTRIBUTE" in log.read_text() output = tmp_path / "out.vspec" result = yaml.load(open(output), Loader=yaml.FullLoader) @@ -277,11 +283,12 @@ def test_added_attribute(caplog: pytest.LogCaptureFixture, tmp_path): def test_deleted_attribute(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test_deleted_attribute.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - assert "DELETED ATTRIBUTE" in process.stdout + subprocess.run(cmd) + assert "DELETED ATTRIBUTE" in log.read_text() output = tmp_path / "out.vspec" result = yaml.load(open(output), Loader=yaml.FullLoader) @@ -292,12 +299,12 @@ def test_deleted_attribute(caplog: pytest.LogCaptureFixture, tmp_path): def test_overlay(caplog: pytest.LogCaptureFixture, tmp_path): spec = HERE / "test_vspecs/test.vspec" overlay = HERE / "test_vspecs/test_overlay.vspec" - cmd = "vspec export id".split() + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export id".split() clas = shlex.split(get_cla_test(spec, tmp_path, overlay)) cmd += clas - process = subprocess.run(cmd, capture_output=True, text=True) - print(process.stdout) - assert "ADDED ATTRIBUTE" in process.stdout + subprocess.run(cmd) + assert "ADDED ATTRIBUTE" in log.read_text() output = tmp_path / "out.vspec" result = yaml.load(open(output), Loader=yaml.FullLoader) @@ -312,7 +319,7 @@ def test_const_id(caplog: pytest.LogCaptureFixture, tmp_path): cmd = "vspec export id".split() clas = shlex.split(get_cla_test(spec, tmp_path, overlay)) cmd += clas - subprocess.run(cmd, capture_output=True, text=True) + subprocess.run(cmd) output = tmp_path / "out.vspec" result = yaml.load(open(output), Loader=yaml.FullLoader) @@ -326,13 +333,13 @@ def test_iterated_file(caplog: pytest.LogCaptureFixture, tmp_path): cmd = "vspec export id".split() clas = shlex.split(get_cla_test(spec, tmp_path)) cmd += clas - subprocess.run(cmd, capture_output=True, text=True) + subprocess.run(cmd) output = tmp_path / "out.vspec" result = yaml.load(open(output), Loader=yaml.FullLoader) # run again on out.vspec to check if it all hashed attributes were exported correctly clas = shlex.split(get_cla_test(output, tmp_path)) - subprocess.run(cmd, capture_output=True, text=True) + subprocess.run(cmd) output = tmp_path / "out.vspec" result_iteration = yaml.load(open(output), Loader=yaml.FullLoader) diff --git a/tests/vspec/test_strict/test_strict.py b/tests/vspec/test_strict/test_strict.py index da1e427a..a997145f 100644 --- a/tests/vspec/test_strict/test_strict.py +++ b/tests/vspec/test_strict/test_strict.py @@ -6,7 +6,6 @@ # # SPDX-License-Identifier: MPL-2.0 -import os import subprocess from pathlib import Path @@ -30,11 +29,7 @@ def test_not_strict(vspec_file: str, tmp_path): spec = HERE / vspec_file output = tmp_path / "out.json" cmd = f"vspec export json --pretty -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) - print(vspec_file) - print(process.stdout) + process = subprocess.run(cmd.split()) assert process.returncode == 0 @@ -43,10 +38,7 @@ def test_strict_ok(vspec_file: str, tmp_path): spec = HERE / vspec_file output = tmp_path / "out.json" cmd = f"vspec export json --pretty --strict -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) - print(process.stdout) + process = subprocess.run(cmd.split()) assert process.returncode == 0 @@ -55,7 +47,5 @@ def test_strict_error(vspec_file: str, tmp_path): spec = HERE / vspec_file output = tmp_path / "out.json" cmd = f"vspec export json --pretty --strict -u {TEST_UNITS} -q {TEST_QUANT} --vspec {spec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split()) assert process.returncode != 0 diff --git a/tests/vspec/test_structs/test_data_type_parsing.py b/tests/vspec/test_structs/test_data_type_parsing.py index 15a92060..8106f7de 100644 --- a/tests/vspec/test_structs/test_data_type_parsing.py +++ b/tests/vspec/test_structs/test_data_type_parsing.py @@ -7,7 +7,6 @@ # SPDX-License-Identifier: MPL-2.0 import filecmp -import os import subprocess from pathlib import Path @@ -232,13 +231,12 @@ def test_data_types_invalid_reference_in_data_type_tree(types_file, error_msg, t output_types = tmp_path / "VehicleDataTypes.vspec" vspec = HERE / "test.vspec" output = tmp_path / "out.json" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" cmd += f" --types-output {output_types} --vspec {vspec} --output {output}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split(), capture_output=True, text=True) assert process.returncode != 0 - assert error_msg in process.stdout + assert error_msg in log.read_text() @pytest.mark.parametrize( @@ -258,14 +256,13 @@ def test_data_types_orphan_properties(types_file, error_msg, tmp_path): types_out = tmp_path / "VehicleDataTypes.vspec" vspec = HERE / "test.vspec" out = tmp_path / "out.json" + log = tmp_path / "log.txt" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" cmd += f" --types-output {types_out} --vspec {vspec} --output {out}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split()) assert process.returncode != 0 - assert error_msg in process.stdout + assert error_msg in log.read_text() def test_data_types_invalid_reference_in_signal_tree(tmp_path): @@ -276,16 +273,15 @@ def test_data_types_invalid_reference_in_signal_tree(tmp_path): types_out = tmp_path / "VehicleDataTypes.json" vspec = HERE / "test-invalid-datatypes.vspec" out = tmp_path / "out.json" + log = tmp_path / "log.txt" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" cmd += f" --types-output {types_out} --vspec {vspec} --output {out}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split()) assert process.returncode != 0 error_msg = "'VehicleDataTypes.TestBranch1.ParentStruct1' is not a valid datatype" - assert error_msg in process.stdout + assert error_msg in log.read_text() def test_error_when_no_user_defined_data_types_are_provided(tmp_path): @@ -295,14 +291,13 @@ def test_error_when_no_user_defined_data_types_are_provided(tmp_path): """ vspec = HERE / "test.vspec" out = tmp_path / "out.json" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --vspec {vspec} --output {out}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --vspec {vspec} --output {out}" + process = subprocess.run(cmd.split()) assert process.returncode != 0 error_msg = "'VehicleDataTypes.TestBranch1.ParentStruct' is not a valid datatype" - assert error_msg in process.stdout + assert error_msg in log.read_text() @pytest.mark.parametrize( @@ -333,16 +328,13 @@ def test_faulty_use_of_standard_attributes(vspec_file, types_file, error_msg, tm types_out = tmp_path / "VehicleDataTypes.json" vspec_file = HERE / vspec_file out = tmp_path / "out.json" + log = tmp_path / "log.txt" - cmd = f"vspec export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" + cmd = f"vspec --log-file {log} export json -u {TEST_UNITS} -q {TEST_QUANT} --pretty --types {types_file}" cmd += f" --types-output {types_out} --vspec {vspec_file} --output {out}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, env=env) + process = subprocess.run(cmd.split(), capture_output=True, text=True) assert process.returncode != 0 - print(process.stderr) - print(process.stdout) - assert error_msg in process.stdout or error_msg in process.stderr + assert error_msg in log.read_text() or error_msg in process.stderr def test_data_types_for_multiple_apigear_templates(tmp_path): diff --git a/tests/vspec/test_type_error/test_type_error.py b/tests/vspec/test_type_error/test_type_error.py index c02fa168..3d5ec6ec 100644 --- a/tests/vspec/test_type_error/test_type_error.py +++ b/tests/vspec/test_type_error/test_type_error.py @@ -30,8 +30,9 @@ def test_description_error(vspec_file: str, types_file, types_out_file, overlay_file, tmp_path): vspec_file = HERE / vspec_file out = tmp_path / "out.json" + log = tmp_path / "log.txt" - cmd = f"vspec export json --pretty -u {TEST_UNITS} -q {TEST_QUANT}" + cmd = f"vspec --log-file {log} export json --pretty -u {TEST_UNITS} -q {TEST_QUANT}" if types_file: cmd += f" --types {HERE / types_file}" if types_out_file: @@ -40,21 +41,22 @@ def test_description_error(vspec_file: str, types_file, types_out_file, overlay_ cmd += f" -l {HERE / overlay_file}" cmd += f" --vspec {vspec_file} --output {out}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + process = subprocess.run(cmd.split()) assert process.returncode != 0 - print(process.stdout) - assert "has 1 model" in process.stdout - assert "CRITICAL" in process.stdout + log_content = log.read_text() + assert "has 1 model" in log_content + assert "CRITICAL" in log_content @pytest.mark.parametrize("vspec_file", [("branch_wrong_case.vspec"), ("sensor_wrong_case.vspec")]) def type_case_sensitive(vspec_file: str, tmp_path): vspec_file = HERE / vspec_file out = tmp_path / "out.json" - cmd = f"vspec export json --pretty --vspec {vspec_file} --output {out}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json --pretty --vspec {vspec_file} --output {out}" + process = subprocess.run(cmd.split()) assert process.returncode != 0 - assert "Unknown type" in process.stdout + assert "Unknown type" in log.read_text() @pytest.mark.parametrize( @@ -66,9 +68,11 @@ def type_case_sensitive(vspec_file: str, tmp_path): def test_scope_error(vspec_file: str, tmp_path): vspec_file = HERE / vspec_file out = tmp_path / "out.json" - cmd = f"vspec export json --pretty -u {TEST_UNITS}" + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json --pretty -u {TEST_UNITS}" cmd += f" -q {TEST_QUANT} --vspec {vspec_file} --output {out}" - process = subprocess.run(cmd.split(), capture_output=True, text=True) + process = subprocess.run(cmd.split()) assert process.returncode != 0 - assert "Invalid nodes=1" in process.stdout - assert "A.UInt8.CCC" in process.stdout + log_content = log.read_text() + assert "Invalid nodes=1" in log_content + assert "A.UInt8.CCC" in log_content diff --git a/tests/vspec/test_units/test_units.py b/tests/vspec/test_units/test_units.py index ce9b0310..4f56c4c4 100644 --- a/tests/vspec/test_units/test_units.py +++ b/tests/vspec/test_units/test_units.py @@ -6,7 +6,6 @@ # # SPDX-License-Identifier: MPL-2.0 import filecmp -import os import subprocess from pathlib import Path from typing import Optional @@ -31,14 +30,12 @@ def run_unit( units = [] spec = HERE / vspec_file out = tmp_path / "out.json" + log = tmp_path / "log.txt" unit_argument = " ".join([f"-u {HERE / unit}" for unit in units]) quantity_argument = " ".join([f"-q {HERE / quantity}" for quantity in quantities]) - cmd = f"vspec export json --pretty --vspec {spec}" + cmd = f"vspec --log-file {log} export json --pretty --vspec {spec}" cmd += f" {unit_argument} {quantity_argument} --output {out}" - env = os.environ.copy() - # Long line needed as file name printed in some error messages - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE, env=env) + process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE) if fails: assert process.returncode != 0 @@ -47,7 +44,7 @@ def run_unit( assert filecmp.cmp(HERE / expected_file, out) if grep_present and grep_string: - assert grep_string in process.stdout or grep_string in process.stderr + assert grep_string in log.read_text() or grep_string in process.stderr def run_unit_error(tmp_path, vspec_file, units, grep_error, quantities=None): @@ -56,17 +53,15 @@ def run_unit_error(tmp_path, vspec_file, units, grep_error, quantities=None): if not units: units = [] out = tmp_path / "out.json" + log = tmp_path / "log.txt" unit_argument = " ".join([f"-u {HERE / unit}" for unit in units]) quantity_argument = " ".join([f"-q {HERE / quantity}" for quantity in quantities]) - cmd = f"vspec export json --pretty --vspec {vspec_file}" + cmd = f"vspec --log-file {log} export json --pretty --vspec {vspec_file}" cmd += f" {unit_argument} {quantity_argument} --output {out}" - env = os.environ.copy() - # Long line needed as file name printed in some error messages - env["COLUMNS"] = "300" - process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE, env=env) + process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE) assert process.returncode != 0 if grep_error: - assert grep_error in process.stdout or grep_error in process.stderr + assert grep_error in log.read_text() or grep_error in process.stderr def test_single_u(tmp_path): diff --git a/tests/vspec/test_units_no_quantity/test_units_no_quantity.py b/tests/vspec/test_units_no_quantity/test_units_no_quantity.py index 139af209..61d12cf7 100644 --- a/tests/vspec/test_units_no_quantity/test_units_no_quantity.py +++ b/tests/vspec/test_units_no_quantity/test_units_no_quantity.py @@ -6,7 +6,6 @@ # # SPDX-License-Identifier: MPL-2.0 import filecmp -import os import subprocess from pathlib import Path from typing import Optional @@ -26,11 +25,10 @@ def run_unit( fails: bool = False, ): out = tmp_path / "out.json" - cmd = f"vspec export json --pretty --vspec {vspec_file}" + log = tmp_path / "log.txt" + cmd = f"vspec --log-file {log} export json --pretty --vspec {vspec_file}" cmd += f" {unit_argument} {quantity_argument} --output {out}" - env = os.environ.copy() - env["COLUMNS"] = "200" - process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE, env=env) + process = subprocess.run(cmd.split(), capture_output=True, text=True, cwd=HERE) print(process.stdout) if fails: assert process.returncode != 0 @@ -39,7 +37,7 @@ def run_unit( assert filecmp.cmp(out, HERE / expected_file) if grep_string and grep_present: - assert grep_string in process.stdout or grep_string in process.stderr + assert grep_string in log.read_text() or grep_string in process.stderr def test_default_unit_no_quantity_warning(tmp_path):