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)