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

Add fully fledged time zones support #200

Open
slvrtrn opened this issue Oct 18, 2023 · 18 comments · Fixed by #253
Open

Add fully fledged time zones support #200

slvrtrn opened this issue Oct 18, 2023 · 18 comments · Fixed by #253
Labels
enhancement New feature or request

Comments

@slvrtrn
Copy link
Collaborator

slvrtrn commented Oct 18, 2023

Despite ClickHouse itself featuring great time zone(s) support, these two driver features were never enabled:

:set-timezone
:convert-timezone

There was a draft attempt from me recently, with this snippet commented out and a few other parts missing:

;; FIXME: there are still many failing tests that prevent us from turning this feature on
;; (defmethod sql.qp/->honeysql [:clickhouse :convert-timezone]
;; [driver [_ arg target-timezone source-timezone]]
;; (let [expr (sql.qp/->honeysql driver (cond-> arg (string? arg) u.date/parse))
;; with-tz-info? (h2x/is-of-type? expr #"(?:nullable\(|lowcardinality\()?(datetime64\(\d, {0,1}'.*|datetime\(.*)")
;; _ (sql.u/validate-convert-timezone-args with-tz-info? target-timezone source-timezone)
;; inner (if (not with-tz-info?) [:'toTimeZone expr source-timezone] expr)]
;; [:'toTimeZone inner target-timezone]))

However, a significant amount of Metabase timezone-related tests fail, most of the time because of hardcoded branches for specific drivers.

Examples of such tests:

Related Metabase issue to remove the hardcoded parts: metabase/metabase#26807

@mattdavenport
Copy link

Any updates on this one? I don't have enough clojure knowledge to pitch in unfortunately. I'm running into this issue where I have:

Clickhouse - UTC
Metabase - US/Eastern
JVM - US/Eastern

I have a value when queried in Clickhouse (UTC) is: 2020-03-22 22:08:28
I can do a SELECT toTimezone(created_at, 'US/Eastern') in Clickhouse to return: 2020-03-22 18:08:28

However in Metabase, when I select this same record, I'm showing the UTC time (March 22, 2020 10:08PM). I believe this is a related issue, but also wanting to check and see if there is another setting somewhere I'm missing.

Thanks!

@slvrtrn
Copy link
Collaborator Author

slvrtrn commented Mar 14, 2024

Hi @mattdavenport, no updates yet. However, as you are interested in this feature, we might reconsider our priorities.

Let me explain why this was postponed in more detail.

The driver runs the entire set of Metabase tests (5000+ tests, 39000+ assertions as of 0.49.x), aiming for 100% green CI run there, as it tests most of the things in and out, allowing us to mostly rely on these, writing specific tests for the driver only when it is necessary (this is still quite a lot, you can see it in the sources).

However, even though I think I have a working driver code for the fully-fledged timezones support (I briefly checked it from the UI, and it seemed to be working), there are a lot of timezone tests with hardcoded assertions for certain built-in drivers. Sometimes, the ClickHouse output, while being correct, is slightly different from the assertion there (it could be as minor as a few extra zeroes after the dot in the ISO formatted string or whatever else), and this causes the entire test to fail. It is also impossible to fix all of them, as one workaround could cause another test to fail (with another minor "cosmetic" discrepancy), and so on.

There are dozens of such test cases (you can see the code examples links in the OP), and we can disable them, but it will require rewriting comparable tests adjusted to the driver in this repo. This is very time-consuming, and that was the main reason why it was postponed. Additionally, this is the exact reason why the Metabase timezones feature was always disabled in this driver. Here's a link to the Metabase issue about these hardcoded tests.

Regarding your situation - yes, this is certainly a related issue. Unless everything (JVM, CH, Metabase) is forced into the same timezone, there might be discrepancies, just like the one you mentioned.

If it is impossible to switch to the same timezone everywhere, which will ensure proper UI results, we can think about a release where we could do the following:

  • Disable Metabase timezones tests
  • Write a few select test cases in the driver code covering the most dangerous parts
  • Allow timezone features in the driver to be enabled via an environment variable or similar.

This has a chance of working properly; however, we cannot consider it stable until it 100% passes the entire Metabase test set.

Please let me know what you think.

CC @mshustov (we discussed that only recently).

@mattdavenport
Copy link

@slvrtrn Thanks for the detailed explanation! That makes a lot of sense. Perhaps Allow timezone features in the driver to be enabled via an environment variable or similar. could be a way to enable this "experimental" behavior that is documented unstable but usable at the moment. This could open up the new functionality without effectively changing the core behavior, but would likely need to remain untested until the referenced Metabase issue is resolved. It looks like there is some relatively recent activity on that ticket, so it may also be best to wait if your nudge to increase priority has any effect.

Thanks again for all of the work you all put in here and on Clickhouse. Very impressive stuff!

@adityapatadia
Copy link

This is a problem for us in production. Can we get this prioritised?

@dimitriosp
Copy link

dimitriosp commented May 16, 2024

Not sure if this is related, however when I try to set the REPORT TIMEZONE in metabase-cloud, it does not show the correct timezone. For the postgres(supabase) driver, this is working.
If not related, i will create a new ticket.

image
image
image

@slvrtrn
Copy link
Collaborator Author

slvrtrn commented May 16, 2024

It is related.

@dimitriosp
Copy link

It is related.

Is there any other solution for metabase-cloud? since we cant host it, we can't change the parameter in docker.

@slvrtrn
Copy link
Collaborator Author

slvrtrn commented May 21, 2024

Is there any other solution for metabase-cloud?

I'd ask Metabase support for that; maybe they can adjust the TZ for your particular instance.

@dimitriosp
Copy link

I'd ask Metabase support for that; maybe they can adjust the TZ for your particular instance.

I went back and forth with the support and there seems no other option, then adjusting the sql query to reflect the timezone, since it is not officially supported. see here

@slvrtrn
Copy link
Collaborator Author

slvrtrn commented Jun 27, 2024

1.50.1 adds support for both timezone-related features.
Please try it out and create a new issue if you find any bugs.

@mattdavenport
Copy link

Thank you @slvrtrn!

@adityapatadia
Copy link

Is this version released on Cloud? We still don't see reports in correct timezone.

@paoliniluis
Copy link

@adityapatadia hi, please contact Metabase support

@dimitriosp
Copy link

1.50.1 adds support for both timezone-related features. Please try it out and create a new issue if you find any bugs.

Not sure if this is now related, however, when I use the simple sql prompt:
select current_date()

i get 13.08.2024, but today is 14.08.2024

doing the same in postgres, i get the correct date

@slvrtrn slvrtrn reopened this Aug 14, 2024
@slvrtrn
Copy link
Collaborator Author

slvrtrn commented Aug 14, 2024

The UI values are indeed incorrect despite the Metabase test suite for that functionality (general time zone support, time zone conversion, etc.) being green.

Currently, oddly, the workaround is to use data types with explicit timezones in the type definition (e.g., DateTime('UTC') instead of DateTime), similarly to the functions such as now.

SELECT now('UTC'); // or other timezone

Then, the report timezone is applied correctly.

We will be investigating how to fix it properly (and why all the tests are green while the UI values are incorrect).

@adityapatadia
Copy link

We have checked with the explicit timezone definition column DateTime('UTC') and it still does not show the correct date on the frontend.

@sandeep-tt
Copy link

sandeep-tt commented Oct 7, 2024

Hey @slvrtrn the 1.50.1 version solves for the where clause and the data filtered using where clause works great with a specified timezone. However, when I get the results on the frontend, the date values appear in UTC time instead of the specific timezone which we configured in the report timezone part in metabase.

Are you still actively looking to fix this too?

@slvrtrn
Copy link
Collaborator Author

slvrtrn commented Jan 3, 2025

Apologies for the delayed reply.

After the JDBC v2 pre-release, we revisited the timezones implementation.
Perhaps it will finally work properly when this PR is merged, and I publish a new release.

At least it looks like that:

Report timezone Honolulu:
image

Report timezone Amsterdam:
image

CLI:

SELECT *
FROM dt_test
   ┌──────────d─┬──────────────────dt─┬─────────────────dtz─┬────────────────────dt64─┬───────────────────dtz64─┐
1. │ 2024-12-19 │ 2024-12-19 21:41:17 │ 2024-12-19 22:41:17 │ 2024-12-19 21:41:17.579 │ 2024-12-19 22:41:17.580 │
   └────────────┴─────────────────────┴─────────────────────┴─────────────────────────┴─────────────────────────┘

DESCRIBE TABLE dt_test
   ┌─name──┬─type──────────────────────────────┬─default_type─┬─default_expression─┬─comment─┬─codec_expression─┬─ttl_expression─┐
1. │ d     │ Date                              │              │                    │         │                  │                │
2. │ dt    │ DateTime                          │              │                    │         │                  │                │
3. │ dtz   │ DateTime('Europe/Amsterdam')      │              │                    │         │                  │                │
4. │ dt64  │ DateTime64(3)                     │              │                    │         │                  │                │
5. │ dtz64 │ DateTime64(3, 'Europe/Amsterdam') │              │                    │         │                  │                │
   └───────┴───────────────────────────────────┴──────────────┴────────────────────┴─────────┴──────────────────┴────────────────┘

(server is UTC, so are dt DateTime and dt64 DateTime64(3) columns)

NB: :convert-timezone (IIUC it is this feature) will be disabled, as it looks like it is intended to be used with "wall clock" types like TIMESTAMP in MySQL and so on, and, sadly, I haven't found a way to make it work properly with the MB test suite.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
6 participants