02-subpub-qos2-pubrec-error.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. #!/usr/bin/env python3
  2. # Test whether a PUBREC with reason code >= 0x80 is handled correctly
  3. from mosq_test_helper import *
  4. def helper(port):
  5. connect_packet = mosq_test.gen_connect("test-helper", keepalive=60)
  6. connack_packet = mosq_test.gen_connack(rc=0)
  7. mid = 1
  8. publish_1_packet = mosq_test.gen_publish("qos2/pubrec/rejected", qos=2, mid=mid, payload="rejected-message")
  9. pubrec_1_packet = mosq_test.gen_pubrec(mid)
  10. pubrel_1_packet = mosq_test.gen_pubrel(mid)
  11. pubcomp_1_packet = mosq_test.gen_pubcomp(mid)
  12. mid = 2
  13. publish_2_packet = mosq_test.gen_publish("qos2/pubrec/accepted", qos=2, mid=mid, payload="accepted-message")
  14. pubrec_2_packet = mosq_test.gen_pubrec(mid)
  15. pubrel_2_packet = mosq_test.gen_pubrel(mid)
  16. pubcomp_2_packet = mosq_test.gen_pubcomp(mid)
  17. sock = mosq_test.do_client_connect(connect_packet, connack_packet, connack_error="helper connack", port=port)
  18. mosq_test.do_send_receive(sock, publish_1_packet, pubrec_1_packet, "helper pubrec")
  19. mosq_test.do_send_receive(sock, pubrel_1_packet, pubcomp_1_packet, "helper pubcomp")
  20. mosq_test.do_send_receive(sock, publish_2_packet, pubrec_2_packet, "helper pubrec")
  21. mosq_test.do_send_receive(sock, pubrel_2_packet, pubcomp_2_packet, "helper pubcomp")
  22. sock.close()
  23. def do_test():
  24. rc = 1
  25. keepalive = 60
  26. connect_packet = mosq_test.gen_connect("pub-qo2-timeout-test", keepalive=keepalive, proto_ver=5)
  27. connack_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  28. mid = 1
  29. subscribe_packet = mosq_test.gen_subscribe(mid, "qos2/pubrec/+", 2, proto_ver=5)
  30. suback_packet = mosq_test.gen_suback(mid, 2, proto_ver=5)
  31. mid = 1
  32. publish_1_packet = mosq_test.gen_publish("qos2/pubrec/rejected", qos=2, mid=mid, payload="rejected-message", proto_ver=5)
  33. pubrec_1_packet = mosq_test.gen_pubrec(mid, proto_ver=5, reason_code=0x80)
  34. mid = 2
  35. publish_2_packet = mosq_test.gen_publish("qos2/pubrec/accepted", qos=2, mid=mid, payload="accepted-message", proto_ver=5)
  36. pubrec_2_packet = mosq_test.gen_pubrec(mid, proto_ver=5)
  37. pubrel_2_packet = mosq_test.gen_pubrel(mid, proto_ver=5)
  38. pubcomp_2_packet = mosq_test.gen_pubcomp(mid, proto_ver=5)
  39. port = mosq_test.get_port()
  40. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  41. try:
  42. sock = mosq_test.do_client_connect(connect_packet, connack_packet, port=port)
  43. mosq_test.do_send_receive(sock, subscribe_packet, suback_packet, "suback")
  44. helper(port)
  45. # Should have now received a publish command
  46. mosq_test.expect_packet(sock, "publish 1", publish_1_packet)
  47. sock.send(pubrec_1_packet)
  48. mosq_test.expect_packet(sock, "publish 2", publish_2_packet)
  49. mosq_test.do_send_receive(sock, pubrec_2_packet, pubrel_2_packet, "pubrel 2")
  50. sock.send(pubcomp_2_packet)
  51. rc = 0
  52. sock.close()
  53. except mosq_test.TestError:
  54. pass
  55. finally:
  56. broker.terminate()
  57. broker.wait()
  58. (stdo, stde) = broker.communicate()
  59. if rc:
  60. print(stde.decode('utf-8'))
  61. print("proto_ver=%d" % (proto_ver))
  62. exit(rc)
  63. do_test()
  64. exit(0)