diff --git a/cosmos/operators/local.py b/cosmos/operators/local.py index 335ce5e07..6af849b65 100644 --- a/cosmos/operators/local.py +++ b/cosmos/operators/local.py @@ -204,17 +204,11 @@ def run_command( tmp_project_dir, ) - # if we need to install deps, do so - if self.install_deps: - self.run_subprocess( - command=[self.dbt_executable_path, "deps"], - env=env, - output_encoding=self.output_encoding, - cwd=tmp_project_dir, - ) - with self.profile_config.ensure_profile() as (profile_path, env_vars): + with self.profile_config.ensure_profile() as profile_values: + (profile_path, env_vars) = profile_values env.update(env_vars) - full_cmd = cmd + [ + + flags = [ "--profiles-dir", str(profile_path.parent), "--profile", @@ -223,6 +217,18 @@ def run_command( self.profile_config.target_name, ] + if self.install_deps: + deps_command = [self.dbt_executable_path, "deps"] + deps_command.extend(flags) + self.run_subprocess( + command=deps_command, + env=env, + output_encoding=self.output_encoding, + cwd=tmp_project_dir, + ) + + full_cmd = cmd + flags + logger.info("Trying to run the command:\n %s\nFrom %s", full_cmd, tmp_project_dir) logger.info("Using environment variables keys: %s", env.keys()) result = self.run_subprocess( diff --git a/tests/operators/test_local.py b/tests/operators/test_local.py index cbecdf450..6d58efe39 100644 --- a/tests/operators/test_local.py +++ b/tests/operators/test_local.py @@ -414,3 +414,46 @@ def test_calculate_openlineage_events_completes_openlineage_errors(mock_processo assert instance.parse.called err_msg = "Unable to parse OpenLineage events" assert err_msg in caplog.text + + +@pytest.mark.parametrize( + "operator_class,expected_template", + [ + (DbtSeedLocalOperator, ("env", "vars", "full_refresh")), + (DbtRunLocalOperator, ("env", "vars", "full_refresh")), + ], +) +def test_dbt_base_operator_template_fields(operator_class, expected_template): + # Check if value of template fields is what we expect for the operators we're validating + dbt_base_operator = operator_class(profile_config=profile_config, task_id="my-task", project_dir="my/dir") + assert dbt_base_operator.template_fields == expected_template + + +@patch("cosmos.operators.local.DbtLocalBaseOperator.store_compiled_sql") +@patch("cosmos.operators.local.DbtLocalBaseOperator.exception_handling") +@patch("cosmos.config.ProfileConfig.ensure_profile") +@patch("cosmos.operators.local.DbtLocalBaseOperator.run_subprocess") +def test_operator_execute_deps_parameters( + mock_build_and_run_cmd, mock_ensure_profile, mock_exception_handling, mock_store_compiled_sql +): + expected_call_kwargs = [ + "/usr/local/bin/dbt", + "deps", + "--profiles-dir", + "/path/to", + "--profile", + "default", + "--target", + "dev", + ] + task = DbtRunLocalOperator( + profile_config=real_profile_config, + task_id="my-task", + project_dir=DBT_PROJ_DIR, + install_deps=True, + emit_datasets=False, + dbt_executable_path="/usr/local/bin/dbt", + ) + mock_ensure_profile.return_value.__enter__.return_value = (Path("/path/to/profile"), {"ENV_VAR": "value"}) + task.execute(context={"task_instance": MagicMock()}) + assert mock_build_and_run_cmd.call_args_list[0].kwargs["command"] == expected_call_kwargs diff --git a/tests/operators/test_virtualenv.py b/tests/operators/test_virtualenv.py index 142a251a7..13dba8f94 100644 --- a/tests/operators/test_virtualenv.py +++ b/tests/operators/test_virtualenv.py @@ -60,7 +60,7 @@ def test_run_command( dbt_cmd = run_command_args[2] assert python_cmd[0][0][0].endswith("/bin/python") assert python_cmd[0][-1][-1] == "from importlib.metadata import version; print(version('dbt-core'))" - assert dbt_deps[0][0][-1] == "deps" + assert dbt_deps[0][0][1] == "deps" assert dbt_deps[0][0][0].endswith("/bin/dbt") assert dbt_deps[0][0][0] == dbt_cmd[0][0][0] assert dbt_cmd[0][0][1] == "do-something"