From a52d1b77f5a70a5c96e58a3dbedd6af52714599e Mon Sep 17 00:00:00 2001 From: adammarples Date: Wed, 22 Nov 2023 10:17:12 +0000 Subject: [PATCH] Return code or error ignores WarnErrorOptions (#692) Ignore `WarnErrorOptions` string in stdout from dbt-core, do not treat it as a failure Closes: #642 --- cosmos/dbt/graph.py | 2 +- tests/dbt/test_graph.py | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/cosmos/dbt/graph.py b/cosmos/dbt/graph.py index 40154308b..556ebe09a 100644 --- a/cosmos/dbt/graph.py +++ b/cosmos/dbt/graph.py @@ -88,7 +88,7 @@ def run_command(command: list[str], tmp_dir: Path, env_vars: dict[str, str]) -> "Unable to run dbt ls command due to missing dbt_packages. Set RenderConfig.dbt_deps=True." ) - if returncode or "Error" in stdout: + if returncode or "Error" in stdout.replace("WarnErrorOptions", ""): details = stderr or stdout raise CosmosLoadDbtException(f"Unable to run {command} due to the error:\n{details}") diff --git a/tests/dbt/test_graph.py b/tests/dbt/test_graph.py index 3e3218259..224aff56e 100644 --- a/tests/dbt/test_graph.py +++ b/tests/dbt/test_graph.py @@ -679,6 +679,7 @@ def test_load_dbt_ls_and_manifest_with_model_version(load_method): "stdout,returncode", [ ("all good", None), + ("WarnErrorOptions", None), pytest.param("fail", 599, marks=pytest.mark.xfail(raises=CosmosLoadDbtException)), pytest.param("Error", None, marks=pytest.mark.xfail(raises=CosmosLoadDbtException)), ],