02-subpub-qos2-1322.py 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. #!/usr/bin/env python3
  2. # Test for issue 1322:
  3. ## restart mosquitto
  4. #sudo systemctl restart mosquitto.service
  5. #
  6. ## listen on topic1
  7. #mosquitto_sub -t "topic1"
  8. #
  9. ## publish to topic1 without clean session
  10. #mosquitto_pub -t "topic1" -q 2 -c --id "foobar" -m "message1"
  11. ## message1 on topic1 is received as expected
  12. #
  13. ## publish to topic2 without clean session
  14. ## IMPORTANT: no subscription to this topic is present on broker!
  15. #mosquitto_pub -t "topic2" -q 2 -c --id "foobar" -m "message2"
  16. ## this goes nowhere, as no subscriber present
  17. #
  18. ## publish to topic1 without clean session
  19. #mosquitto_pub -t "topic1" -q 2 -c --id "foobar" -m "message3"
  20. ## message3 on topic1 IS NOT RECEIVED
  21. #
  22. ## listen on topic2
  23. #mosquitto_sub -t "topic2"
  24. #
  25. ## publish to topic1 without clean session
  26. #mosquitto_pub -t "topic1" -q 2 -c --id "foobar" -m "message4"
  27. ## message2 on topic2 is received incorrectly
  28. #
  29. ## publish to topic1 without clean session
  30. #mosquitto_pub -t "topic1" -q 2 -c --id "foobar" -m "message5"
  31. ## message5 on topic1 is received as expected (message4 was dropped)
  32. from mosq_test_helper import *
  33. def do_test(proto_ver):
  34. rc = 1
  35. keepalive = 60
  36. pub_connect_packet = mosq_test.gen_connect("pub", keepalive=keepalive, clean_session=False, proto_ver=proto_ver, session_expiry=60)
  37. pub_connack1_packet = mosq_test.gen_connack(rc=0, proto_ver=proto_ver)
  38. pub_connack2_packet = mosq_test.gen_connack(rc=0, flags=1, proto_ver=proto_ver)
  39. sub1_connect_packet = mosq_test.gen_connect("sub1", keepalive=keepalive, proto_ver=proto_ver)
  40. sub1_connack_packet = mosq_test.gen_connack(rc=0, proto_ver=proto_ver)
  41. sub2_connect_packet = mosq_test.gen_connect("sub2", keepalive=keepalive, proto_ver=proto_ver)
  42. sub2_connack_packet = mosq_test.gen_connack(rc=0, proto_ver=proto_ver)
  43. mid = 1
  44. subscribe1_packet = mosq_test.gen_subscribe(mid, "topic1", 0, proto_ver=proto_ver)
  45. suback1_packet = mosq_test.gen_suback(mid, 0, proto_ver=proto_ver)
  46. mid = 1
  47. subscribe2_packet = mosq_test.gen_subscribe(mid, "topic2", 0, proto_ver=proto_ver)
  48. suback2_packet = mosq_test.gen_suback(mid, 0, proto_ver=proto_ver)
  49. # All publishes have the same mid
  50. mid = 1
  51. pubrec_packet = mosq_test.gen_pubrec(mid, proto_ver=proto_ver)
  52. pubrel_packet = mosq_test.gen_pubrel(mid, proto_ver=proto_ver)
  53. pubcomp_packet = mosq_test.gen_pubcomp(mid, proto_ver=proto_ver)
  54. publish1s_packet = mosq_test.gen_publish("topic1", qos=2, mid=mid, payload="message1", proto_ver=proto_ver)
  55. publish2s_packet = mosq_test.gen_publish("topic2", qos=2, mid=mid, payload="message2", proto_ver=proto_ver)
  56. publish3s_packet = mosq_test.gen_publish("topic1", qos=2, mid=mid, payload="message3", proto_ver=proto_ver)
  57. publish4s_packet = mosq_test.gen_publish("topic1", qos=2, mid=mid, payload="message4", proto_ver=proto_ver)
  58. publish5s_packet = mosq_test.gen_publish("topic1", qos=2, mid=mid, payload="message5", proto_ver=proto_ver)
  59. publish1r_packet = mosq_test.gen_publish("topic1", qos=0, payload="message1", proto_ver=proto_ver)
  60. publish2r_packet = mosq_test.gen_publish("topic2", qos=0, payload="message2", proto_ver=proto_ver)
  61. publish3r_packet = mosq_test.gen_publish("topic1", qos=0, payload="message3", proto_ver=proto_ver)
  62. publish4r_packet = mosq_test.gen_publish("topic1", qos=0, payload="message4", proto_ver=proto_ver)
  63. publish5r_packet = mosq_test.gen_publish("topic1", qos=0, payload="message5", proto_ver=proto_ver)
  64. port = mosq_test.get_port()
  65. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  66. try:
  67. sub1 = mosq_test.do_client_connect(sub1_connect_packet, sub1_connack_packet, timeout=10, port=port)
  68. mosq_test.do_send_receive(sub1, subscribe1_packet, suback1_packet, "suback1")
  69. pub = mosq_test.do_client_connect(pub_connect_packet, pub_connack1_packet, timeout=10, port=port)
  70. mosq_test.do_send_receive(pub, publish1s_packet, pubrec_packet, "pubrec1")
  71. mosq_test.do_send_receive(pub, pubrel_packet, pubcomp_packet, "pubcomp1")
  72. pub.close()
  73. mosq_test.expect_packet(sub1, "publish1", publish1r_packet)
  74. pub = mosq_test.do_client_connect(pub_connect_packet, pub_connack2_packet, timeout=10, port=port)
  75. mosq_test.do_send_receive(pub, publish2s_packet, pubrec_packet, "pubrec2")
  76. mosq_test.do_send_receive(pub, pubrel_packet, pubcomp_packet, "pubcomp2")
  77. pub.close()
  78. # We expect nothing on sub1
  79. mosq_test.do_ping(sub1, error_string="pingresp1")
  80. pub = mosq_test.do_client_connect(pub_connect_packet, pub_connack2_packet, timeout=10, port=port)
  81. mosq_test.do_send_receive(pub, publish3s_packet, pubrec_packet, "pubrec3")
  82. mosq_test.do_send_receive(pub, pubrel_packet, pubcomp_packet, "pubcomp3")
  83. pub.close()
  84. mosq_test.expect_packet(sub1, "publish3", publish3r_packet)
  85. sub2 = mosq_test.do_client_connect(sub2_connect_packet, sub2_connack_packet, timeout=10, port=port)
  86. mosq_test.do_send_receive(sub2, subscribe2_packet, suback2_packet, "suback2")
  87. pub = mosq_test.do_client_connect(pub_connect_packet, pub_connack2_packet, timeout=10, port=port)
  88. mosq_test.do_send_receive(pub, publish4s_packet, pubrec_packet, "pubrec4")
  89. mosq_test.do_send_receive(pub, pubrel_packet, pubcomp_packet, "pubcomp4")
  90. pub.close()
  91. # We expect nothing on sub2
  92. mosq_test.do_ping(sub2, error_string="pingresp2")
  93. mosq_test.expect_packet(sub1, "publish4", publish4r_packet)
  94. pub = mosq_test.do_client_connect(pub_connect_packet, pub_connack2_packet, timeout=10, port=port)
  95. mosq_test.do_send_receive(pub, publish5s_packet, pubrec_packet, "pubrec5")
  96. mosq_test.do_send_receive(pub, pubrel_packet, pubcomp_packet, "pubcomp5")
  97. pub.close()
  98. # We expect nothing on sub2
  99. mosq_test.do_ping(sub2, error_string="pingresp2")
  100. mosq_test.expect_packet(sub1, "publish5", publish5r_packet)
  101. rc = 0
  102. sub2.close()
  103. sub1.close()
  104. except mosq_test.TestError:
  105. pass
  106. finally:
  107. broker.terminate()
  108. broker.wait()
  109. (stdo, stde) = broker.communicate()
  110. if rc:
  111. print(stde.decode('utf-8'))
  112. print("proto_ver=%d" % (proto_ver))
  113. exit(rc)
  114. do_test(proto_ver=4)
  115. do_test(proto_ver=5)
  116. exit(0)