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

[Bug]: snowflake_execute - context deadline exceeded duration #3334

Closed
1 task
fabiomx opened this issue Jan 9, 2025 · 8 comments
Closed
1 task

[Bug]: snowflake_execute - context deadline exceeded duration #3334

fabiomx opened this issue Jan 9, 2025 · 8 comments
Labels
feature-request Used to mark issues with provider's missing functionalities

Comments

@fabiomx
Copy link

fabiomx commented Jan 9, 2025

Terraform CLI Version

1.10.4

Terraform Provider Version

1.0.0

Company Name

No response

Terraform Configuration

terraform {
  required_providers {
    snowflake = {
      source  = "Snowflake-Labs/snowflake"
      version = "1.0.0"
    }
  }
}

provider "snowflake" {
  organization_name = "xxxx"
  account_name      = "xxxx"
  user              = "username"
  authenticator     = "SNOWFLAKE_JWT"
  private_key = file("~/path.p8")

  role                     = "role_name"
  warehouse                = "wh_name"
  preview_features_enabled = [
    "snowflake_dynamic_table_resource", "snowflake_file_format_resource", "snowflake_function_sql_resource", "snowflake_pipe_resource",
    "snowflake_procedure_python_resource", "snowflake_stage_resource",
    "snowflake_storage_integration_resource", "snowflake_table_resource"
  ]
  request_timeout = 1320 # 22mins # tested with no/other values, same issue
  driver_tracing = "trace"
}

# Context deadline test
resource "snowflake_execute" "context_deadline_test" {
 execute = "CALL SYSTEM$WAIT(22, 'MINUTES');"
 revert = "select 'context_deadline_test revert'"
}

Category

category:resource

Object type(s)

resource:execute

Expected Behavior

The query should be able to run for the necessary time, even if it's longer than 20 minutes.

Actual Behavior

Because of "context deadline exceeded duration 20m0" error (see attached log), the SQL query is canceled after 20 minutes.

I'm not sure if the issue depends on the provider, the Go driver, or even Snowflake itself (I'll comment on that later).

Obviously, the original query is not a SYSTEM$WAIT, but a real query that copies data through an "insert into..from" statement, and can take many minutes. In fact, a few weeks ago, I was able to run the same code on other tables without any problems, despite it taking over 20 minutes (it even reached over 60 minutes without issues).

It may be relevant to share that just last night, the same error appeared in our Grafana instance when connecting to Snowflake, which also uses the Go driver (client: failed to query data: Failed to query data: rpc error: code = DeadlineExceeded desc = context deadline exceeded).

On the other hand, the queries are executed correctly from another client (such as DataGrip via JDBC driver) and the same machine, so it's not an issue with account/user-level parameters, network connectivity, or machine-specific settings, which I've also reviewed.

Due to the uncertainty about the origin of the issue, I opened a ticket with Snowflake support, relating it to Go driver, but since the problem is also related to Terraform, which is not covered, they have dismissed it.

Steps to Reproduce

Add

resource "snowflake_execute" "context_deadline_test" {
 execute = "CALL SYSTEM$WAIT(22, 'MINUTES');"
 revert = "select 'context_deadline_test revert'"
}

and apply the resource

How much impact is this issue causing?

Medium

Logs

https://gist.github.com/fabiomx/dbcc757b635e227498526a50c415069a

Additional Information

No response

Would you like to implement a fix?

  • Yeah, I'll take it 😎
@fabiomx fabiomx added the bug Used to mark issues with provider's incorrect behavior label Jan 9, 2025
@sfc-gh-asawicki
Copy link
Collaborator

Hey @fabiomx. Thanks for reaching out to us.

