summaryrefslogtreecommitdiff
path: root/Lib/test/test_multiprocessing.py
diff options
context:
space:
mode:
authorRichard Oudkerk <shibturn@gmail.com>2012-08-14 12:51:14 +0100
committerRichard Oudkerk <shibturn@gmail.com>2012-08-14 12:51:14 +0100
commit3165a75e45817e858b77ce307cebb93657249dc2 (patch)
tree7511830c6138de57f2f45ac10ea2a3ba9293e052 /Lib/test/test_multiprocessing.py
parente471772fff6cde0f0f30aab62bb4c4d57271bbcf (diff)
parente88a2445bc31dce0caa0be9b543689a953c1f920 (diff)
downloadcpython-git-3165a75e45817e858b77ce307cebb93657249dc2.tar.gz
Merge 3.2
Diffstat (limited to 'Lib/test/test_multiprocessing.py')
-rw-r--r--Lib/test/test_multiprocessing.py23
1 files changed, 22 insertions, 1 deletions
diff --git a/Lib/test/test_multiprocessing.py b/Lib/test/test_multiprocessing.py
index afb0bee419..57252a7fb0 100644
--- a/Lib/test/test_multiprocessing.py
+++ b/Lib/test/test_multiprocessing.py
@@ -20,6 +20,7 @@ import random
import logging
import struct
import test.support
+import test.script_helper
# Skip tests if _multiprocessing wasn't built.
@@ -3346,9 +3347,29 @@ class TestTimeouts(unittest.TestCase):
finally:
socket.setdefaulttimeout(old_timeout)
+#
+# Test what happens with no "if __name__ == '__main__'"
+#
+
+class TestNoForkBomb(unittest.TestCase):
+ def test_noforkbomb(self):
+ name = os.path.join(os.path.dirname(__file__), 'mp_fork_bomb.py')
+ if WIN32:
+ rc, out, err = test.script_helper.assert_python_failure(name)
+ self.assertEqual('', out.decode('ascii'))
+ self.assertIn('RuntimeError', err.decode('ascii'))
+ else:
+ rc, out, err = test.script_helper.assert_python_ok(name)
+ self.assertEqual('123', out.decode('ascii').rstrip())
+ self.assertEqual('', err.decode('ascii'))
+
+#
+#
+#
+
testcases_other = [OtherTest, TestInvalidHandle, TestInitializers,
TestStdinBadfiledescriptor, TestWait, TestInvalidFamily,
- TestFlags, TestTimeouts]
+ TestFlags, TestTimeouts, TestNoForkBomb]
#
#