2025-02-13 20:55:29 +01:00
|
|
|
from tests.dialects.test_dialect import Validator
|
|
|
|
|
|
|
|
|
|
|
|
class TestDoris(Validator):
|
|
|
|
dialect = "doris"
|
|
|
|
|
2025-02-13 21:19:14 +01:00
|
|
|
def test_doris(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT TO_DATE('2020-02-02 00:00:00')",
|
|
|
|
write={
|
|
|
|
"doris": "SELECT TO_DATE('2020-02-02 00:00:00')",
|
|
|
|
"oracle": "SELECT CAST('2020-02-02 00:00:00' AS DATE)",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT MAX_BY(a, b), MIN_BY(c, d)",
|
2025-02-13 21:36:08 +01:00
|
|
|
read={
|
|
|
|
"clickhouse": "SELECT argMax(a, b), argMin(c, d)",
|
|
|
|
},
|
2025-02-13 21:19:14 +01:00
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT ARRAY_SUM(x -> x * x, ARRAY(2, 3))",
|
|
|
|
read={
|
|
|
|
"clickhouse": "SELECT arraySum(x -> x*x, [2, 3])",
|
|
|
|
},
|
|
|
|
write={
|
|
|
|
"clickhouse": "SELECT arraySum(x -> x * x, [2, 3])",
|
|
|
|
"doris": "SELECT ARRAY_SUM(x -> x * x, ARRAY(2, 3))",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 21:29:39 +01:00
|
|
|
self.validate_all(
|
|
|
|
"MONTHS_ADD(d, n)",
|
|
|
|
read={
|
|
|
|
"oracle": "ADD_MONTHS(d, n)",
|
|
|
|
},
|
|
|
|
write={
|
|
|
|
"doris": "MONTHS_ADD(d, n)",
|
|
|
|
"oracle": "ADD_MONTHS(d, n)",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 21:36:08 +01:00
|
|
|
self.validate_all(
|
|
|
|
"""SELECT JSON_EXTRACT(CAST('{"key": 1}' AS JSONB), '$.key')""",
|
|
|
|
read={
|
|
|
|
"postgres": """SELECT '{"key": 1}'::jsonb ->> 'key'""",
|
|
|
|
},
|
|
|
|
write={
|
|
|
|
"doris": """SELECT JSON_EXTRACT(CAST('{"key": 1}' AS JSONB), '$.key')""",
|
|
|
|
"postgres": """SELECT JSON_EXTRACT_PATH(CAST('{"key": 1}' AS JSONB), 'key')""",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 21:37:40 +01:00
|
|
|
self.validate_all(
|
|
|
|
"SELECT GROUP_CONCAT('aa', ',')",
|
|
|
|
read={
|
|
|
|
"doris": "SELECT GROUP_CONCAT('aa', ',')",
|
|
|
|
"mysql": "SELECT GROUP_CONCAT('aa' SEPARATOR ',')",
|
|
|
|
"postgres": "SELECT STRING_AGG('aa', ',')",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 21:41:14 +01:00
|
|
|
self.validate_all(
|
|
|
|
"SELECT LAG(1, 1, NULL) OVER (ORDER BY 1)",
|
|
|
|
read={
|
|
|
|
"doris": "SELECT LAG(1, 1, NULL) OVER (ORDER BY 1)",
|
|
|
|
"postgres": "SELECT LAG(1) OVER (ORDER BY 1)",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT LAG(1, 2, NULL) OVER (ORDER BY 1)",
|
|
|
|
read={
|
|
|
|
"doris": "SELECT LAG(1, 2, NULL) OVER (ORDER BY 1)",
|
|
|
|
"postgres": "SELECT LAG(1, 2) OVER (ORDER BY 1)",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT LEAD(1, 1, NULL) OVER (ORDER BY 1)",
|
|
|
|
read={
|
|
|
|
"doris": "SELECT LEAD(1, 1, NULL) OVER (ORDER BY 1)",
|
|
|
|
"postgres": "SELECT LEAD(1) OVER (ORDER BY 1)",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT LEAD(1, 2, NULL) OVER (ORDER BY 1)",
|
|
|
|
read={
|
|
|
|
"doris": "SELECT LEAD(1, 2, NULL) OVER (ORDER BY 1)",
|
|
|
|
"postgres": "SELECT LEAD(1, 2) OVER (ORDER BY 1)",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 21:19:14 +01:00
|
|
|
|
2025-02-13 20:55:29 +01:00
|
|
|
def test_identity(self):
|
2025-02-13 20:58:22 +01:00
|
|
|
self.validate_identity("COALECSE(a, b, c, d)")
|
2025-02-13 20:55:29 +01:00
|
|
|
self.validate_identity("SELECT CAST(`a`.`b` AS INT) FROM foo")
|
|
|
|
self.validate_identity("SELECT APPROX_COUNT_DISTINCT(a) FROM x")
|
|
|
|
|
|
|
|
def test_time(self):
|
|
|
|
self.validate_identity("TIMESTAMP('2022-01-01')")
|
|
|
|
|
|
|
|
def test_regex(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT REGEXP_LIKE(abc, '%foo%')",
|
|
|
|
write={
|
|
|
|
"doris": "SELECT REGEXP(abc, '%foo%')",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 22:00:08 +01:00
|
|
|
|
|
|
|
def test_analyze(self):
|
|
|
|
self.validate_identity("ANALYZE TABLE tbl")
|
|
|
|
self.validate_identity("ANALYZE DATABASE db")
|
|
|
|
self.validate_identity("ANALYZE TABLE TBL(c1, c2)")
|