summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorEzio Melotti <ezio.melotti@gmail.com>2011-05-07 16:50:28 (GMT)
committerEzio Melotti <ezio.melotti@gmail.com>2011-05-07 16:50:28 (GMT)
commit4c1aebd88bc71fcbca26279bd21f971f93acb641 (patch)
treedaaced62afb4e01a2b850b6128291ff42a89ee58 /Lib/test
parent06383ee090e3c66130db9dc0b562fba3cb749be1 (diff)
parent63e4230c3865f6b15538b61fbecd5d0286b1f0a9 (diff)
downloadcpython-4c1aebd88bc71fcbca26279bd21f971f93acb641.zip
cpython-4c1aebd88bc71fcbca26279bd21f971f93acb641.tar.gz
cpython-4c1aebd88bc71fcbca26279bd21f971f93acb641.tar.bz2
#5421: merge with 3.1.
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_socket.py44
1 files changed, 44 insertions, 0 deletions
diff --git a/Lib/test/test_socket.py b/Lib/test/test_socket.py
index e745502..a948541 100644
--- a/Lib/test/test_socket.py
+++ b/Lib/test/test_socket.py
@@ -295,6 +295,50 @@ class GeneralModuleTests(unittest.TestCase):
self.assertRaises(socket.error, raise_gaierror,
"Error raising socket exception.")
+ def testSendtoErrors(self):
+ # Testing that sendto doens't masks failures. See #10169.
+ s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
+ self.addCleanup(s.close)
+ s.bind(('', 0))
+ sockname = s.getsockname()
+ # 2 args
+ with self.assertRaises(TypeError) as cm:
+ s.sendto('\u2620', sockname)
+ self.assertEqual(str(cm.exception),
+ "'str' does not support the buffer interface")
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(5j, sockname)
+ self.assertEqual(str(cm.exception),
+ "'complex' does not support the buffer interface")
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo', None)
+ self.assertIn('not NoneType',str(cm.exception))
+ # 3 args
+ with self.assertRaises(TypeError) as cm:
+ s.sendto('\u2620', 0, sockname)
+ self.assertEqual(str(cm.exception),
+ "'str' does not support the buffer interface")
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(5j, 0, sockname)
+ self.assertEqual(str(cm.exception),
+ "'complex' does not support the buffer interface")
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo', 0, None)
+ self.assertIn('not NoneType', str(cm.exception))
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo', 'bar', sockname)
+ self.assertIn('an integer is required', str(cm.exception))
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo', None, None)
+ self.assertIn('an integer is required', str(cm.exception))
+ # wrong number of args
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo')
+ self.assertIn('(1 given)', str(cm.exception))
+ with self.assertRaises(TypeError) as cm:
+ s.sendto(b'foo', 0, sockname, 4)
+ self.assertIn('(4 given)', str(cm.exception))
+
def testCrucialConstants(self):
# Testing for mission critical constants
socket.AF_INET