mirror of https://github.com/python/cpython
(3.3->default) Issue #17269: Workaround for a platform bug in getaddrinfo on OSX
Without this patch socket.getaddrinfo crashed when called with some unusual argument combinations.
This commit is contained in:
commit
dc3e6cc452
|
@ -1201,6 +1201,9 @@ class GeneralModuleTests(unittest.TestCase):
|
||||||
# Issue #6697.
|
# Issue #6697.
|
||||||
self.assertRaises(UnicodeEncodeError, socket.getaddrinfo, 'localhost', '\uD800')
|
self.assertRaises(UnicodeEncodeError, socket.getaddrinfo, 'localhost', '\uD800')
|
||||||
|
|
||||||
|
# Issue 17269
|
||||||
|
socket.getaddrinfo("localhost", None, 0, 0, 0, socket.AI_NUMERICSERV)
|
||||||
|
|
||||||
def test_getnameinfo(self):
|
def test_getnameinfo(self):
|
||||||
# only IP addresses are allowed
|
# only IP addresses are allowed
|
||||||
self.assertRaises(OSError, socket.getnameinfo, ('mail.python.org',0), 0)
|
self.assertRaises(OSError, socket.getnameinfo, ('mail.python.org',0), 0)
|
||||||
|
|
|
@ -96,6 +96,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #17269: Workaround for socket.getaddrinfo crash on MacOS X
|
||||||
|
with port None or "0" and flags AI_NUMERICSERV.
|
||||||
|
|
||||||
- Issue #16986: ElementTree now correctly parses a string input not only when
|
- Issue #16986: ElementTree now correctly parses a string input not only when
|
||||||
an internal XML encoding is UTF-8 or US-ASCII.
|
an internal XML encoding is UTF-8 or US-ASCII.
|
||||||
|
|
||||||
|
|
|
@ -4978,6 +4978,15 @@ socket_getaddrinfo(PyObject *self, PyObject *args, PyObject* kwargs)
|
||||||
PyErr_SetString(PyExc_OSError, "Int or String expected");
|
PyErr_SetString(PyExc_OSError, "Int or String expected");
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
#ifdef __APPLE__
|
||||||
|
if ((flags & AI_NUMERICSERV) && (pptr == NULL || (pptr[0] == '0' && pptr[1] == 0))) {
|
||||||
|
/* On OSX upto at least OSX 10.8 getaddrinfo crashes
|
||||||
|
* if AI_NUMERICSERV is set and the servname is NULL or "0".
|
||||||
|
* This workaround avoids a segfault in libsystem.
|
||||||
|
*/
|
||||||
|
pptr = "00";
|
||||||
|
}
|
||||||
|
#endif
|
||||||
memset(&hints, 0, sizeof(hints));
|
memset(&hints, 0, sizeof(hints));
|
||||||
hints.ai_family = family;
|
hints.ai_family = family;
|
||||||
hints.ai_socktype = socktype;
|
hints.ai_socktype = socktype;
|
||||||
|
|
Loading…
Reference in New Issue