summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-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):