2025-02-13 14:54:32 +01:00
|
|
|
from tests.dialects.test_dialect import Validator
|
|
|
|
|
|
|
|
|
|
|
|
class TestDrill(Validator):
|
|
|
|
dialect = "drill"
|
|
|
|
|
|
|
|
def test_string_literals(self):
|
|
|
|
self.validate_all(
|
|
|
|
"SELECT '2021-01-01' + INTERVAL 1 MONTH",
|
|
|
|
write={
|
|
|
|
"mysql": "SELECT '2021-01-01' + INTERVAL 1 MONTH",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
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:26:26 +01:00
|
|
|
"presto": "'\\\\a'",
|
2025-02-13 14:54:32 +01:00
|
|
|
},
|
|
|
|
write={
|
2025-02-13 15:26:26 +01:00
|
|
|
"duckdb": "'\\\\a'",
|
|
|
|
"presto": "'\\\\a'",
|
2025-02-13 14:54:32 +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'))",
|
|
|
|
},
|
|
|
|
)
|