test_sql_format.py 1.2 KB

12345678910111213141516171819202122232425262728293031
  1. import os
  2. import yatest.common
  3. import pytest
  4. from test_sql2yql import get_sql2yql_cmd
  5. from test_utils import pytest_generate_tests_by_template
  6. DATA_PATH = yatest.common.source_path('yql/essentials/tests/sql/suites')
  7. def pytest_generate_tests(metafunc):
  8. return pytest_generate_tests_by_template('.sql', metafunc, data_path=DATA_PATH)
  9. def test(suite, case, tmpdir):
  10. files = []
  11. # case can contain slash because of nested suites
  12. out_dir = tmpdir.mkdir(suite).mkdir(case.replace('/', '_')).dirname
  13. case_file = os.path.join(DATA_PATH, suite, '%s.sql' % case)
  14. ansi_lexer = False
  15. with open(case_file, 'r') as f:
  16. content = f.read()
  17. ansi_lexer = 'ansi_lexer' in content
  18. test_double_format = 'skip double format' not in content
  19. if 'syntax_pg' in content:
  20. pytest.skip('syntax_pg')
  21. cmd = get_sql2yql_cmd(suite, case, case_file, out_dir=out_dir, ansi_lexer=ansi_lexer, test_format=True, test_double_format=test_double_format)
  22. yatest.common.process.execute(cmd, env={'YQL_DETERMINISTIC_MODE': '1'})
  23. files.append(os.path.join(out_dir, 'formatted.sql'))
  24. return [yatest.common.canonical_file(file_name, local=True) for file_name in files]