diff options
author | Thorsten von Eicken <tve@voneicken.com> | 2020-04-02 10:01:16 -0700 |
---|---|---|
committer | Damien George <damien@micropython.org> | 2021-02-17 11:50:54 +1100 |
commit | 2c1299b0071c2c528cc01e3cde9eb22743820176 (patch) | |
tree | 0679eb4daf9522f30cec65b3d7bce494029482b9 /tests/net_inet/ssl_errors.py | |
parent | 2eed9780ba7074de9e464a2bc771ad14f0332a6c (diff) | |
download | micropython-2c1299b0071c2c528cc01e3cde9eb22743820176.tar.gz micropython-2c1299b0071c2c528cc01e3cde9eb22743820176.zip |
extmod/modussl: Fix ussl read/recv/send/write errors when non-blocking.
Also fix related problems with socket on esp32, improve docs for
wrap_socket, and add more tests.
Diffstat (limited to 'tests/net_inet/ssl_errors.py')
-rw-r--r-- | tests/net_inet/ssl_errors.py | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/tests/net_inet/ssl_errors.py b/tests/net_inet/ssl_errors.py new file mode 100644 index 0000000000..fd281b1c49 --- /dev/null +++ b/tests/net_inet/ssl_errors.py @@ -0,0 +1,51 @@ +# test that socket.connect() on a non-blocking socket raises EINPROGRESS +# and that an immediate write/send/read/recv does the right thing + +import sys + +try: + import uerrno as errno, usocket as socket, ussl as ssl +except: + import errno, socket, ssl + + +def test(addr, hostname, block=True): + print("---", hostname or addr) + s = socket.socket() + s.setblocking(block) + try: + s.connect(addr) + print("connected") + except OSError as e: + if e.args[0] != errno.EINPROGRESS: + raise + print("EINPROGRESS") + + try: + if sys.implementation.name == "micropython": + s = ssl.wrap_socket(s, do_handshake=block) + else: + s = ssl.wrap_socket(s, do_handshake_on_connect=block) + print("wrap: True") + except OSError: + print("wrap: error") + + if not block: + try: + while s.write(b"0") is None: + pass + except (ValueError, OSError): # CPython raises ValueError, MicroPython raises OSError + print("write: error") + s.close() + + +if __name__ == "__main__": + # connect to plain HTTP port, oops! + addr = socket.getaddrinfo("micropython.org", 80)[0][-1] + test(addr, None) + # connect to plain HTTP port, oops! + addr = socket.getaddrinfo("micropython.org", 80)[0][-1] + test(addr, None, False) + # connect to server with self-signed cert, oops! + addr = socket.getaddrinfo("test.mosquitto.org", 8883)[0][-1] + test(addr, "test.mosquitto.org") |