|
9 | 9 | from sqlalchemy.testing import config |
10 | 10 | from sqlalchemy.orm import Session |
11 | 11 | from sqlalchemy import testing |
12 | | -from sqlalchemy import Table, Column, select |
| 12 | +from sqlalchemy import Table, Column, select, func |
13 | 13 | from sqlalchemy.types import Integer |
14 | 14 | from sqlalchemy.types import String |
15 | 15 | from sqlalchemy.types import VARBINARY |
| 16 | +from sqlalchemy.types import TEXT |
16 | 17 | from sqlalchemy.types import BINARY |
17 | 18 | from sqlalchemy_iris import TINYINT |
18 | 19 | from sqlalchemy_iris import INTEGER |
@@ -440,3 +441,48 @@ def test_max_inner_product(self): |
440 | 441 | (2,), |
441 | 442 | ], |
442 | 443 | ) |
| 444 | + |
| 445 | + |
| 446 | +class ConcatTest(fixtures.TablesTest): |
| 447 | + __backend__ = True |
| 448 | + |
| 449 | + @classmethod |
| 450 | + def define_tables(cls, metadata): |
| 451 | + Table( |
| 452 | + "data", |
| 453 | + metadata, |
| 454 | + Column("sometext", TEXT), |
| 455 | + Column("testdata", TEXT), |
| 456 | + ) |
| 457 | + |
| 458 | + @classmethod |
| 459 | + def fixtures(cls): |
| 460 | + return dict( |
| 461 | + data=( |
| 462 | + ( |
| 463 | + "sometext", |
| 464 | + "testdata", |
| 465 | + ), |
| 466 | + ( |
| 467 | + "sometestdata", |
| 468 | + "test", |
| 469 | + ), |
| 470 | + ) |
| 471 | + ) |
| 472 | + |
| 473 | + def _assert_result(self, select, result): |
| 474 | + with config.db.connect() as conn: |
| 475 | + eq_(conn.execute(select).fetchall(), result) |
| 476 | + |
| 477 | + def test_concat_func(self): |
| 478 | + self._assert_result( |
| 479 | + select( |
| 480 | + self.tables.data.c.sometext, |
| 481 | + ).filter( |
| 482 | + self.tables.data.c.sometext |
| 483 | + == func.concat("some", self.tables.data.c.testdata, "data") |
| 484 | + ), |
| 485 | + [ |
| 486 | + ("sometestdata",), |
| 487 | + ], |
| 488 | + ) |
0 commit comments