Skip to content

Commit

Permalink
removes a compliance test that fails and replaces with unit test
Browse files Browse the repository at this point in the history
  • Loading branch information
chalmerlowe committed Aug 9, 2024
1 parent f9324e3 commit e9d15a6
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@
QuotedNameArgumentTest,
SimpleUpdateDeleteTest as _SimpleUpdateDeleteTest,
TimestampMicrosecondsTest as _TimestampMicrosecondsTest,
WindowFunctionTest,
)

from sqlalchemy.testing.suite.test_types import (
Expand Down Expand Up @@ -636,3 +637,6 @@ def test_no_results_for_non_returning_insert(cls):
del LongNameBlowoutTest # Requires features (indexes, primary keys, etc., that BigQuery doesn't have.
del PostCompileParamsTest # BQ adds backticks to bind parameters, causing failure of tests TODO: fix this?
del QuotedNameArgumentTest # Quotes aren't allowed in BigQuery table names.
del (
WindowFunctionTest.test_window_rows_between
) # test expects BQ to return sorted results
50 changes: 50 additions & 0 deletions tests/unit/test_select.py
Original file line number Diff line number Diff line change
Expand Up @@ -507,3 +507,53 @@ def test_visit_mod_binary(faux_conn):
expected = "MOD(`table`.`foo`, %(foo_1:INT64)s)"

assert result == expected


def test_window_rows_between(faux_conn):
"""This is a replacement for the
'test_window_rows_between'
test in sqlalchemy's suite of compliance tests.
Their test is expecting things in sorted order and BQ
doesn't return sorted results they way they expect so that
test fails.
Note: that test only appears in:
sqlalchemy/lib/sqlalchemy/testing/suite/test_select.py
in version 2.0.32. It appears as those that test will be
replaced with the a similar but new test called:
'test_window_rows_between_w_caching'
due to the fact the rows are part of the cache key right now and
not handled as binds. This is related to sqlalchemy Issue #11515
It is expected the new test will also have the same sorting failure.
"""

table = setup_table(
faux_conn,
"table",
sqlalchemy.Column("id", sqlalchemy.String),
sqlalchemy.Column("col1", sqlalchemy.Integer),
sqlalchemy.Column("col2", sqlalchemy.Integer),
)

stmt = sqlalchemy.select(
sqlalchemy.func.max(table.c.col2).over(
order_by=[table.c.col1],
rows=(-5, 0),
)
)

sql = stmt.compile(
dialect=faux_conn.dialect,
compile_kwargs={"literal_binds": True},
)

result = str(sql)
expected = (
"SELECT max(`table`.`col2`) "
"OVER (ORDER BY `table`.`col1` "
"ROWS BETWEEN 5 PRECEDING AND CURRENT ROW) AS `anon_1` \n" # newline character required here to match
"FROM `table`"
)
assert result == expected

0 comments on commit e9d15a6

Please sign in to comment.