From 8904cf07aa16e69d2c4b9bcfc9b24132be095f10 Mon Sep 17 00:00:00 2001 From: Emily Rockman Date: Fri, 26 Apr 2024 13:25:15 -0500 Subject: [PATCH] [Backport 1.7.latest] convert SECRET_ENV_PREFIX from DBT_ENV_SECRET_ to DBT_ENV_SECRET (#10052) * convert SECRET_ENV_PREFIX from DBT_ENV_SECRET_ to DBT_ENV_SECRET * changelog # Conflicts: # tests/functional/context_methods/test_secret_env_vars.py --- .../unreleased/Under the Hood-20240426-090222.yaml | 6 ++++++ core/dbt/constants.py | 2 +- core/dbt/context/secret.py | 2 +- tests/functional/context_methods/test_env_vars.py | 4 ++-- .../context_methods/test_secret_env_vars.py | 14 +++++++------- tests/functional/partial_parsing/test_pp_vars.py | 6 +++--- 6 files changed, 20 insertions(+), 14 deletions(-) create mode 100644 .changes/unreleased/Under the Hood-20240426-090222.yaml diff --git a/.changes/unreleased/Under the Hood-20240426-090222.yaml b/.changes/unreleased/Under the Hood-20240426-090222.yaml new file mode 100644 index 00000000000..6727a4ee761 --- /dev/null +++ b/.changes/unreleased/Under the Hood-20240426-090222.yaml @@ -0,0 +1,6 @@ +kind: Under the Hood +body: Remove the final underscore from secret environment variable constants. +time: 2024-04-26T09:02:22.481158-05:00 +custom: + Author: emmyoop + Issue: "10052" diff --git a/core/dbt/constants.py b/core/dbt/constants.py index f52ac23fefe..394d34fd818 100644 --- a/core/dbt/constants.py +++ b/core/dbt/constants.py @@ -1,4 +1,4 @@ -SECRET_ENV_PREFIX = "DBT_ENV_SECRET_" +SECRET_ENV_PREFIX = "DBT_ENV_SECRET" DEFAULT_ENV_PLACEHOLDER = "DBT_DEFAULT_PLACEHOLDER" METADATA_ENV_PREFIX = "DBT_ENV_CUSTOM_ENV_" diff --git a/core/dbt/context/secret.py b/core/dbt/context/secret.py index 4d8ff342aff..a2f4bb3226e 100644 --- a/core/dbt/context/secret.py +++ b/core/dbt/context/secret.py @@ -21,7 +21,7 @@ def env_var(self, var: str, default: Optional[str] = None) -> str: If the default is None, raise an exception for an undefined variable. - In this context *only*, env_var will accept env vars prefixed with DBT_ENV_SECRET_. + In this context *only*, env_var will accept env vars prefixed with DBT_ENV_SECRET. It will return the name of the secret env var, wrapped in 'start' and 'end' identifiers. The actual value will be subbed in later in SecretRenderer.render_value() """ diff --git a/tests/functional/context_methods/test_env_vars.py b/tests/functional/context_methods/test_env_vars.py index 506ed40d31c..20600fd9b60 100644 --- a/tests/functional/context_methods/test_env_vars.py +++ b/tests/functional/context_methods/test_env_vars.py @@ -55,13 +55,13 @@ def setup(self): os.environ["DBT_TEST_ENV_VAR"] = "1" os.environ["DBT_TEST_USER"] = "root" os.environ["DBT_TEST_PASS"] = "password" - os.environ[SECRET_ENV_PREFIX + "SECRET"] = "secret_variable" + os.environ[SECRET_ENV_PREFIX + "_SECRET"] = "secret_variable" os.environ["DBT_TEST_NOT_SECRET"] = "regular_variable" os.environ["DBT_TEST_IGNORE_DEFAULT"] = "ignored_default" yield del os.environ["DBT_TEST_ENV_VAR"] del os.environ["DBT_TEST_USER"] - del os.environ[SECRET_ENV_PREFIX + "SECRET"] + del os.environ[SECRET_ENV_PREFIX + "_SECRET"] del os.environ["DBT_TEST_NOT_SECRET"] del os.environ["DBT_TEST_IGNORE_DEFAULT"] diff --git a/tests/functional/context_methods/test_secret_env_vars.py b/tests/functional/context_methods/test_secret_env_vars.py index a95c20b7f91..3a084e668de 100644 --- a/tests/functional/context_methods/test_secret_env_vars.py +++ b/tests/functional/context_methods/test_secret_env_vars.py @@ -73,13 +73,13 @@ def test_disallow_secret(self, project): class TestAllowSecretProfilePackage(FirstDependencyProject): @pytest.fixture(scope="class", autouse=True) def setup(self): - os.environ[SECRET_ENV_PREFIX + "USER"] = "root" - os.environ[SECRET_ENV_PREFIX + "PASS"] = "password" - os.environ[SECRET_ENV_PREFIX + "PACKAGE"] = "first_dependency" + os.environ[SECRET_ENV_PREFIX + "_USER"] = "root" + os.environ[SECRET_ENV_PREFIX + "_PASS"] = "password" + os.environ[SECRET_ENV_PREFIX + "_PACKAGE"] = "first_dependency" yield - del os.environ[SECRET_ENV_PREFIX + "USER"] - del os.environ[SECRET_ENV_PREFIX + "PASS"] - del os.environ[SECRET_ENV_PREFIX + "PACKAGE"] + del os.environ[SECRET_ENV_PREFIX + "_USER"] + del os.environ[SECRET_ENV_PREFIX + "_PASS"] + del os.environ[SECRET_ENV_PREFIX + "_PACKAGE"] @pytest.fixture(scope="class") def models(self): @@ -114,7 +114,7 @@ def test_allow_secrets(self, project, first_dependency): class TestCloneFailSecretScrubbed: @pytest.fixture(scope="class", autouse=True) def setup(self): - os.environ[SECRET_ENV_PREFIX + "GIT_TOKEN"] = "abc123" + os.environ[SECRET_ENV_PREFIX + "_GIT_TOKEN"] = "abc123" @pytest.fixture(scope="class") def models(self): diff --git a/tests/functional/partial_parsing/test_pp_vars.py b/tests/functional/partial_parsing/test_pp_vars.py index 2e89e526026..8ff3a60ee80 100644 --- a/tests/functional/partial_parsing/test_pp_vars.py +++ b/tests/functional/partial_parsing/test_pp_vars.py @@ -358,7 +358,7 @@ def dbt_profile_target(self): # user is secret and password is not. postgres on macos doesn't care if the password # changes so we have to change the user. related: https://github.com/dbt-labs/dbt-core/pull/4250 - os.environ[SECRET_ENV_PREFIX + "USER"] = "root" + os.environ[SECRET_ENV_PREFIX + "_USER"] = "root" os.environ["ENV_VAR_PASS"] = "password" return { "type": "postgres", @@ -373,7 +373,7 @@ def dbt_profile_target(self): def test_profile_secret_env_vars(self, project): # Initial run - os.environ[SECRET_ENV_PREFIX + "USER"] = "root" + os.environ[SECRET_ENV_PREFIX + "_USER"] = "root" os.environ["ENV_VAR_PASS"] = "password" results = run_dbt(["run"]) @@ -381,7 +381,7 @@ def test_profile_secret_env_vars(self, project): env_vars_checksum = manifest.state_check.profile_env_vars_hash.checksum # Change a secret var, it shouldn't register because we shouldn't save secrets. - os.environ[SECRET_ENV_PREFIX + "USER"] = "fake_user" + os.environ[SECRET_ENV_PREFIX + "_USER"] = "fake_user" # we just want to see if the manifest has included # the secret in the hash of environment variables. (results, log_output) = run_dbt_and_capture(["run"], expect_pass=True)