Improve get_columns
Add support for columns, column properties and instrumented attributes
This commit is contained in:
@@ -4,6 +4,12 @@ Changelog
|
||||
Here you can see the full list of changes between each SQLAlchemy-Utils release.
|
||||
|
||||
|
||||
0.30.13 (2015-07-16)
|
||||
^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
- Added support for InstrumentedAttributes, ColumnProperties and Columns in get_columns function
|
||||
|
||||
|
||||
0.30.12 (2015-07-05)
|
||||
^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
|
@@ -377,7 +377,6 @@ from .relationships import (
|
||||
select_correlated_expression
|
||||
)
|
||||
|
||||
|
||||
aggregated_attrs = WeakKeyDictionary(defaultdict(list))
|
||||
|
||||
|
||||
|
@@ -403,14 +403,18 @@ def get_columns(mixed):
|
||||
SA Table object, SA Mapper, SA declarative class, SA declarative class
|
||||
instance or an alias of any of these objects
|
||||
"""
|
||||
if isinstance(mixed, sa.Table):
|
||||
if isinstance(mixed, sa.sql.selectable.Selectable):
|
||||
return mixed.c
|
||||
if isinstance(mixed, sa.orm.util.AliasedClass):
|
||||
return sa.inspect(mixed).mapper.columns
|
||||
if isinstance(mixed, sa.sql.selectable.Alias):
|
||||
return mixed.c
|
||||
if isinstance(mixed, sa.orm.Mapper):
|
||||
return mixed.columns
|
||||
if isinstance(mixed, InstrumentedAttribute):
|
||||
return mixed.property.columns
|
||||
if isinstance(mixed, ColumnProperty):
|
||||
return mixed.columns
|
||||
if isinstance(mixed, sa.Column):
|
||||
return [mixed]
|
||||
if not isclass(mixed):
|
||||
mixed = mixed.__class__
|
||||
return sa.inspect(mixed).columns
|
||||
|
@@ -21,6 +21,19 @@ class TestGetColumns(object):
|
||||
sa.sql.base.ImmutableColumnCollection
|
||||
)
|
||||
|
||||
def test_instrumented_attribute(self):
|
||||
assert get_columns(self.Building.id) == [self.Building.__table__.c._id]
|
||||
|
||||
def test_column_property(self):
|
||||
assert get_columns(self.Building.id.property) == [
|
||||
self.Building.__table__.c._id
|
||||
]
|
||||
|
||||
def test_column(self):
|
||||
assert get_columns(self.Building.__table__.c._id) == [
|
||||
self.Building.__table__.c._id
|
||||
]
|
||||
|
||||
def test_declarative_class(self):
|
||||
assert isinstance(
|
||||
get_columns(self.Building),
|
||||
|
Reference in New Issue
Block a user