54 lines
1.4 KiB
Python
54 lines
1.4 KiB
Python
|
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={
|
||
|
"presto": "'\\a'",
|
||
|
},
|
||
|
write={
|
||
|
"duckdb": "'\\a'",
|
||
|
"presto": "'\\a'",
|
||
|
"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'))",
|
||
|
},
|
||
|
)
|