02-subpub-qos1-message-expiry-will.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #!/usr/bin/env python3
  2. # Test whether the broker reduces the message expiry interval when republishing a will.
  3. # MQTT v5
  4. # Client connects with clean session set false, subscribes with qos=1, then disconnects
  5. # Helper publishes two messages, one with a short expiry and one with a long expiry
  6. # We wait until the short expiry will have expired but the long one not.
  7. # Client reconnects, expects delivery of the long expiry message with a reduced
  8. # expiry interval property.
  9. from mosq_test_helper import *
  10. def do_test():
  11. rc = 1
  12. mid = 53
  13. keepalive = 60
  14. props = mqtt5_props.gen_uint32_prop(mqtt5_props.PROP_SESSION_EXPIRY_INTERVAL, 60)
  15. connect_packet = mosq_test.gen_connect("subpub-qos0-test", keepalive=keepalive, proto_ver=5, clean_session=False, properties=props)
  16. connack1_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  17. connack2_packet = mosq_test.gen_connack(rc=0, proto_ver=5, flags=1)
  18. subscribe_packet = mosq_test.gen_subscribe(mid, "subpub/qos1", 1, proto_ver=5)
  19. suback_packet = mosq_test.gen_suback(mid, 1, proto_ver=5)
  20. props = mqtt5_props.gen_uint32_prop(mqtt5_props.PROP_MESSAGE_EXPIRY_INTERVAL, 10)
  21. helper_connect = mosq_test.gen_connect("helper", proto_ver=5, will_topic="subpub/qos1", will_qos=1, will_payload=b"message", will_properties=props, keepalive=2)
  22. helper_connack = mosq_test.gen_connack(rc=0, proto_ver=5)
  23. #mid=2
  24. props = mqtt5_props.gen_uint32_prop(mqtt5_props.PROP_MESSAGE_EXPIRY_INTERVAL, 10)
  25. publish2s_packet = mosq_test.gen_publish("subpub/qos1", mid=mid, qos=1, payload="message2", proto_ver=5, properties=props)
  26. puback2s_packet = mosq_test.gen_puback(mid)
  27. port = mosq_test.get_port()
  28. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  29. try:
  30. sock = mosq_test.do_client_connect(connect_packet, connack1_packet, timeout=20, port=port)
  31. mosq_test.do_send_receive(sock, subscribe_packet, suback_packet, "suback")
  32. sock.close()
  33. helper = mosq_test.do_client_connect(helper_connect, helper_connack, timeout=20, port=port)
  34. time.sleep(2)
  35. sock = mosq_test.do_client_connect(connect_packet, connack2_packet, timeout=20, port=port)
  36. packet = sock.recv(len(publish2s_packet))
  37. for i in range(10, 5, -1):
  38. props = mqtt5_props.gen_uint32_prop(mqtt5_props.PROP_MESSAGE_EXPIRY_INTERVAL, i)
  39. publish2r_packet = mosq_test.gen_publish("subpub/qos1", mid=1, qos=1, payload="message", proto_ver=5, properties=props)
  40. if packet == publish2r_packet:
  41. rc = 0
  42. break
  43. sock.close()
  44. except mosq_test.TestError:
  45. pass
  46. finally:
  47. broker.terminate()
  48. broker.wait()
  49. (stdo, stde) = broker.communicate()
  50. if rc:
  51. print(stde.decode('utf-8'))
  52. print("proto_ver=%d" % (proto_ver))
  53. exit(rc)
  54. do_test()
  55. exit(0)