From: Mike Bayer Date: Mon, 17 Jun 2013 20:06:29 +0000 (-0400) Subject: Merged in goodscloud/sqlalchemy (pull request #2) X-Git-Tag: rel_0_8_2~42 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6286f715dbf88c052fde1647689d8b0dff84a445;p=thirdparty%2Fsqlalchemy%2Fsqlalchemy.git Merged in goodscloud/sqlalchemy (pull request #2) don't create a history entry when an object in a backref has changed --- diff --git a/examples/versioning/history_meta.py b/examples/versioning/history_meta.py index 5335993941..79c77cdc26 100644 --- a/examples/versioning/history_meta.py +++ b/examples/versioning/history_meta.py @@ -158,8 +158,12 @@ def create_version(obj, session, deleted = False): for prop in obj_mapper.iterate_properties: if isinstance(prop, RelationshipProperty) and \ attributes.get_history(obj, prop.key).has_changes(): - obj_changed = True - break + for p in prop.local_columns: + if p.foreign_keys: + obj_changed = True + break + if obj_changed is True: + break if not obj_changed and not deleted: return diff --git a/examples/versioning/test_versioning.py b/examples/versioning/test_versioning.py index 43e2b0ae1e..a08f1dbf3c 100644 --- a/examples/versioning/test_versioning.py +++ b/examples/versioning/test_versioning.py @@ -306,7 +306,7 @@ class TestVersioning(TestCase): id = Column(Integer, primary_key=True) name = Column(String(50)) related_id = Column(Integer, ForeignKey('somerelated.id')) - related = relationship("SomeRelated") + related = relationship("SomeRelated", backref='classes') SomeClassHistory = SomeClass.__history_mapper__.class_ @@ -341,3 +341,38 @@ class TestVersioning(TestCase): assert sc.version == 3 + def test_backref_relationship(self): + + class SomeRelated(Base, ComparableEntity): + __tablename__ = 'somerelated' + + id = Column(Integer, primary_key=True) + name = Column(String(50)) + related_id = Column(Integer, ForeignKey('sometable.id')) + related = relationship("SomeClass", backref='related') + + class SomeClass(Versioned, Base, ComparableEntity): + __tablename__ = 'sometable' + + id = Column(Integer, primary_key=True) + + self.create_tables() + sess = Session() + sc = SomeClass() + sess.add(sc) + sess.commit() + + assert sc.version == 1 + + sr = SomeRelated(name='sr', related=sc) + sess.add(sr) + sess.commit() + + assert sc.version == 1 + + sr.name = 'sr2' + sess.commit() + + assert sc.version == 1 + sess.delete(sr) + sess.commit()