2025-02-13 14:53:43 +01:00
|
|
|
from tests.dialects.test_dialect import Validator
|
|
|
|
|
|
|
|
|
|
|
|
class TestDrill(Validator):
|
|
|
|
dialect = "drill"
|
|
|
|
|
2025-02-13 15:45:33 +01:00
|
|
|
def test_drill(self):
|
|
|
|
self.validate_all(
|
|
|
|
"DATE_FORMAT(a, 'yyyy')",
|
|
|
|
write={"drill": "TO_CHAR(a, 'yyyy')"},
|
|
|
|
)
|
|
|
|
|
2025-02-13 14:53:43 +01:00
|
|
|
def test_string_literals(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT '2021-01-01' + INTERVAL 1 MONTH",
|
|
|
|
write={
|
2025-02-13 15:51:35 +01:00
|
|
|
"mysql": "SELECT '2021-01-01' + INTERVAL '1' MONTH",
|
2025-02-13 14:53:43 +01:00
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_quotes(self):
|
|
|
|
self.validate_all(
|
|
|
|
"'\\''",
|
|
|
|
write={
|
|
|
|
"duckdb": "''''",
|
|
|
|
"presto": "''''",
|
|
|
|
"hive": "'\\''",
|
|
|
|
"spark": "'\\''",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"'\"x\"'",
|
|
|
|
write={
|
|
|
|
"duckdb": "'\"x\"'",
|
|
|
|
"presto": "'\"x\"'",
|
|
|
|
"hive": "'\"x\"'",
|
|
|
|
"spark": "'\"x\"'",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
self.validate_all(
|
|
|
|
"'\\\\a'",
|
|
|
|
read={
|
2025-02-13 15:24:45 +01:00
|
|
|
"presto": "'\\\\a'",
|
2025-02-13 14:53:43 +01:00
|
|
|
},
|
|
|
|
write={
|
2025-02-13 15:24:45 +01:00
|
|
|
"duckdb": "'\\\\a'",
|
|
|
|
"presto": "'\\\\a'",
|
2025-02-13 14:53:43 +01:00
|
|
|
"hive": "'\\\\a'",
|
|
|
|
"spark": "'\\\\a'",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_table_function(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT * FROM table( dfs.`test_data.xlsx` (type => 'excel', sheetName => 'secondSheet'))",
|
|
|
|
write={
|
|
|
|
"drill": "SELECT * FROM table(dfs.`test_data.xlsx`(type => 'excel', sheetName => 'secondSheet'))",
|
|
|
|
},
|
|
|
|
)
|
2025-02-13 15:44:19 +01:00
|
|
|
|
|
|
|
def test_validate_pivot(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT * FROM (SELECT education_level, salary, marital_status, "
|
|
|
|
"EXTRACT(year FROM age(birth_date)) age FROM cp.`employee.json`) PIVOT (avg(salary) AS "
|
|
|
|
"avg_salary, avg(age) AS avg_age FOR marital_status IN ('M' married, 'S' single))",
|
|
|
|
write={
|
|
|
|
"drill": "SELECT * FROM (SELECT education_level, salary, marital_status, "
|
|
|
|
"EXTRACT(year FROM age(birth_date)) AS age FROM cp.`employee.json`) "
|
2025-02-13 20:47:46 +01:00
|
|
|
"PIVOT(avg(salary) AS avg_salary, avg(age) AS avg_age FOR marital_status "
|
2025-02-13 15:44:19 +01:00
|
|
|
"IN ('M' AS married, 'S' AS single))"
|
|
|
|
},
|
|
|
|
)
|