From 8463af35c3e9f09af94f3b334439b6f2358bc023 Mon Sep 17 00:00:00 2001 From: Gerda Shank Date: Mon, 20 Dec 2021 14:19:05 -0500 Subject: [PATCH] [#4523] Fix error with env_var in hook (#4524) --- CHANGELOG.md | 1 + core/dbt/context/providers.py | 10 ++++++---- test/integration/014_hook_tests/test_run_hooks.py | 3 +++ 3 files changed, 10 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b8b9616b7f6..b5e69dabab8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ - Issue better error message for incompatible schemas ([#4470](https://github.com/dbt-labs/dbt-core/pull/4442), [#4497](https://github.com/dbt-labs/dbt-core/pull/4497)) - Remove secrets from error related to packages. ([#4507](https://github.com/dbt-labs/dbt-core/pull/4507)) - Prevent coercion of boolean values (`True`, `False`) to numeric values (`0`, `1`) in query results ([#4511](https://github.com/dbt-labs/dbt-core/issues/4511), [#4512](https://github.com/dbt-labs/dbt-core/pull/4512)) +- Fix error with an env_var in a project hook ([#4523](https://github.com/dbt-labs/dbt-core/issues/4523), [#4524](https://github.com/dbt-labs/dbt-core/pull/4524)) ### Docs - Fix missing data on exposures in docs ([#4467](https://github.com/dbt-labs/dbt-core/issues/4467)) diff --git a/core/dbt/context/providers.py b/core/dbt/context/providers.py index 6f887ba9d98..3b0ff96d004 100644 --- a/core/dbt/context/providers.py +++ b/core/dbt/context/providers.py @@ -1186,10 +1186,12 @@ def env_var(self, var: str, default: Optional[str] = None) -> str: # If this is compiling, do not save because it's irrelevant to parsing. if self.model and not hasattr(self.model, 'compiled'): self.manifest.env_vars[var] = return_value - source_file = self.manifest.files[self.model.file_id] - # Schema files should never get here - if source_file.parse_file_type != 'schema': - source_file.env_vars.append(var) + # hooks come from dbt_project.yml which doesn't have a real file_id + if self.model.file_id in self.manifest.files: + source_file = self.manifest.files[self.model.file_id] + # Schema files should never get here + if source_file.parse_file_type != 'schema': + source_file.env_vars.append(var) return return_value else: msg = f"Env var required but not provided: '{var}'" diff --git a/test/integration/014_hook_tests/test_run_hooks.py b/test/integration/014_hook_tests/test_run_hooks.py index 7f1a38cd8df..f8d4858b627 100644 --- a/test/integration/014_hook_tests/test_run_hooks.py +++ b/test/integration/014_hook_tests/test_run_hooks.py @@ -1,4 +1,5 @@ from test.integration.base import DBTIntegrationTest, use_profile +import os class TestPrePostRunHooks(DBTIntegrationTest): @@ -22,6 +23,7 @@ def setUp(self): 'run_started_at', 'invocation_id' ] + os.environ['TERM_TEST'] = 'TESTING' @property def schema(self): @@ -41,6 +43,7 @@ def project_config(self): "{{ custom_run_hook('start', target, run_started_at, invocation_id) }}", "create table {{ target.schema }}.start_hook_order_test ( id int )", "drop table {{ target.schema }}.start_hook_order_test", + "{{ log(env_var('TERM_TEST'), info=True) }}", ], "on-run-end": [ "{{ custom_run_hook('end', target, run_started_at, invocation_id) }}",