summaryrefslogtreecommitdiff
path: root/test/sql/test_selectable.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2013-02-02 20:06:31 -0500
committerMike Bayer <mike_mp@zzzcomputing.com>2013-02-02 20:06:31 -0500
commitaf44efe26e3f703ca1c30e79ee68428eed35abcf (patch)
treea0b5a20398ef9a54c187cb802fe9922a2f99cb91 /test/sql/test_selectable.py
parenteea0ca9fb4f21c37d1a8c4beb9d6327b19fc3d0f (diff)
downloadsqlalchemy-af44efe26e3f703ca1c30e79ee68428eed35abcf.tar.gz
Fixed a bug regarding column annotations which in particular
could impact some usages of the new :func:`.orm.remote` and :func:`.orm.local` annotation functions, where annotations could be lost when the column were used in a subsequent expression. [ticket:2660]
Diffstat (limited to 'test/sql/test_selectable.py')
-rw-r--r--test/sql/test_selectable.py31
1 files changed, 31 insertions, 0 deletions
diff --git a/test/sql/test_selectable.py b/test/sql/test_selectable.py
index 7857681f3..30052a806 100644
--- a/test/sql/test_selectable.py
+++ b/test/sql/test_selectable.py
@@ -1556,3 +1556,34 @@ class AnnotationsTest(fixtures.TestBase):
# also pass, [ticket:2425]
eq_(str(or_(b, b._annotate({"foo": "bar"}))),
":bind_1 OR :bind_1")
+
+ def test_comparators_cleaned_out_construction(self):
+ c = column('a')
+
+ comp1 = c.comparator
+
+ c1 = c._annotate({"foo": "bar"})
+ comp2 = c1.comparator
+ assert comp1 is not comp2
+
+ def test_comparators_cleaned_out_reannotate(self):
+ c = column('a')
+
+ c1 = c._annotate({"foo": "bar"})
+ comp1 = c1.comparator
+
+ c2 = c1._annotate({"bat": "hoho"})
+ comp2 = c2.comparator
+
+ assert comp1 is not comp2
+
+ def test_comparator_cleanout_integration(self):
+ c = column('a')
+
+ c1 = c._annotate({"foo": "bar"})
+ comp1 = c1.comparator
+
+ c2 = c1._annotate({"bat": "hoho"})
+ comp2 = c2.comparator
+
+ assert (c2 == 5).left._annotations == {"foo": "bar", "bat": "hoho"}