diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-09-09 15:51:40 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-09-09 15:51:40 -0400 |
| commit | 1492cc634ee67afb5ad03f0d56caca9fc3bbcc0e (patch) | |
| tree | 5ca87a8d50adc65bd6971d6843b2fe85420bb7a9 /test/orm/test_mapper.py | |
| parent | 07179d2aae12bb4e72eb1e494a870eefada8320a (diff) | |
| download | sqlalchemy-1492cc634ee67afb5ad03f0d56caca9fc3bbcc0e.tar.gz | |
- Fixed bug whereby if __eq__() was
redefined, a relationship many-to-one lazyload
would hit the __eq__() and fail. [ticket:2260]
Does not apply to 0.6.9.
Diffstat (limited to 'test/orm/test_mapper.py')
| -rw-r--r-- | test/orm/test_mapper.py | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/test/orm/test_mapper.py b/test/orm/test_mapper.py index ba477e8e6..ce729ed6b 100644 --- a/test/orm/test_mapper.py +++ b/test/orm/test_mapper.py @@ -690,6 +690,28 @@ class MapperTest(_fixtures.FixtureTest): s.add(A()) s.commit() + def test_we_dont_call_eq(self): + class NoEqAllowed(object): + def __eq__(self, other): + raise Exception("nope") + + addresses, users = self.tables.addresses, self.tables.users + Address = self.classes.Address + + mapper(NoEqAllowed, users, properties={ + 'addresses':relationship(Address, backref='user') + }) + mapper(Address, addresses) + + u1 = NoEqAllowed() + u1.name = "some name" + u1.addresses = [Address(id=12, email_address='a1')] + s = Session(testing.db) + s.add(u1) + s.commit() + + a1 = s.query(Address).filter_by(id=12).one() + assert a1.user is u1 def test_mapping_to_join_raises(self): """Test implicit merging of two cols raises.""" |
