From b7f353adc7f198c70bdc1aa46c25caa88bdbfb0c Mon Sep 17 00:00:00 2001 From: Matt Shaver <60105315+matthewshaver@users.noreply.github.com> Date: Wed, 8 May 2024 19:07:59 -0400 Subject: [PATCH] Deprecated functionality for v1.8 --- .../core-upgrade/01-upgrading-to-v1.8.md | 14 ++++++++++++++ .../core-upgrade/02-upgrading-to-v1.7.md | 15 +++++++++++++++ .../core-upgrade/03-upgrading-to-v1.6.md | 14 ++++++++++++++ 3 files changed, 43 insertions(+) diff --git a/website/docs/docs/dbt-versions/core-upgrade/01-upgrading-to-v1.8.md b/website/docs/docs/dbt-versions/core-upgrade/01-upgrading-to-v1.8.md index f9e3b95a97c..fffdfc87c49 100644 --- a/website/docs/docs/dbt-versions/core-upgrade/01-upgrading-to-v1.8.md +++ b/website/docs/docs/dbt-versions/core-upgrade/01-upgrading-to-v1.8.md @@ -78,6 +78,20 @@ models: The [`run`](/reference/commands/run#the-`--empty`-flag) and [`build`](/reference/commands/build#the---empty-flag) commands now support the `--empty` flag for building schema-only dry runs. The `--empty` flag limits the refs and sources to zero rows. dbt will still execute the model SQL against the target data warehouse but will avoid expensive reads of input data. This validates dependencies and ensures your models will build properly. +### Deprecated functionality + +The ability for installed packages to override built-in materializations without explicit opt-in from the user is being deprecated. + +- Overriding a built-in materialization from an installed package raises a deprecation warning. +- Using a custom materialization from an installed package does not raise a deprecation warning. +- Using a built-in materialization package override from the root project via a wrapping materialization is still supported. For example: + + ``` + {% materialization view, default %} + {{ return(my_cool_package.materialization_view_default()) }} + {% endmaterialization %} + ``` + ### Managing changes to legacy behaviors dbt Core v1.8 has introduced flags for [managing changes to legacy behaviors](/reference/global-configs/legacy-behaviors). You may opt into recently introduced changes (disabled by default), or opt out of mature changes (enabled by default), by setting `True` / `False` values, respectively, for `flags` in `dbt_project.yml`. diff --git a/website/docs/docs/dbt-versions/core-upgrade/02-upgrading-to-v1.7.md b/website/docs/docs/dbt-versions/core-upgrade/02-upgrading-to-v1.7.md index bf66673817f..ddda9de0141 100644 --- a/website/docs/docs/dbt-versions/core-upgrade/02-upgrading-to-v1.7.md +++ b/website/docs/docs/dbt-versions/core-upgrade/02-upgrading-to-v1.7.md @@ -30,6 +30,7 @@ This is a relatively small behavior change, but worth calling out in case you no Beginning with v1.7, running [`dbt deps`](/reference/commands/deps) creates or updates the `package-lock.yml` file in the _project_root_ where `packages.yml` is recorded. The `package-lock.yml` file contains a record of all packages installed and, if subsequent `dbt deps` runs contain no updated packages in `dependencies.yml` or `packages.yml`, dbt-core installs from `package-lock.yml`. + ## New and changed features and functionality - [`dbt docs generate`](/reference/commands/cmd-docs) now supports `--select` to generate [catalog metadata](/reference/artifacts/catalog-json) for a subset of your project. Currently available for Snowflake and Postgres only, but other adapters are coming soon. @@ -76,6 +77,20 @@ The run_results.json now includes three attributes related to the `applied` stat - `compiled_code`: Rendered string of the code that was compiled (empty after parsing, but full string after compiling). - `relation_name`: The fully-qualified name of the object that was (or will be) created/updated within the database. +### Deprecated functionality + +The ability for installed packages to override built-in materializations without explicit opt-in from the user is being deprecated. + +- Overriding a built-in materialization from an installed package raises a deprecation warning. +- Using a custom materialization from an installed package does not raise a deprecation warning. +- Using a built-in materialization package override from the root project via a wrapping materialization is still supported. For example: + + ``` + {% materialization view, default %} + {{ return(my_cool_package.materialization_view_default()) }} + {% endmaterialization %} + ``` + ### Quick hits diff --git a/website/docs/docs/dbt-versions/core-upgrade/03-upgrading-to-v1.6.md b/website/docs/docs/dbt-versions/core-upgrade/03-upgrading-to-v1.6.md index 01426d1b6ff..a989217b3cf 100644 --- a/website/docs/docs/dbt-versions/core-upgrade/03-upgrading-to-v1.6.md +++ b/website/docs/docs/dbt-versions/core-upgrade/03-upgrading-to-v1.6.md @@ -85,6 +85,20 @@ More consistency and flexibility around packages. Resources defined in a package [**Project dependencies**](/docs/collaborate/govern/project-dependencies): Introduces `dependencies.yml` and dependent `projects` as a feature of dbt Cloud Enterprise. Allows enforcing model access (public vs. protected/private) across project/package boundaries. Enables cross-project `ref` of public models, without requiring the installation of upstream source code. ::: +### Deprecated functionality + +The ability for installed packages to override built-in materializations without explicit opt-in from the user is being deprecated. + +- Overriding a built-in materialization from an installed package raises a deprecation warning. +- Using a custom materialization from an installed package does not raise a deprecation warning. +- Using a built-in materialization package override from the root project via a wrapping materialization is still supported. For example: + + ``` + {% materialization view, default %} + {{ return(my_cool_package.materialization_view_default()) }} + {% endmaterialization %} + ``` + ### Quick hits - [`state:unmodified` and `state:old`](/reference/node-selection/methods#the-state-method) for [MECE](https://en.wikipedia.org/wiki/MECE_principle) stateful selection