Source code for sqlobject.inheritance.tests.test_asdict
from sqlobject import StringCol
from sqlobject.inheritance import InheritableSQLObject
from sqlobject.tests.dbtest import setupClass
########################################
# sqlmeta.asDict
########################################
[docs]class InheritablePersonAD(InheritableSQLObject):
firstName = StringCol()
lastName = StringCol(alternateID=True, length=100)
[docs]class ManagerAD(InheritablePersonAD):
department = StringCol()
[docs]class EmployeeAD(InheritablePersonAD):
_inheritable = False
so_position = StringCol()
[docs]def test_getColumns():
setupClass([InheritablePersonAD, ManagerAD, EmployeeAD])
for klass, columns in (
(InheritablePersonAD, ['firstName', 'lastName']),
(ManagerAD, ['department', 'firstName', 'lastName']),
(EmployeeAD, ['firstName', 'lastName', 'so_position'])):
_columns = sorted(klass.sqlmeta.getColumns().keys())
assert _columns == columns
[docs]def test_asDict():
setupClass([InheritablePersonAD, ManagerAD, EmployeeAD], force=True)
InheritablePersonAD(firstName='Oneof', lastName='Authors')
ManagerAD(firstName='ManagerAD', lastName='The', department='Dep')
EmployeeAD(firstName='Project', lastName='Leader',
so_position='Project leader')
assert InheritablePersonAD.get(1).sqlmeta.asDict() == \
dict(firstName='Oneof', lastName='Authors', id=1)
assert InheritablePersonAD.get(2).sqlmeta.asDict() == \
dict(firstName='ManagerAD', lastName='The', department='Dep', id=2)
assert InheritablePersonAD.get(3).sqlmeta.asDict() == \
dict(firstName='Project', lastName='Leader',
so_position='Project leader', id=3)