Source code for sqlobject.tests.test_aliases
from sqlobject import SQLObject, StringCol
from sqlobject.sqlbuilder import Alias, LEFTJOINOn
from sqlobject.tests.dbtest import setupClass
########################################
# Table aliases and self-joins
########################################
[docs]class JoinAlias(SQLObject):
    name = StringCol()
    parent = StringCol() 
[docs]def test_1syntax():
    setupClass(JoinAlias)
    alias = Alias(JoinAlias)
    select = JoinAlias.select(JoinAlias.q.parent == alias.q.name)
    assert str(select) == \
        
"SELECT join_alias.id, join_alias.name, join_alias.parent " \
        
"FROM join_alias, join_alias  join_alias_alias1 " \
        
"WHERE ((join_alias.parent) = (join_alias_alias1.name))" 
[docs]def test_3joins():
    setupClass(JoinAlias)
    alias = Alias(JoinAlias)
    select = JoinAlias.select(
        (JoinAlias.q.name == 'a') & (alias.q.name == 'b'),
        join=LEFTJOINOn(None, alias, alias.q.name == 'c')
    )
    assert str(select) == \
        
"SELECT join_alias.id, join_alias.name, join_alias.parent " \
        
"FROM join_alias " \
        
"LEFT JOIN join_alias  join_alias_alias3 " \
        
"ON ((join_alias_alias3.name) = ('c')) " \
        
"WHERE (((join_alias.name) = ('a')) AND " \
        
"((join_alias_alias3.name) = ('b')))"