Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 3ac8c0a

Browse files
gh-98793: Fix typecheck in overlapped.c (#98835)
Co-authored-by: Kumar Aditya <[email protected]>
1 parent fc94d55 commit 3ac8c0a

File tree

4 files changed

+25
-5
lines changed

4 files changed

+25
-5
lines changed

Lib/test/test_asyncio/test_windows_events.py

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -239,6 +239,17 @@ def test_read_self_pipe_restart(self):
239239
self.close_loop(self.loop)
240240
self.assertFalse(self.loop.call_exception_handler.called)
241241

242+
def test_address_argument_type_error(self):
243+
# Regression test for https://github.com/python/cpython/issues/98793
244+
proactor = self.loop._proactor
245+
sock = socket.socket(type=socket.SOCK_DGRAM)
246+
bad_address = None
247+
with self.assertRaises(TypeError):
248+
proactor.connect(sock, bad_address)
249+
with self.assertRaises(TypeError):
250+
proactor.sendto(sock, b'abc', addr=bad_address)
251+
sock.close()
252+
242253

243254
class WinPolicyTests(test_utils.TestCase):
244255

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Fix argument typechecks in :func:`!_overlapped.WSAConnect` and :func:`!_overlapped.Overlapped.WSASendTo` functions.

Modules/clinic/overlapped.c.h

Lines changed: 9 additions & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

Modules/overlapped.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1674,7 +1674,7 @@ Overlapped_traverse(OverlappedObject *self, visitproc visit, void *arg)
16741674
_overlapped.WSAConnect
16751675
16761676
client_handle as ConnectSocket: HANDLE
1677-
address_as_bytes as AddressObj: object
1677+
address_as_bytes as AddressObj: object(subclass_of='&PyTuple_Type')
16781678
/
16791679
16801680
Bind a remote address to a connectionless (UDP) socket.
@@ -1683,7 +1683,7 @@ Bind a remote address to a connectionless (UDP) socket.
16831683
static PyObject *
16841684
_overlapped_WSAConnect_impl(PyObject *module, HANDLE ConnectSocket,
16851685
PyObject *AddressObj)
1686-
/*[clinic end generated code: output=ea0b4391e94dad63 input=169f8075e9ae7fa4]*/
1686+
/*[clinic end generated code: output=ea0b4391e94dad63 input=7cf65313d49c015a]*/
16871687
{
16881688
char AddressBuf[sizeof(struct sockaddr_in6)];
16891689
SOCKADDR *Address = (SOCKADDR*)AddressBuf;
@@ -1717,7 +1717,7 @@ _overlapped.Overlapped.WSASendTo
17171717
handle: HANDLE
17181718
buf as bufobj: Py_buffer
17191719
flags: DWORD
1720-
address_as_bytes as AddressObj: object
1720+
address_as_bytes as AddressObj: object(subclass_of='&PyTuple_Type')
17211721
/
17221722
17231723
Start overlapped sendto over a connectionless (UDP) socket.
@@ -1727,7 +1727,7 @@ static PyObject *
17271727
_overlapped_Overlapped_WSASendTo_impl(OverlappedObject *self, HANDLE handle,
17281728
Py_buffer *bufobj, DWORD flags,
17291729
PyObject *AddressObj)
1730-
/*[clinic end generated code: output=3cdedc4cfaeb70cd input=b7c1749a62e2e374]*/
1730+
/*[clinic end generated code: output=3cdedc4cfaeb70cd input=31f44cd4ab92fc33]*/
17311731
{
17321732
char AddressBuf[sizeof(struct sockaddr_in6)];
17331733
SOCKADDR *Address = (SOCKADDR*)AddressBuf;

0 commit comments

Comments
 (0)