From: Julien Castets Date: Mon, 16 Mar 2015 10:45:06 +0000 (+0100) Subject: Accept unicode in CascadeOptions X-Git-Tag: rel_1_0_0b2~16 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=edfe2deffb7a3ab637e5ee7ab3379911483380fa;p=thirdparty%2Fsqlalchemy%2Fsqlalchemy.git Accept unicode in CascadeOptions --- diff --git a/lib/sqlalchemy/orm/util.py b/lib/sqlalchemy/orm/util.py index 9787b0fb43..ad071376dc 100644 --- a/lib/sqlalchemy/orm/util.py +++ b/lib/sqlalchemy/orm/util.py @@ -35,7 +35,7 @@ class CascadeOptions(frozenset): 'expunge', 'delete_orphan') def __new__(cls, value_list): - if isinstance(value_list, str) or value_list is None: + if isinstance(value_list, util.string_types) or value_list is None: return cls.from_string(value_list) values = set(value_list) if values.difference(cls._allowed_cascades): diff --git a/test/orm/test_cascade.py b/test/orm/test_cascade.py index e39911d0f6..f104ee34c0 100644 --- a/test/orm/test_cascade.py +++ b/test/orm/test_cascade.py @@ -2,7 +2,7 @@ import copy from sqlalchemy.testing import assert_raises, assert_raises_message from sqlalchemy import Integer, String, ForeignKey, Sequence, \ - exc as sa_exc + exc as sa_exc, util from sqlalchemy.testing.schema import Table, Column from sqlalchemy.orm import mapper, relationship, create_session, \ sessionmaker, class_mapper, backref, Session, util as orm_util,\ @@ -119,6 +119,14 @@ class CascadeArgTest(fixtures.MappedTest): 'refresh-expire', 'save-update']) ) + def test_cascade_unicode(self): + User, Address = self.classes.User, self.classes.Address + users, addresses = self.tables.users, self.tables.addresses + + rel = relationship(Address) + rel.cascade = util.u('save-update, merge, expunge') + eq_(rel.cascade, set(['save-update', 'merge', 'expunge'])) + class O2MCascadeDeleteOrphanTest(fixtures.MappedTest): run_inserts = None