#5421: merge with 3.1.
This commit is contained in:
commit
4c1aebd88b
|
@ -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
|
||||
|
|
Loading…
Reference in New Issue