02-subpub-qos0-send-retain.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #!/usr/bin/env python3
  2. # Test whether "send retain" subscribe options work
  3. # MQTT v5
  4. from mosq_test_helper import *
  5. def do_test():
  6. rc = 1
  7. keepalive = 60
  8. connect_packet = mosq_test.gen_connect("subpub-test", keepalive=keepalive, proto_ver=5)
  9. connack_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  10. mid = 530
  11. subscribe1_packet = mosq_test.gen_subscribe(mid, "subpub/always", 0 | mqtt5_opts.MQTT_SUB_OPT_SEND_RETAIN_ALWAYS, proto_ver=5)
  12. suback1_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  13. mid = 531
  14. subscribe2_packet = mosq_test.gen_subscribe(mid, "subpub/new", 0 | mqtt5_opts.MQTT_SUB_OPT_SEND_RETAIN_NEW, proto_ver=5)
  15. suback2_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  16. mid = 532
  17. subscribe3_packet = mosq_test.gen_subscribe(mid, "subpub/never", 0 | mqtt5_opts.MQTT_SUB_OPT_SEND_RETAIN_NEVER, proto_ver=5)
  18. suback3_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  19. publish1_packet = mosq_test.gen_publish("subpub/always", qos=0, retain=True, payload="message", proto_ver=5)
  20. publish2_packet = mosq_test.gen_publish("subpub/new", qos=0, retain=True, payload="message", proto_ver=5)
  21. publish3_packet = mosq_test.gen_publish("subpub/never", qos=0, retain=True, payload="message", proto_ver=5)
  22. publish1r1_packet = mosq_test.gen_publish("subpub/always", qos=0, retain=True, payload="message", proto_ver=5)
  23. publish1r2_packet = mosq_test.gen_publish("subpub/always", qos=0, retain=True, payload="message", proto_ver=5)
  24. publish2r1_packet = mosq_test.gen_publish("subpub/new", qos=0, retain=True, payload="message", proto_ver=5)
  25. publish2r2_packet = mosq_test.gen_publish("subpub/new", qos=0, retain=False, payload="message", proto_ver=5)
  26. publish3r1_packet = mosq_test.gen_publish("subpub/never", qos=0, retain=False, payload="message", proto_ver=5)
  27. publish3r2_packet = mosq_test.gen_publish("subpub/never", qos=0, retain=False, payload="message", proto_ver=5)
  28. port = mosq_test.get_port()
  29. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  30. try:
  31. sock = mosq_test.do_client_connect(connect_packet, connack_packet, timeout=5, port=port)
  32. sock.send(publish1_packet)
  33. sock.send(publish2_packet)
  34. sock.send(publish3_packet)
  35. # Don't expect a message after this
  36. mosq_test.do_send_receive(sock, subscribe3_packet, suback3_packet, "suback3")
  37. # Don't expect a message after this
  38. mosq_test.do_send_receive(sock, subscribe3_packet, suback3_packet, "suback3")
  39. # Expect a message after this, because it is the first subscribe
  40. mosq_test.do_send_receive(sock, subscribe2_packet, suback2_packet, "suback2")
  41. mosq_test.expect_packet(sock, "publish2r1", publish2r1_packet)
  42. # Don't expect a message after this, it is the second subscribe
  43. mosq_test.do_send_receive(sock, subscribe2_packet, suback2_packet, "suback2")
  44. # Always expect a message after this
  45. mosq_test.do_send_receive(sock, subscribe1_packet, suback1_packet, "suback1")
  46. mosq_test.expect_packet(sock, "publish1r1", publish1r1_packet)
  47. # Always expect a message after this
  48. mosq_test.do_send_receive(sock, subscribe1_packet, suback1_packet, "suback1")
  49. mosq_test.expect_packet(sock, "publish1r1", publish1r2_packet)
  50. rc = 0
  51. sock.close()
  52. except mosq_test.TestError:
  53. pass
  54. finally:
  55. broker.terminate()
  56. broker.wait()
  57. (stdo, stde) = broker.communicate()
  58. if rc:
  59. print(stde.decode('utf-8'))
  60. exit(rc)
  61. do_test()
  62. exit(0)