Sugar Config

where dbt-sugar's sweetness lives.

The sugar_config.yml contains all the information necessary for dbt-sugar to know how to deal with your dbt models as well as setting up behavioural settings for dbt-sugar.

The sugar_config.yml holds what we call "syrups".

What are syrups?

Syrups are dbt-sugars configurations profiles. You may only have one if you maintain only one dbt project, but you may have as many as you need if your setup interacts with different dbt projects for which you want different sets of controls.

The sugar_config.yml looks something like this:

defaults:
  syrup: syrup_1
  target: dev
syrups:
  - name: syrup_1
    dbt_projects:
      - name: dbt_sugar_test
        path: "./tests/test_dbt_project/dbt_sugar_test"
        excluded_tables:
          - table_a

For now, dbt-sugar can only manage one dbt project per syrup. It is a known limitation and we plan to allow support for multiple projects (hence the use of plural) in a later feature release. Stay tuned!

defaults

The defaults section allows you to declare which of the syrups you would like dbt-sugar to use as default so that you do not have to pass the --syrup CLI argument for the run type that you plan to execute most of the time.

syrups

Syrups are a list of entries made of a name which is how you will refer to the syrup you want dbt-sugar to use at runtime. Each syrup entry is made of a list of dbt_projects. This is how you tell dbt-sugar where to find the dbt project you want it to sugar coat. It must contain the name of your dbt project and a path to that dbt project. It can also contain a series of other settings, which are listed below:

excluded_tables:

You may have a use case where you do not want dbt-sugar to consider some of your dbt models (tables). You can simply list those and dbt-sugar will ignore everything about it. For example, it will not attempt to document it, nor will it look up its definitions, tests, and tags in the case where you want to homogenise column definitions across all your dbt models.

excluded_folders:

A bit like excluded_tables but to exclude entire folders.

use_describe_snowflake:

Only applies to Snowflake warehouse users. Experimental!

New in v0.1.0

If you're using Snowflake as your warehouse and have large schemas or tables, dbt-sugar might take a while to get all the information from your warehouse's information_schema. That is because the developers of the Snowflake SQLAlchemy plugin have opted for a slower method to get columns from a table (see https://github.com/snowflakedb/snowflake-sqlalchemy/issues/221 and https://github.com/bitpicky/dbt-sugar/issues/211).

We therefore decided to allow users to opt in for an experimental alternative that uses describe table instead of select from information_schema. Set this argument to true and dbt-sugar will use this method from now on. Needs to be set at the dbt_projects level of your syrups (as shown below):

defaults:
  syrup: syrup_1
  target: dev
syrups:
  - name: syrup_1
    dbt_projects:
      - name: dbt_sugar_test
        path: "./tests/test_dbt_project/dbt_sugar_test"
        excluded_tables:
          - table_a
        use_describe_snowflake: true

preserve_yaml_order:

New in v0.1.0

If you have comments in your schema.yaml files and you want to make sure that dbt-sugar does not delete them as part of its default behaviour to order models and columns alphabetically, you can choose to turn off this behaviour by setting the preserve_yaml_order config variable to false. This will make sure all your comments (inline or blocks) are preserved when we write back into your yaml file.

Last updated

Was this helpful?