summaryrefslogtreecommitdiffstatshomepage
path: root/tests/net_hosted/connect_timeout.py
blob: 5f35047c8c8921fcfdf09f11c6a8f085e6919689 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
# Test that socket.connect() on a socket with timeout raises EINPROGRESS or ETIMEDOUT appropriately.

import errno
import socket


def test(peer_addr, timeout, expected_exc):
    s = socket.socket()
    s.settimeout(timeout)
    try:
        s.connect(peer_addr)
        print("OK")
    except OSError as er:
        print(er.args[0] in expected_exc)
    s.close()


if __name__ == "__main__":
    # This test needs an address that doesn't respond to TCP connections.
    # 1.1.1.1:8000 seem to reliably timeout, so use that.
    addr = socket.getaddrinfo("1.1.1.1", 8000)[0][-1]

    test(addr, 0, (errno.EINPROGRESS,))
    test(addr, 1, (errno.ETIMEDOUT, "timed out"))  # CPython uses a string instead of errno