From a2355f53a6612793efdd36bd7a2782ff77efa9cb Mon Sep 17 00:00:00 2001 From: Jakub Michalak Date: Fri, 20 Dec 2024 14:29:33 +0100 Subject: [PATCH] Add migration guide, fix --- MIGRATION_GUIDE.md | 45 +++++++++++++++++++++++++++++++++++++++ pkg/sdk/parameters.go | 2 +- pkg/sdk/tasks_gen_test.go | 4 ++-- 3 files changed, 48 insertions(+), 3 deletions(-) diff --git a/MIGRATION_GUIDE.md b/MIGRATION_GUIDE.md index 3ecf522a66..005f3992ed 100644 --- a/MIGRATION_GUIDE.md +++ b/MIGRATION_GUIDE.md @@ -7,6 +7,51 @@ across different versions. > [!TIP] > We highly recommend upgrading the versions one by one instead of bulk upgrades. +## v1.0.0 ➞ v1.0.1 + +### Fixes in account parameters +As a follow-up of reworked `snowflake_account_parameter`, this version has several improvements regarding handling parameters. + +#### Add missing parameters based on the docs and output of SHOW PARAMETERS IN ACCOUNT +Based on [parameters docs](https://docs.snowflake.com/en/sql-reference/parameters) and `SHOW PARAMETERS IN ACCOUNT`, we established a list of supported parameters. New supported or fixed parameters in `snowflake_account_parameter`: +- `ACTIVE_PYTHON_PROFILER` +- `CLIENT_ENABLE_LOG_INFO_STATEMENT_PARAMETERS` +- `CORTEX_ENABLED_CROSS_REGION` +- `CSV_TIMESTAMP_FORMAT` +- `ENABLE_PERSONAL_DATABASE` +- `ENABLE_UNHANDLED_EXCEPTIONS_REPORTING` +- `ENFORCE_NETWORK_RULES_FOR_INTERNAL_STAGES` +- `HYBRID_TABLE_LOCK_TIMEOUT` +- `JS_TREAT_INTEGER_AS_BIGINT` +- `PREVENT_UNLOAD_TO_INLINE_URL` +- `PREVENT_UNLOAD_TO_INTERNAL_STAGES` +- `PYTHON_PROFILER_MODULES` +- `PYTHON_PROFILER_TARGET_STAGE` +- `STORAGE_SERIALIZATION_POLICY` +- `TASK_AUTO_RETRY_ATTEMPTS` + +#### Adjusted validations +Validations for number parameters are now relaxed. This is because a few of the value limits are soft limits in Snowflake, and can be changed externally. +We decided to keep validations for non-negative values. Affected parameters: +- `QUERY_TAG` +- `TWO_DIGIT_CENTURY_START` +- `WEEK_OF_YEAR_POLICY` +- `WEEK_START` +- `USER_TASK_TIMEOUT_MS` + +We added non-negative validations for the following parameters: +- `CLIENT_PREFETCH_THREADS` +- `CLIENT_RESULT_CHUNK_SIZE` +- `CLIENT_SESSION_KEEP_ALIVE_HEARTBEAT_FREQUENCY` +- `HYBRID_TABLE_LOCK_TIMEOUT` +- `JSON_INDENT` +- `STATEMENT_QUEUED_TIMEOUT_IN_SECONDS` +- `STATEMENT_TIMEOUT_IN_SECONDS` +- `TASK_AUTO_RETRY_ATTEMPTS` +- `USER_TASK_MINIMUM_TRIGGER_INTERVAL_IN_SECONDS` + +Note that enum parameters are still not validated by the provider - they are only validated in Snowflake. We will handle this during a small rework of the parameters in the future. + ## v0.100.0 ➞ v1.0.0 ### Preview features flag diff --git a/pkg/sdk/parameters.go b/pkg/sdk/parameters.go index fb65e84eef..86551dd14e 100644 --- a/pkg/sdk/parameters.go +++ b/pkg/sdk/parameters.go @@ -1530,7 +1530,7 @@ func (v *SessionParameters) validate() error { } if valueSet(v.JsonIndent) { if !validateIntGreaterThanOrEqual(*v.JsonIndent, 0) { - errs = append(errs, errIntValue("SessionParameters", "JsonIndent", IntErrGreaterOrEqual, 16)) + errs = append(errs, errIntValue("SessionParameters", "JsonIndent", IntErrGreaterOrEqual, 0)) } } if valueSet(v.LockTimeout) { diff --git a/pkg/sdk/tasks_gen_test.go b/pkg/sdk/tasks_gen_test.go index 38cff4f5f6..56b8fe4c6f 100644 --- a/pkg/sdk/tasks_gen_test.go +++ b/pkg/sdk/tasks_gen_test.go @@ -45,9 +45,9 @@ func TestTasks_Create(t *testing.T) { t.Run("validation: opts.SessionParameters.SessionParameters should be valid", func(t *testing.T) { opts := defaultOpts() opts.SessionParameters = &SessionParameters{ - JsonIndent: Int(25), + JsonIndent: Int(-1), } - assertOptsInvalidJoinedErrors(t, opts, errIntBetween("SessionParameters", "JSONIndent", 0, 16)) + assertOptsInvalidJoinedErrors(t, opts, errIntValue("SessionParameters", "JsonIndent", IntErrGreaterOrEqual, 0)) }) t.Run("basic", func(t *testing.T) {