summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorRichard Oudkerk <shibturn@gmail.com>2012-06-18 20:29:30 (GMT)
committerRichard Oudkerk <shibturn@gmail.com>2012-06-18 20:29:30 (GMT)
commitac38571f00ccb5e1e0346ad27a8fac96d05e61c3 (patch)
treef9c8bc09a58917250daf9ac1beec8196b98a4912 /Lib
parent9c1feb88f3511b35663ea4cc2a1f8cd2b21ee3d1 (diff)
downloadcpython-ac38571f00ccb5e1e0346ad27a8fac96d05e61c3.zip
cpython-ac38571f00ccb5e1e0346ad27a8fac96d05e61c3.tar.gz
cpython-ac38571f00ccb5e1e0346ad27a8fac96d05e61c3.tar.bz2
Issue #15064: Make BaseManager.__enter__() start server if necessary.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/multiprocessing/managers.py3
-rw-r--r--Lib/test/test_multiprocessing.py26
2 files changed, 23 insertions, 6 deletions
diff --git a/Lib/multiprocessing/managers.py b/Lib/multiprocessing/managers.py
index f6611af..1ab147e 100644
--- a/Lib/multiprocessing/managers.py
+++ b/Lib/multiprocessing/managers.py
@@ -561,6 +561,9 @@ class BaseManager(object):
conn.close()
def __enter__(self):
+ if self._state.value == State.INITIAL:
+ self.start()
+ assert self._state.value == State.STARTED
return self
def __exit__(self, exc_type, exc_val, exc_tb):
diff --git a/Lib/test/test_multiprocessing.py b/Lib/test/test_multiprocessing.py
index 017e6b4..f6f4f73 100644
--- a/Lib/test/test_multiprocessing.py
+++ b/Lib/test/test_multiprocessing.py
@@ -1888,7 +1888,27 @@ class _TestMyManager(BaseTestCase):
def test_mymanager(self):
manager = MyManager()
manager.start()
+ self.common(manager)
+ manager.shutdown()
+
+ # If the manager process exited cleanly then the exitcode
+ # will be zero. Otherwise (after a short timeout)
+ # terminate() is used, resulting in an exitcode of -SIGTERM.
+ self.assertEqual(manager._process.exitcode, 0)
+
+ def test_mymanager_context(self):
+ with MyManager() as manager:
+ self.common(manager)
+ self.assertEqual(manager._process.exitcode, 0)
+
+ def test_mymanager_context_prestarted(self):
+ manager = MyManager()
+ manager.start()
+ with manager:
+ self.common(manager)
+ self.assertEqual(manager._process.exitcode, 0)
+ def common(self, manager):
foo = manager.Foo()
bar = manager.Bar()
baz = manager.baz()
@@ -1911,12 +1931,6 @@ class _TestMyManager(BaseTestCase):
self.assertEqual(list(baz), [i*i for i in range(10)])
- manager.shutdown()
-
- # If the manager process exited cleanly then the exitcode
- # will be zero. Otherwise (after a short timeout)
- # terminate() is used, resulting in an exitcode of -SIGTERM.
- self.assertEqual(manager._process.exitcode, 0)
#
# Test of connecting to a remote server and using xmlrpclib for serialization