summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2015-12-17 11:24:35 -0500
committerMike Bayer <mike_mp@zzzcomputing.com>2015-12-17 11:24:35 -0500
commit913858c949ae9ca6250217d82d72c7d79e9f6585 (patch)
treea0e0033b8511a33b86a200019ce4c23255f58242
parent30be49c157e6ebe47c32abb98a570a013418b1e6 (diff)
downloadsqlalchemy-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.rst8
-rw-r--r--lib/sqlalchemy/ext/mutable.py4
-rw-r--r--test/ext/test_mutable.py17
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):