-
Notifications
You must be signed in to change notification settings - Fork 427
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
[Bug]: Table Column Updates are not recognized by Terraform Provider #3007
Comments
Hey @JESCHO99. Thanks for raising this issue. Unfortunately, this is a known error that affects multiple resources, not only tables (e.g., check #2735). Long story short: data types with arguments (like VARCHAR(3) and VARCHAR(200)) are not always handled properly. In this case, they are both synonymized to check if the type changed, but their length is not taken into consideration, so the diff is suppressed incorrectly. We should start working on procedures and functions next week, so the datatype topic will be addressed then. Before that, we can add a hotfix to handle properly at least changes to VARCHAR length in the table resource. The hotfix won't make it probably into the next release (tomorrow or on Friday) but should be ready next week. |
I will also make sure it's added to the known issues/limitations in our FAQ (https://github.com/Snowflake-Labs/terraform-provider-snowflake/blob/main/CREATING_ISSUES.md#commonly-known-issues). |
Hey @sfc-gh-asawicki, thanks for the reply. A Hotfix for Varchar Fields in the next week would help a lot. If possible it would be great if NUMBER fields could be added to the Hotfix too. Those are the two data types mainly used in our environments. Thanks for your help! |
Hey @JESCHO99. I think we can include numbers, too; I will confirm next week. |
…ce (only for text and number types) References: #3007
Hey @JESCHO99. I have prepared a fix both for text and number columns in #3020. It will be released as part of v0.95.0 today or tomorrow (we have to wrap a few other pull requests before making the release). |
Hey @JESCHO99, we had to postpone the v0.95.0 release to Monday, sorry for the inconvenience. |
Hey @sfc-gh-asawicki , no problem and thanks for the information. As there was no release yesterday I just wanted to ask if it will come during this week or is planned much later right now? |
Hey. Yeah, we have unfortunately faced a few unexpected issues with the underlying library while working on the fix (#3032) that we really want to include in this release. Currently, we estimate the release will happen late today or early tomorrow. I'll keep you posted. |
Hey @JESCHO99 . |
Hey @JESCHO99, did you validate the fix? If so, can we close the issue? |
Closing as the fix was provided. Please file a new issue if there are any problems in the newest provider version. |
Terraform CLI Version
1.5.7
Terraform Provider Version
0.94.1
Terraform Configuration
Category
category:resource
Object type(s)
resource:table
Expected Behavior
The code provided above could be applied to a Snowflake Account without any problem. If you change the data type of a column for example change the "type" of the column "NAME" in the snowflake table "TEST_TABLE_V2" to "VARCHAR(3)" the next terraform plan should recognize this change and provide a plan how this change could be applied to the backend.
Actual Behavior
Even if the resource block for the snowflake table "table_2" is changed the terraform plan running on the changed code shows no changes. Terraform does not recognize that there should be a change on the data type of the column.
Steps to Reproduce
resource "snowflake_database" "this" {
name = "TEST_DATABASE"
}
resource "snowflake_schema" "this" {
database = snowflake_database.this.name
name = "TEST_SCHEMA"
is_transient = "false"
with_managed_access = "false"
data_retention_time_in_days = 1
}
resource "snowflake_table" "table_1" {
database = snowflake_database.this.name
schema = snowflake_schema.this.name
name = "TEST_TABLE_V1"
data_retention_time_in_days = 1
change_tracking = false
column {
name = "ID"
type = "NUMBER"
}
column {
name = "NAME"
type = "VARCHAR(3)"
}
}
resource "snowflake_table" "table_2" {
database = snowflake_database.this.name
schema = snowflake_schema.this.name
name = "TEST_TABLE_V2"
data_retention_time_in_days = 1
change_tracking = false
column {
name = "ID"
type = "NUMBER(11,2)"
}
column {
name = "NAME"
type = "VARCHAR(255)"
}
}
Run
terraform apply
to a Snowflake AccountChange the resource block "snowflake_table" "table_2" like this:
resource "snowflake_table" "table_2" {
database = snowflake_database.this.name
schema = snowflake_schema.this.name
name = "TEST_TABLE_V2"
data_retention_time_in_days = 1
change_tracking = false
column {
name = "ID"
type = "NUMBER(11,2)"
}
column {
name = "NAME"
type = "VARCHAR(3)"
}
}
How much impact is this issue causing?
High
Logs
No response
Additional Information
It would be great if you could provide us with an estimation when this issue could be fixed. We tested around with various provider versions and found out that this issue appears the first time in version "0.90.0". In version "0.89.0" the terraform plan showed changes as expected.
We plan to have huge changes during the next three weeks. If it is not possible to provide a hotfix we need to downgrade our current terraform project. Thanks for your help!
Would you like to implement a fix?
The text was updated successfully, but these errors were encountered: