kopia lustrzana https://github.com/micropython/micropython
tests: Add socket timeout tests for connect and recv.
Signed-off-by: stijn <stijn@ignitron.net>pull/12810/head
rodzic
a0127919bc
commit
07f229e030
|
@ -0,0 +1,37 @@
|
||||||
|
import errno
|
||||||
|
import socket
|
||||||
|
|
||||||
|
PORT = 8000
|
||||||
|
|
||||||
|
|
||||||
|
# Server
|
||||||
|
def instance0():
|
||||||
|
multitest.globals(IP=multitest.get_network_ip())
|
||||||
|
s = socket.socket()
|
||||||
|
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
|
s.bind(socket.getaddrinfo("0.0.0.0", PORT)[0][-1])
|
||||||
|
s.listen()
|
||||||
|
multitest.next()
|
||||||
|
s2, _ = s.accept()
|
||||||
|
s2.settimeout(0.2)
|
||||||
|
try:
|
||||||
|
s2.recv(1)
|
||||||
|
except OSError as er:
|
||||||
|
print(er.errno in (errno.ETIMEDOUT, errno.EAGAIN) or str(er) == "timed out")
|
||||||
|
multitest.next()
|
||||||
|
s2.close()
|
||||||
|
s.close()
|
||||||
|
|
||||||
|
|
||||||
|
# Client
|
||||||
|
def instance1():
|
||||||
|
multitest.next()
|
||||||
|
s = socket.socket()
|
||||||
|
s.connect(socket.getaddrinfo(IP, PORT)[0][-1])
|
||||||
|
s.settimeout(0.2)
|
||||||
|
try:
|
||||||
|
s.recv(1)
|
||||||
|
except OSError as er:
|
||||||
|
print(er.errno in (errno.ETIMEDOUT, errno.EAGAIN) or str(er) == "timed out")
|
||||||
|
multitest.next()
|
||||||
|
s.close()
|
|
@ -0,0 +1,6 @@
|
||||||
|
--- instance0 ---
|
||||||
|
True
|
||||||
|
NEXT
|
||||||
|
--- instance1 ---
|
||||||
|
True
|
||||||
|
NEXT
|
|
@ -0,0 +1,16 @@
|
||||||
|
import errno
|
||||||
|
import socket
|
||||||
|
|
||||||
|
|
||||||
|
def test(peer_addr):
|
||||||
|
s = socket.socket()
|
||||||
|
s.settimeout(1)
|
||||||
|
try:
|
||||||
|
s.connect(peer_addr)
|
||||||
|
except OSError as er:
|
||||||
|
print(er.errno == errno.ETIMEDOUT or str(er) == "timed out")
|
||||||
|
s.close()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
test(socket.getaddrinfo("192.0.0.0", 8888)[0][-1])
|
|
@ -0,0 +1 @@
|
||||||
|
True
|
Ładowanie…
Reference in New Issue