Client timeout is one thing, but we also have to add custom timeouts directly to the resource (https://developer.hashicorp.com/terraform/language/resources/syntax#operation-timeouts).

We should add these to the next release. I will get back to you so you would be able to verify if that solves your problem.

@sfc-gh-asawicki sfc-gh-asawicki added feature-request Used to mark issues with provider's missing functionalities and removed bug Used to mark issues with provider's incorrect behavior labels Jan 9, 2025
@fabiomx
Copy link
Author

fabiomx commented Jan 9, 2025

Hi @sfc-gh-asawicki , thanks for getting back to me.

Yes, indeed I had noticed that this provider doesn't support adding custom timeouts directly to resources as described in the Terraform documentation. However, I'm still puzzled because, as mentioned before, I hadn't experienced any issues with timeouts until now, at least up to version 0.98.0.

Where are these 20-minute timeouts set? I couldn't find any reference to them in the provider's settings or Snowflake's parameters.

Also, do you have an estimated release date for the next version that will include the custom timeouts? I'd be happy to verify if it solves my problem.

Thank you

@sfc-gh-asawicki
Copy link
Collaborator

Hey @fabiomx.

These are the defaults: https://developer.hashicorp.com/terraform/plugin/sdkv2/resources/retries-and-customizable-timeouts#default-timeouts-and-deadline-exceeded-errors.

We should have the next patch on Thursday next week (16 Jan).

sfc-gh-asawicki added a commit that referenced this issue Jan 13, 2025
sfc-gh-asawicki added a commit that referenced this issue Jan 14, 2025
@sfc-gh-asawicki
Copy link
Collaborator

Hey @fabiomx. The release got postponed to Monday (20 Jan); We are sorry for the inconvenience.

sfc-gh-jcieslak pushed a commit that referenced this issue Jan 20, 2025
Run pre-push

Add timeouts to snowflake_execute

References: #3334

Add example to views data source documentation

References: #3203

Add resource monitors to grant ownership

References: #3318

Remove vacation notice from README

Extract okta URL to test vars

Add test showing tabs behavior for multiline

References: #3307
sfc-gh-jcieslak pushed a commit that referenced this issue Jan 20, 2025
Run pre-push

Add timeouts to snowflake_execute

References: #3334

Add example to views data source documentation

References: #3203

Add resource monitors to grant ownership

References: #3318

Remove vacation notice from README

Extract okta URL to test vars

Add test showing tabs behavior for multiline

References: #3307
sfc-gh-jcieslak pushed a commit that referenced this issue Jan 20, 2025
Fixes:
- add missing resource monitor as valid option to `snowflake_grant_ownership` (references: [#3318](#3318))
- clarify docs for `snowflake_views` (references: [#3203](#3203))
- add timeouts to `snowflake_execute` (references: [#3334](#3334))

Misc (mostly regarding acceptance tests):
- remove vacations notice from readme
- document current behavior of multiline attributes in cofig generators when there is whitespace (like `\t`); result of #3307 (comment)
- extract okta url to test data
sfc-gh-jcieslak pushed a commit that referenced this issue Jan 20, 2025
Fixes:
- add missing resource monitor as valid option to `snowflake_grant_ownership` (references: [#3318](#3318))
- clarify docs for `snowflake_views` (references: [#3203](#3203))
- add timeouts to `snowflake_execute` (references: [#3334](#3334))

Misc (mostly regarding acceptance tests):
- remove vacations notice from readme
- document current behavior of multiline attributes in cofig generators when there is whitespace (like `\t`); result of #3307 (comment)
- extract okta url to test data
sfc-gh-jcieslak pushed a commit that referenced this issue Jan 20, 2025
Fixes:
- add missing resource monitor as valid option to `snowflake_grant_ownership` (references: [#3318](#3318))
- clarify docs for `snowflake_views` (references: [#3203](#3203))
- add timeouts to `snowflake_execute` (references: [#3334](#3334))

Misc (mostly regarding acceptance tests):
- remove vacations notice from readme
- document current behavior of multiline attributes in cofig generators when there is whitespace (like `\t`); result of #3307 (comment)
- extract okta url to test data
@fabiomx
Copy link
Author

fabiomx commented Jan 20, 2025

Hi @sfc-gh-asawicki ,

I would like to comment that I just had the same problem with snowflake_dynamic_table. It is a resource that, depending on the volume of data, may also require a longer timeout to be created. Please, let me know if I need to create another issue.

Thank you

@sfc-gh-asawicki
Copy link
Collaborator

Hey @fabiomx, we added timeouts to the v1.0.2 release. Please check it out and let us know.

Regarding the dynamic table: please create a separate issue.

@fabiomx
Copy link
Author

fabiomx commented Jan 22, 2025

Hey @sfc-gh-asawicki ,

It worked, thank you :)

@sfc-gh-asawicki
Copy link
Collaborator

Great to hear that! I'm closing the issue then.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature-request Used to mark issues with provider's missing functionalities
Projects
None yet
Development

No branches or pull requests

2 participants