mirror of https://github.com/python/cpython
#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,
|
self.assertRaises(socket.error, raise_gaierror,
|
||||||
"Error raising socket exception.")
|
"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):
|
def testCrucialConstants(self):
|
||||||
# Testing for mission critical constants
|
# Testing for mission critical constants
|
||||||
socket.AF_INET
|
socket.AF_INET
|
||||||
|
|
Loading…
Reference in New Issue