01-keepalive-pingreq.py 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. #!/usr/bin/env python3
  2. # Test whether a client sends a pingreq after the keepalive time
  3. # The client should connect to port 1888 with keepalive=4, clean session set,
  4. # and client id 01-keepalive-pingreq
  5. # The client should send a PINGREQ message after the appropriate amount of time
  6. # (4 seconds after no traffic).
  7. from mosq_test_helper import *
  8. port = mosq_test.get_lib_port()
  9. rc = 1
  10. keepalive = 5
  11. connect_packet = mosq_test.gen_connect("01-keepalive-pingreq", keepalive=keepalive)
  12. connack_packet = mosq_test.gen_connack(rc=0)
  13. pingreq_packet = mosq_test.gen_pingreq()
  14. pingresp_packet = mosq_test.gen_pingresp()
  15. sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  16. sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
  17. sock.settimeout(10)
  18. sock.bind(('', port))
  19. sock.listen(5)
  20. client_args = sys.argv[1:]
  21. env = dict(os.environ)
  22. env['LD_LIBRARY_PATH'] = '../../lib:../../lib/cpp'
  23. try:
  24. pp = env['PYTHONPATH']
  25. except KeyError:
  26. pp = ''
  27. env['PYTHONPATH'] = '../../lib/python:'+pp
  28. client = mosq_test.start_client(filename=sys.argv[1].replace('/', '-'), cmd=client_args, env=env, port=port)
  29. try:
  30. (conn, address) = sock.accept()
  31. conn.settimeout(keepalive+10)
  32. mosq_test.do_receive_send(conn, connect_packet, connack_packet, "connect")
  33. mosq_test.expect_packet(conn, "pingreq", pingreq_packet)
  34. time.sleep(1.0)
  35. conn.send(pingresp_packet)
  36. mosq_test.expect_packet(conn, "pingreq", pingreq_packet)
  37. rc = 0
  38. conn.close()
  39. except mosq_test.TestError:
  40. pass
  41. finally:
  42. client.terminate()
  43. client.wait()
  44. sock.close()
  45. exit(rc)