Source code for sqlobject.tests.test_default_style

"""
Test the default styles, to guarantee consistency.
"""

from sqlobject import ForeignKey, MixedCaseStyle, MixedCaseUnderscoreStyle, \
    SQLObject, StringCol, Style

# Hash of styles versus the database names resulting from 'columns' below.
columns = ["ABCUpper", "abc_lower", "ABCamelCaseColumn"]
styles = {
    Style: columns,
    MixedCaseUnderscoreStyle: ["abc_upper", "abc_lower",
                               "ab_camel_case_column"],
    MixedCaseStyle: ["ABCUpper", "Abc_lower", "ABCamelCaseColumn"],
}

# Hash of styles versus the database names
# resulting from a foreign key named 'FKey'.
fkey = ForeignKey("DefaultStyleTest", name="FKey")
fkeys = {
    Style: "FKeyID",
    MixedCaseUnderscoreStyle: "f_key_id",
    MixedCaseStyle: "FKeyID",
}


[docs]def make_columns(): global columns columns = [] for col_name in columns: columns.append(StringCol(name=col_name, length=10))
[docs]def do_col_test(DefaultStyleTest, style, dbnames): DefaultStyleTest.sqlmeta.style = style() for col, old_dbname in zip(columns, dbnames): DefaultStyleTest.sqlmeta.addColumn(col) try: new_dbname = DefaultStyleTest.sqlmeta.columns[col.name].dbName assert new_dbname == old_dbname finally: if col.name in DefaultStyleTest.sqlmeta.columns: DefaultStyleTest.sqlmeta.delColumn(col)
[docs]def do_fkey_test(DefaultStyleTest, style, dbname): DefaultStyleTest.sqlmeta.style = style() DefaultStyleTest.sqlmeta.addColumn(fkey) try: assert list(DefaultStyleTest.sqlmeta.columns.keys())[0] == "FKeyID" assert list(DefaultStyleTest.sqlmeta.columns.values())[0].dbName == \ dbname finally: DefaultStyleTest.sqlmeta.delColumn(fkey)
[docs]class DefaultStyleTest(SQLObject): pass
[docs]def test_default_styles(): make_columns() for style in styles: do_col_test(DefaultStyleTest, style, styles[style]) do_fkey_test(DefaultStyleTest, style, fkeys[style])