diff --git a/.changes/unreleased/Dependencies-20241113-112043.yaml b/.changes/unreleased/Dependencies-20241113-112043.yaml new file mode 100644 index 00000000000..cc477456787 --- /dev/null +++ b/.changes/unreleased/Dependencies-20241113-112043.yaml @@ -0,0 +1,6 @@ +kind: Dependencies +body: Bump minimum dbt-adapters version to 1.9.0 +time: 2024-11-13T11:20:43.25658-06:00 +custom: + Author: QMalcolm + Issue: "10996" diff --git a/.changes/unreleased/Fixes-20241112-210839.yaml b/.changes/unreleased/Fixes-20241112-210839.yaml new file mode 100644 index 00000000000..031e160f092 --- /dev/null +++ b/.changes/unreleased/Fixes-20241112-210839.yaml @@ -0,0 +1,6 @@ +kind: Fixes +body: Correct when custom microbatch macro deprecation warning is fired +time: 2024-11-12T21:08:39.866837-06:00 +custom: + Author: QMalcolm MichelleArk + Issue: "10994" diff --git a/core/dbt/parser/manifest.py b/core/dbt/parser/manifest.py index 6743bf5e6e7..fbfc83cd6c5 100644 --- a/core/dbt/parser/manifest.py +++ b/core/dbt/parser/manifest.py @@ -662,7 +662,7 @@ def check_for_microbatch_deprecations(self) -> None: has_microbatch_model = True break - if has_microbatch_model and self.manifest._microbatch_macro_is_core( + if has_microbatch_model and not self.manifest._microbatch_macro_is_core( self.root_project.project_name ): dbt.deprecations.warn("microbatch-macro-outside-of-batches-deprecation") diff --git a/core/setup.py b/core/setup.py index 456e5fedc15..8fdb2731a82 100644 --- a/core/setup.py +++ b/core/setup.py @@ -72,7 +72,7 @@ "dbt-semantic-interfaces>=0.7.4,<0.8", # Minor versions for these are expected to be backwards-compatible "dbt-common>=1.11.0,<2.0", - "dbt-adapters>=1.8.0,<2.0", + "dbt-adapters>=1.9.0,<2.0", # ---- # Expect compatibility with all new versions of these packages, so lower bounds only. "packaging>20.9", diff --git a/tests/functional/microbatch/test_microbatch.py b/tests/functional/microbatch/test_microbatch.py index b98ad38caa9..3de48225f44 100644 --- a/tests/functional/microbatch/test_microbatch.py +++ b/tests/functional/microbatch/test_microbatch.py @@ -182,19 +182,16 @@ def test_use_custom_microbatch_strategy_by_default( project, deprecation_catcher: EventCatcher, ): - with mock.patch.object( - type(project.adapter), "valid_incremental_strategies", lambda _: [] - ): - # Initial run - run_dbt(["run"]) + # Initial run fires deprecation + run_dbt(["run"], callbacks=[deprecation_catcher.catch]) + # Deprecation warning about custom microbatch macro fired + assert len(deprecation_catcher.caught_events) == 1 - # Incremental run uses custom strategy - _, logs = run_dbt_and_capture(["run"]) - assert "custom microbatch strategy" in logs - # The custom strategy wasn't used with batch functionality - assert "START batch" not in logs - # Deprecation warning about custom microbatch macro fired - assert len(deprecation_catcher.caught_events) == 0 + # Incremental run uses custom strategy + _, logs = run_dbt_and_capture(["run"]) + assert "custom microbatch strategy" in logs + # The custom strategy wasn't used with batch functionality + assert "START batch" not in logs class TestMicrobatchCustomUserStrategyProjectFlagTrueValid(BaseMicrobatchCustomUserStrategy): @@ -208,7 +205,9 @@ def test_use_custom_microbatch_strategy_project_flag_true_invalid_incremental_st ): # Initial run with patch_microbatch_end_time("2020-01-03 13:57:00"): - run_dbt(["run"]) + run_dbt(["run"], callbacks=[deprecation_catcher.catch]) + # Deprecation warning about custom microbatch macro not fired + assert len(deprecation_catcher.caught_events) == 0 # Incremental run uses custom strategy with patch_microbatch_end_time("2020-01-03 13:57:00"): @@ -216,11 +215,11 @@ def test_use_custom_microbatch_strategy_project_flag_true_invalid_incremental_st assert "custom microbatch strategy" in logs # The custom strategy was used with batch functionality assert "START batch" in logs - # Deprecation warning about custom microbatch macro not fired - assert len(deprecation_catcher.caught_events) == 0 -class TestMicrobatchCustomUserStrategyProjectFlagTrueInvalid(BaseMicrobatchCustomUserStrategy): +class TestMicrobatchCustomUserStrategyProjectFlagTrueNoValidBuiltin( + BaseMicrobatchCustomUserStrategy +): def test_use_custom_microbatch_strategy_project_flag_true_invalid_incremental_strategy( self, project ): @@ -228,10 +227,15 @@ def test_use_custom_microbatch_strategy_project_flag_true_invalid_incremental_st type(project.adapter), "valid_incremental_strategies", lambda _: [] ): # Run of microbatch model while adapter doesn't have a "valid" - # microbatch strategy causes an error to be raised + # microbatch strategy causes no error when behaviour flag set to true + # and there is a custom microbatch macro with patch_microbatch_end_time("2020-01-03 13:57:00"): - _, logs = run_dbt_and_capture(["run"], expect_pass=False) - assert "'microbatch' is not valid" in logs + _, logs = run_dbt_and_capture(["run"]) + assert "'microbatch' is not valid" not in logs + assert ( + "The use of a custom microbatch macro outside of batched execution is deprecated" + not in logs + ) class BaseMicrobatchTest: