-
Notifications
You must be signed in to change notification settings - Fork 0
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
Adding convert_tz and datetime functions to SQL and PPL #109
Adding convert_tz and datetime functions to SQL and PPL #109
Conversation
Codecov Report
@@ Coverage Diff @@
## integ-Add-convert_tz-function #109 +/- ##
===================================================================
+ Coverage 94.83% 94.87% +0.04%
- Complexity 2916 2932 +16
===================================================================
Files 291 291
Lines 7795 7857 +62
Branches 567 574 +7
===================================================================
+ Hits 7392 7454 +62
Misses 349 349
Partials 54 54
Flags with carried forward coverage won't be shown. Click here to find out more.
📣 We’re building smart automated test selection to slash your CI/CD build times. Learn more |
core/src/test/java/org/opensearch/sql/expression/datetime/DateTimeFunctionTest.java
Outdated
Show resolved
Hide resolved
Other optional tests:
Please, keep in mind, we don't test java, but we should ensure that user will get a valid result or a clear error message of incorrect input/limitation. |
core/src/test/java/org/opensearch/sql/expression/datetime/DateTimeFunctionTest.java
Outdated
Show resolved
Hide resolved
core/src/test/java/org/opensearch/sql/expression/datetime/DateTimeFunctionTest.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Show resolved
Hide resolved
@@ -679,4 +780,29 @@ private ExprValue exprYear(ExprValue date) { | |||
return new ExprIntegerValue(date.dateValue().getYear()); | |||
} | |||
|
|||
private Boolean isTimeZoneValid(ZoneId zone) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't every ZoneId a valid time zone identifier? Why do we need this validation?
If we do, needs unit tests to show which subset of ZoneId
s is valid and which are invalid.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The valid/invalid test is just to check if the timezone is outside of the range
+14 and - 13:59. Also needs validation if the input was actually a valid timezone, if not it should return null too. Current commit doesn't have it, being pushed soon.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd like to follow-up on this. As far as I can see, in Java, every ZoneId instance is a valid time zone.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
mysql> select convert_tz("2000-01-01 10:00:00", "+14:00", "+00:00");
+-------------------------------------------------------+
| convert_tz("2000-01-01 10:00:00", "+14:00", "+00:00") |
+-------------------------------------------------------+
| 1999-12-31 20:00:00 |
+-------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select convert_tz("2000-01-01 10:00:00", "+14:01", "+00:00");
+-------------------------------------------------------+
| convert_tz("2000-01-01 10:00:00", "+14:01", "+00:00") |
+-------------------------------------------------------+
| NULL |
+-------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select convert_tz("2000-01-01 10:00:00", "-13:59", "+00:00");
+-------------------------------------------------------+
| convert_tz("2000-01-01 10:00:00", "-13:59", "+00:00") |
+-------------------------------------------------------+
| 2000-01-01 23:59:00 |
+-------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select convert_tz("2000-01-01 10:00:00", "-14:00", "+00:00");
+-------------------------------------------------------+
| convert_tz("2000-01-01 10:00:00", "-14:00", "+00:00") |
+-------------------------------------------------------+
| NULL |
+-------------------------------------------------------+
1 row in set (0.00 sec)
The validator is to validate the timezones that match with MySQL standard. Java can handle all timezones being accepted and converted, but it won't match MySQL standard.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If that's the case, we need to rename this as isValidMySqlTimeZoneId
is similar
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See my comment above where the function is being used.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Function name updated to isValidMySqlTimeZoneId
.
core/src/test/java/org/opensearch/sql/expression/datetime/DateTimeFunctionTest.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/DateTimeFunctionIT.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/DateTimeFunctionIT.java
Outdated
Show resolved
Hide resolved
Queries on Feb 30 don't fail. A bug? |
/** | ||
* DateTime implementation for ExprValue. | ||
* | ||
* @param dateTime ExprValue of String type. | ||
* @return ExprValue of date type. | ||
*/ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please, describe both params in javadoc
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Second parameter added to java doc. Java doc also added to exprDateTimeNoTimezone function.
core/src/test/java/org/opensearch/sql/expression/datetime/DateTimeFunctionTest.java
Outdated
Show resolved
Hide resolved
@@ -463,4 +462,4 @@ public void testDateFormatISO8601() throws IOException { | |||
String dateFormatted = "1998-01-31T00:00:00Z"; | |||
verifyDateFormat(date, "date", dateFormat, dateFormatted); | |||
} | |||
} | |||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
newline would be great here.
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Show resolved
Hide resolved
* @param dateTime ExprValue of String type. | ||
* @return ExprValue of date type. | ||
*/ | ||
private ExprValue exprDateTime(ExprValue dateTime, ExprValue timeZone) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's discuss this method. I'd like to understand a few things:
- How do we know
dateTime
can be successfully parsed? This is done in two places without try-catch, yet it was parsing was wrapped in try-catch elsewhere. - We are checking if timeZone is null but not dateTime -- how come?
- If timeZone.isNull block is special case only for
exprDateTimeNoTZ
then it needs to move to that method. - try block on line 549 guards against parse on line 550 failing? Then why is it safe to assume parse call on line 558 will succeed?
- What is the difference between LocalDateTime and default time zone?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We are checking if timeZone is null but not dateTime -- how come?
The null field will come from exprDateTimeNoTimezone
which is used when only one parameter to datetime is called.
If I call SELECT DATETIME('2021-02-31 12:34:56)
then exprDateTimeNoTimezone
calls exprDateTime with null in the timezone field.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A better pattern would be to have function overloads: one with date and timezone, and one without timezone.
As it stands, you should include the null
as an expected/handled expected @param value for timeZone.
@@ -679,4 +780,29 @@ private ExprValue exprYear(ExprValue date) { | |||
return new ExprIntegerValue(date.dateValue().getYear()); | |||
} | |||
|
|||
private Boolean isTimeZoneValid(ZoneId zone) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd like to follow-up on this. As far as I can see, in Java, every ZoneId instance is a valid time zone.
integ-test/src/test/java/org/opensearch/sql/ppl/DateTimeImplementationIT.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/ConvertTZFunctionIT.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/ConvertTZFunctionIT.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/ConvertTZFunctionIT.java
Outdated
Show resolved
Hide resolved
integ-test/src/test/java/org/opensearch/sql/sql/DateTimeImplementationIT.java
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Outdated
Show resolved
Hide resolved
core/src/main/java/org/opensearch/sql/expression/datetime/DateTimeFunction.java
Show resolved
Hide resolved
DateTimeFormatter formatDT = DateTimeFormatter.ofPattern("uuuu-MM-dd HH:mm:ss[xxx]") | ||
.withResolverStyle(ResolverStyle.STRICT); | ||
|
||
try { | ||
LocalDateTime ldtFormatted = LocalDateTime.parse(dateTime.stringValue(), formatDT); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can use new ExprDatetimeValue(dateTime.stringValue())
and don't worry about parser and format.
In that case you just need to update ExprDatetimeValue
ctor to use ResolverStyle.STRICT
- it will be good in any case.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't understand what the benefit of this change would be.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can reduce a bit your code an delegate parsing to code that already exists and covered by tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Resolved.
Signed-off-by: MitchellGale-BitQuill <[email protected]>
…field number. Signed-off-by: MitchellGale-BitQuill <[email protected]>
…est in ConvertTZTest.java. Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
Signed-off-by: MitchellGale-BitQuill <[email protected]>
bb409a4
to
45a6d2e
Compare
Description
PR adds support for convert_tz and Datetime for PPL and SQL languages.
convert_tz
Syntax for convert_tz:
convert_tz(datetime string, from timezone, to timezone)
It converts the
datetime string
from thefrom timezone
to theto timezone
. Converts from negative to positive timezone, from positive to negative, from positive to positive or negative to negative time zones. Works across year roll-over and leap years.Example:
nulls
It returns null for time zones outside of the allowed range (allow range is -12:00 -> +14:00)
Leap year
DateTime
DATETIME(timestamp_expression [, time_zone])
Issues Resolved
#703
#46
Check List
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.