Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature] Support pre-flight checks for dbt model contacts on dynamic tables #888

Open
2 tasks done
awal11 opened this issue Jan 17, 2024 · 11 comments
Open
2 tasks done

Comments

@awal11
Copy link

awal11 commented Jan 17, 2024

Is this a new bug in dbt-snowflake?

  • I believe this is a new bug in dbt-snowflake
  • I have searched the existing issues, and I could not find an existing issue for this bug

Current Behavior

When I deploy models materialized as table or view - the contract is verified and in case of discrepancy I receive the expected error

Compilation Error in model your_model (models\your_model_v1.sql)
This model has an enforced contract that failed.
Please ensure the name, data_type, and number of columns in your contract match the columns in your model's definition.

When I deploy models materialized as dynamic_table - the contract verification does not seem to happen, so can I release things that have not been vetted and can violate the contract.

This behavior is completely unexpected and when unnoticed will have nasty consequences discovered only on target environment (as was my case).

Expected Behavior

The models deployed as dynamic_tables should have the contract enforced, similarly to other materializations.

At minimum - there should be some warning emitted that this is not the case for dynamic tables

Steps To Reproduce

  1. take a simple model with enforced contract
  2. break the contract, eg by renaming one of the columns in model
  3. observe that the deployment fails properly when materialization is set to 'table'
  4. observe that it passes without error when materialization is set to 'dynamic_table' no matter if you use --full-refresh or not

Relevant log output

No response

Environment

- OS:Windows 10
- Python:3.10.5
- dbt-core: 1.7.4
- dbt-snowflake: 1.7.1

Additional Context

No response

@awal11 awal11 added type:bug Something isn't working triage:product labels Jan 17, 2024
@github-actions github-actions bot changed the title [Bug] Contract enforced is ignored when using dynamic tables [ADAP-1095] [Bug] Contract enforced is ignored when using dynamic tables Jan 17, 2024
@mikealfare
Copy link
Contributor

Dynamic tables do not currently support model contracts. Please see the docs for more information. I'll reclassify this as an enhancement in the meantime. Hopefully this is a feature that we can take on soon.

@mikealfare mikealfare added type:enhancement New feature or request refinement and removed type:bug Something isn't working triage:product labels Feb 2, 2024
@awal11
Copy link
Author

awal11 commented Feb 6, 2024

The typical flow of working with contract would be that you start working with View or Table and only then switch to Dynamic Table (especially that it's not GA in Snowflake yet), so that limitation mentioned in Contract documentation is something that I missed completely.

Ideally it could be mentioned here as well https://docs.getdbt.com/reference/resource-configs/snowflake-configs#limitations

@mikealfare
Copy link
Contributor

mikealfare commented Feb 8, 2024

Ideally it could be mentioned here as well https://docs.getdbt.com/reference/resource-configs/snowflake-configs#limitations

That's fair. I'll open a docs ticket for that. This ticket (888) will pertain to the actual implementation of of model contracts for DTs.

@mikealfare mikealfare changed the title [ADAP-1095] [Bug] Contract enforced is ignored when using dynamic tables [Feature] Contract enforced is ignored when using dynamic tables Feb 8, 2024
@mikealfare mikealfare changed the title [Feature] Contract enforced is ignored when using dynamic tables [Feature] Implement model contracts for dynamic tables Feb 8, 2024
@colin-rogers-dbt
Copy link
Contributor

We also want to incorporate sanity testing cases into completing this issue

@amychen1776
Copy link

Closing this because we did update the docs

@awal11
Copy link
Author

awal11 commented Aug 27, 2024

@amychen1776 - not sure if closing is the right thing - updating docs (saying it's not working) was a separate issue (dbt-labs/docs.getdbt.com#4869), but ultimately the contract verification should be implemented for Dynamic Tables as well, especially that its GA on Snowflake already.

@amychen1776
Copy link

Ah you're right - I was skimming and misread the above message. Will reopen now

@amychen1776 amychen1776 reopened this Aug 27, 2024
@amychen1776
Copy link

@awal11 I just dug into this and we had a conversation with the Snowflake team about this. Contract verification is not supported for Dynamic tables. While I tried to reproduce on snowsight, I get this error message
image

Which the Snowflake DT confirmed is expected. Do you have information otherwise?

@awal11
Copy link
Author

awal11 commented Aug 28, 2024

@amychen1776 - hmm, now I am confused....
By contract verification I understand the dbt functionality described as:

dbt will run a "preflight" check to ensure that the model's query will return a set of columns with names and data types matching the ones you have defined.

and to my understanding this is rather an internal dbt check against metadata, similar to what already happens with views or tables, so I really do not understand how your screenshot is related to it...

@amychen1776 amychen1776 changed the title [Feature] Implement model contracts for dynamic tables [Feature] Support pre-flight checks for dbt model contacts on dynamic tables Aug 29, 2024
@amychen1776
Copy link

Okay, @dbeatty10 dug into this and validated that we can do pre-flight checks separately from applying model constraints despite the fact that they're defined in the same place. We don't have capacity in the short term to tackle this but we will scope this out for our next quarter.

@amychen1776
Copy link

@colin-rogers-dbt a note for when we refine this - we should scope this out to support MVs on the other adapters.

mirnawong1 pushed a commit to dbt-labs/docs.getdbt.com that referenced this issue Aug 30, 2024
…5993)

[Preview](https://docs-getdbt-com-git-dbeatty10-patch-1-dbt-labs.vercel.app/docs/collaborate/govern/model-contracts#where-are-contracts-supported)

## What are you changing in this pull request and why?
- It isn't clear if materialized views have support for model contracts
or not.
- Also not clear if custom materializations automatically include
support for model contracts or not.

Context: dbt-labs/dbt-snowflake#888 (`dynamic
table` is the Snowflake equivalent of `materialized view` in other data
platforms)

## Checklist
- [x] I have reviewed the [Content style
guide](https://github.com/dbt-labs/docs.getdbt.com/blob/current/contributing/content-style-guide.md)
so my content adheres to these guidelines.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

6 participants