diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-12-17 11:24:35 -0500 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-12-17 11:24:35 -0500 |
| commit | 913858c949ae9ca6250217d82d72c7d79e9f6585 (patch) | |
| tree | a0e0033b8511a33b86a200019ce4c23255f58242 | |
| parent | 30be49c157e6ebe47c32abb98a570a013418b1e6 (diff) | |
| download | sqlalchemy-913858c949ae9ca6250217d82d72c7d79e9f6585.tar.gz | |
- Further fixes to :ticket:`3605`, pop method on :class:`.MutableDict`,
where the "default" argument was not included.
fixes #3605
| -rw-r--r-- | doc/build/changelog/changelog_10.rst | 8 | ||||
| -rw-r--r-- | lib/sqlalchemy/ext/mutable.py | 4 | ||||
| -rw-r--r-- | test/ext/test_mutable.py | 17 |
3 files changed, 26 insertions, 3 deletions
diff --git a/doc/build/changelog/changelog_10.rst b/doc/build/changelog/changelog_10.rst index b9eae73e6..d41ee70fd 100644 --- a/doc/build/changelog/changelog_10.rst +++ b/doc/build/changelog/changelog_10.rst @@ -20,6 +20,14 @@ .. change:: :tags: bug, ext + :tickets: 3605 + :versions: 1.1.0b1 + + Further fixes to :ticket:`3605`, pop method on :class:`.MutableDict`, + where the "default" argument was not included. + + .. change:: + :tags: bug, ext :tickets: 3612 :versions: 1.1.0b1 diff --git a/lib/sqlalchemy/ext/mutable.py b/lib/sqlalchemy/ext/mutable.py index 88b653f60..7bcef5b8e 100644 --- a/lib/sqlalchemy/ext/mutable.py +++ b/lib/sqlalchemy/ext/mutable.py @@ -658,8 +658,8 @@ class MutableDict(Mutable, dict): dict.update(self, *a, **kw) self.changed() - def pop(self, key): - result = dict.pop(self, key) + def pop(self, key, *arg): + result = dict.pop(self, key, *arg) self.changed() return result diff --git a/test/ext/test_mutable.py b/test/ext/test_mutable.py index ed97a0d92..602ff911a 100644 --- a/test/ext/test_mutable.py +++ b/test/ext/test_mutable.py @@ -4,7 +4,7 @@ from sqlalchemy.orm import mapper, Session, composite from sqlalchemy.orm.mapper import Mapper from sqlalchemy.orm.instrumentation import ClassManager from sqlalchemy.testing.schema import Table, Column -from sqlalchemy.testing import eq_, assert_raises_message +from sqlalchemy.testing import eq_, assert_raises_message, assert_raises from sqlalchemy.testing.util import picklers from sqlalchemy.testing import fixtures from sqlalchemy.ext.mutable import MutableComposite @@ -146,6 +146,21 @@ class _MutableDictTestBase(_MutableDictTestFixture): eq_(f1.data.pop('a'), 'b') sess.commit() + assert_raises(KeyError, f1.data.pop, 'g') + + eq_(f1.data, {'c': 'd'}) + + def test_pop_default(self): + sess = Session() + + f1 = Foo(data={'a': 'b', 'c': 'd'}) + sess.add(f1) + sess.commit() + + eq_(f1.data.pop('a', 'q'), 'b') + eq_(f1.data.pop('a', 'q'), 'q') + sess.commit() + eq_(f1.data, {'c': 'd'}) def test_popitem(self): |
