Skip to content

Commit

Permalink
chore(sqllab): Do not strip comments when executing SQL statements
Browse files Browse the repository at this point in the history
  • Loading branch information
john-bodley committed Mar 28, 2024
1 parent 5e8459b commit 0b35815
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 7 deletions.
1 change: 0 additions & 1 deletion superset/sql_lab.py
Original file line number Diff line number Diff line change
Expand Up @@ -412,7 +412,6 @@ def execute_sql_statements(
# Breaking down into multiple statements
parsed_query = ParsedQuery(
rendered_query,
strip_comments=True,
engine=db_engine_spec.engine,
)
if not db_engine_spec.run_multiple_statements_as_one:
Expand Down
21 changes: 15 additions & 6 deletions tests/integration_tests/sqllab_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
"""Unit tests for Sql Lab"""
import json
from datetime import datetime
from textwrap import dedent

import pytest
from celery.exceptions import SoftTimeLimitExceeded
Expand Down Expand Up @@ -639,12 +640,14 @@ def test_execute_sql_statements(
mock_get_query,
mock_db,
):
sql = """
sql = dedent(
"""
-- comment
SET @value = 42;
SELECT @value AS foo;
-- comment
"""
)
mock_db = mock.MagicMock()
mock_query = mock.MagicMock()
mock_query.database.allow_run_async = False
Expand All @@ -667,7 +670,7 @@ def test_execute_sql_statements(
mock_execute_sql_statement.assert_has_calls(
[
mock.call(
"SET @value = 42",
"-- comment\nSET @value = 42",
mock_query,
mock_cursor,
None,
Expand All @@ -689,12 +692,14 @@ def test_execute_sql_statements(
def test_execute_sql_statements_no_results_backend(
self, mock_execute_sql_statement, mock_get_query
):
sql = """
sql = dedent(
"""
-- comment
SET @value = 42;
SELECT @value AS foo;
-- comment
"""
)
mock_query = mock.MagicMock()
mock_query.database.allow_run_async = True
mock_cursor = mock.MagicMock()
Expand Down Expand Up @@ -741,12 +746,14 @@ def test_execute_sql_statements_ctas(
mock_get_query,
mock_db,
):
sql = """
sql = dedent(
"""
-- comment
SET @value = 42;
SELECT @value AS foo;
-- comment
"""
)
mock_db = mock.MagicMock()
mock_query = mock.MagicMock()
mock_query.database.allow_run_async = False
Expand All @@ -773,7 +780,7 @@ def test_execute_sql_statements_ctas(
mock_execute_sql_statement.assert_has_calls(
[
mock.call(
"SET @value = 42",
"-- comment\nSET @value = 42",
mock_query,
mock_cursor,
None,
Expand Down Expand Up @@ -817,12 +824,14 @@ def test_execute_sql_statements_ctas(

# try invalid CVAS
mock_query.ctas_method = CtasMethod.VIEW
sql = """
sql = dedent(
"""
-- comment
SET @value = 42;
SELECT @value AS foo;
-- comment
"""
)
with pytest.raises(SupersetErrorException) as excinfo:
execute_sql_statements(
query_id=1,
Expand Down

0 comments on commit 0b35815

Please sign in to comment.