02-subscribe-persistence-flipflop.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #!/usr/bin/env python3
  2. # Test switching between persistence and a clean session.
  3. #
  4. # Bug #874:
  5. #
  6. #
  7. # mosquitto_sub -i sub -t 'topic' -v -p 29883 -q 1 -d -c
  8. # ^C
  9. # mosquitto_sub -i sub -t 'topic' -v -p 29883 -q 1 -d
  10. # ^C
  11. #
  12. # SUBSCRIBE to topic is no longer respected by mosquitto
  13. #
  14. # run:
  15. #
  16. # mosquitto_sub -i sub -t 'topic' -v -p 29883 -q 1 -d -c
  17. #
  18. # and in a separate shell
  19. #
  20. # mosquitto_pub -i pub -t topic -m 'hello' -p 29883 -q 1
  21. #
  22. # sub does not receive the message
  23. from mosq_test_helper import *
  24. def do_test(proto_ver):
  25. rc = 1
  26. keepalive = 60
  27. connect_packet_sub_persistent = mosq_test.gen_connect("flipflop-test", keepalive=keepalive, clean_session=False, proto_ver=proto_ver)
  28. connect_packet_sub_clean = mosq_test.gen_connect("flipflop-test", keepalive=keepalive, clean_session=True, proto_ver=proto_ver)
  29. connack_packet_sub = mosq_test.gen_connack(rc=0, proto_ver=proto_ver)
  30. connect_packet_pub = mosq_test.gen_connect("flipflop-test-pub", keepalive=keepalive, proto_ver=proto_ver)
  31. connack_packet_pub = mosq_test.gen_connack(rc=0, proto_ver=proto_ver)
  32. mid=1
  33. subscribe_packet = mosq_test.gen_subscribe(mid, "flipflop/test", 1, proto_ver=proto_ver)
  34. suback_packet = mosq_test.gen_suback(mid, 1, proto_ver=proto_ver)
  35. mid=1
  36. publish_packet = mosq_test.gen_publish("flipflop/test", qos=1, mid=mid, payload="message", proto_ver=proto_ver)
  37. puback_packet = mosq_test.gen_puback(mid, proto_ver=proto_ver)
  38. port = mosq_test.get_port()
  39. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  40. try:
  41. # mosquitto_sub -i sub -t 'topic' -q 1 -d -c
  42. sub_sock = mosq_test.do_client_connect(connect_packet_sub_persistent, connack_packet_sub, port=port)
  43. mosq_test.do_send_receive(sub_sock, subscribe_packet, suback_packet, "subscribe persistent 1")
  44. # And disconnect
  45. sub_sock.close()
  46. # mosquitto_sub -i sub -t 'topic' -q 1 -d
  47. sub_sock = mosq_test.do_client_connect(connect_packet_sub_clean, connack_packet_sub, port=port)
  48. mosq_test.do_send_receive(sub_sock, subscribe_packet, suback_packet, "subscribe clean")
  49. # And disconnect
  50. sub_sock.close()
  51. # mosquitto_sub -i sub -t 'topic' -v -q 1 -d -c
  52. sub_sock = mosq_test.do_client_connect(connect_packet_sub_persistent, connack_packet_sub, port=port)
  53. mosq_test.do_send_receive(sub_sock, subscribe_packet, suback_packet, "subscribe persistent 2")
  54. # and in a separate shell
  55. #
  56. # mosquitto_pub -i pub -t topic -m 'hello' -p 29883 -q 1
  57. pub_sock = mosq_test.do_client_connect(connect_packet_pub, connack_packet_pub, port=port)
  58. mosq_test.do_send_receive(pub_sock, publish_packet, puback_packet, "publish")
  59. mosq_test.expect_packet(sub_sock, "publish receive", publish_packet)
  60. rc = 0
  61. sub_sock.close()
  62. except mosq_test.TestError:
  63. pass
  64. finally:
  65. broker.terminate()
  66. broker.wait()
  67. (stdo, stde) = broker.communicate()
  68. if rc:
  69. print(stde.decode('utf-8'))
  70. print("proto_ver=%d" % (proto_ver))
  71. exit(rc)
  72. do_test(proto_ver=4)
  73. do_test(proto_ver=5)
  74. exit(0)