diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2015-06-28 14:06:07 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2015-06-28 14:06:07 (GMT) |
commit | 101ff3541cbe5bd9549722dc53c28d6c21b9389c (patch) | |
tree | 58ae6bba18ae65ca686f8a7ea89a78b482400f5e /Lib | |
parent | acac1e0e3bf564fbad2107d8f50d7e9c42e5ef22 (diff) | |
download | cpython-101ff3541cbe5bd9549722dc53c28d6c21b9389c.zip cpython-101ff3541cbe5bd9549722dc53c28d6c21b9389c.tar.gz cpython-101ff3541cbe5bd9549722dc53c28d6c21b9389c.tar.bz2 |
Issue #24336: The contextmanager decorator now works with functions with
keyword arguments called "func" and "self". Patch by Martin Panter.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/contextlib.py | 6 | ||||
-rw-r--r-- | Lib/test/test_contextlib.py | 8 | ||||
-rw-r--r-- | Lib/test/test_with.py | 6 |
3 files changed, 14 insertions, 6 deletions
diff --git a/Lib/contextlib.py b/Lib/contextlib.py index 82ee955..07b2261 100644 --- a/Lib/contextlib.py +++ b/Lib/contextlib.py @@ -34,7 +34,7 @@ class ContextDecorator(object): class _GeneratorContextManager(ContextDecorator): """Helper for @contextmanager decorator.""" - def __init__(self, func, *args, **kwds): + def __init__(self, func, args, kwds): self.gen = func(*args, **kwds) self.func, self.args, self.kwds = func, args, kwds # Issue 19330: ensure context manager instances have good docstrings @@ -52,7 +52,7 @@ class _GeneratorContextManager(ContextDecorator): # _GCM instances are one-shot context managers, so the # CM must be recreated each time a decorated function is # called - return self.__class__(self.func, *self.args, **self.kwds) + return self.__class__(self.func, self.args, self.kwds) def __enter__(self): try: @@ -123,7 +123,7 @@ def contextmanager(func): """ @wraps(func) def helper(*args, **kwds): - return _GeneratorContextManager(func, *args, **kwds) + return _GeneratorContextManager(func, args, kwds) return helper diff --git a/Lib/test/test_contextlib.py b/Lib/test/test_contextlib.py index 39cc776..8f849ae 100644 --- a/Lib/test/test_contextlib.py +++ b/Lib/test/test_contextlib.py @@ -111,6 +111,14 @@ class ContextManagerTestCase(unittest.TestCase): baz = self._create_contextmanager_attribs()(None) self.assertEqual(baz.__doc__, "Whee!") + def test_keywords(self): + # Ensure no keyword arguments are inhibited + @contextmanager + def woohoo(self, func, args, kwds): + yield (self, func, args, kwds) + with woohoo(self=11, func=22, args=33, kwds=44) as target: + self.assertEqual(target, (11, 22, 33, 44)) + class ClosingTestCase(unittest.TestCase): diff --git a/Lib/test/test_with.py b/Lib/test/test_with.py index 7068a80..cbaafcf 100644 --- a/Lib/test/test_with.py +++ b/Lib/test/test_with.py @@ -12,8 +12,8 @@ from test.support import run_unittest class MockContextManager(_GeneratorContextManager): - def __init__(self, func, *args, **kwds): - super().__init__(func, *args, **kwds) + def __init__(self, *args): + super().__init__(*args) self.enter_called = False self.exit_called = False self.exit_args = None @@ -31,7 +31,7 @@ class MockContextManager(_GeneratorContextManager): def mock_contextmanager(func): def helper(*args, **kwds): - return MockContextManager(func, *args, **kwds) + return MockContextManager(func, args, kwds) return helper |