02-shared-qos0-v5.py 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #!/usr/bin/env python3
  2. # Test whether shared subscriptions work
  3. # Client 1 subscribes to #, non shared. Should receive everything.
  4. # Client 2 subscribes to $share/one/share-test
  5. # Client 3 subscribes to $share/one/share-test and $share/two/share-test
  6. # Client 4 subscribes to $share/two/share-test
  7. # Client 5 subscribes to $share/one/share-test
  8. # A publish to "share-test" should always go to client 1.
  9. # The first publish should also go to client 2 (share one) and client 3 (share two)
  10. # The second publish should also go to client 3 (share one) and client 4 (share two)
  11. # The third publish should also go to client 3 (share two) and client 5 (share one)
  12. from mosq_test_helper import *
  13. rc = 1
  14. keepalive = 60
  15. mid = 1
  16. connect1_packet = mosq_test.gen_connect("client1", keepalive=keepalive, proto_ver=5)
  17. connack1_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  18. connect2_packet = mosq_test.gen_connect("client2", keepalive=keepalive, proto_ver=5)
  19. connack2_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  20. connect3_packet = mosq_test.gen_connect("client3", keepalive=keepalive, proto_ver=5)
  21. connack3_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  22. connect4_packet = mosq_test.gen_connect("client4", keepalive=keepalive, proto_ver=5)
  23. connack4_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  24. connect5_packet = mosq_test.gen_connect("client5", keepalive=keepalive, proto_ver=5)
  25. connack5_packet = mosq_test.gen_connack(rc=0, proto_ver=5)
  26. subscribe1_packet = mosq_test.gen_subscribe(mid, "#", 0, proto_ver=5)
  27. suback1_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  28. subscribe2_packet = mosq_test.gen_subscribe(mid, "$share/one/share-test", 0, proto_ver=5)
  29. suback2_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  30. subscribe3a_packet = mosq_test.gen_subscribe(mid, "$share/one/share-test", 0, proto_ver=5)
  31. suback3a_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  32. subscribe3b_packet = mosq_test.gen_subscribe(mid, "$share/two/share-test", 0, proto_ver=5)
  33. suback3b_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  34. subscribe4_packet = mosq_test.gen_subscribe(mid, "$share/two/share-test", 0, proto_ver=5)
  35. suback4_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  36. subscribe5_packet = mosq_test.gen_subscribe(mid, "$share/one/share-test", 0, proto_ver=5)
  37. suback5_packet = mosq_test.gen_suback(mid, 0, proto_ver=5)
  38. publish1_packet = mosq_test.gen_publish("share-test", qos=0, payload="message1", proto_ver=5)
  39. publish2_packet = mosq_test.gen_publish("share-test", qos=0, payload="message2", proto_ver=5)
  40. publish3_packet = mosq_test.gen_publish("share-test", qos=0, payload="message3", proto_ver=5)
  41. mid = 2
  42. unsubscribe1_packet = mosq_test.gen_unsubscribe(mid, "#", proto_ver=5)
  43. unsuback1_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  44. unsubscribe2_packet = mosq_test.gen_unsubscribe(mid, "$share/one/share-test", proto_ver=5)
  45. unsuback2_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  46. unsubscribe3a_packet = mosq_test.gen_unsubscribe(mid, "$share/one/share-test", proto_ver=5)
  47. unsuback3a_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  48. unsubscribe3b_packet = mosq_test.gen_unsubscribe(mid, "$share/two/share-test", proto_ver=5)
  49. unsuback3b_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  50. unsubscribe4_packet = mosq_test.gen_unsubscribe(mid, "$share/two/share-test", proto_ver=5)
  51. unsuback4_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  52. unsubscribe5_packet = mosq_test.gen_unsubscribe(mid, "$share/one/share-test", proto_ver=5)
  53. unsuback5_packet = mosq_test.gen_unsuback(mid, proto_ver=5)
  54. port = mosq_test.get_port()
  55. broker = mosq_test.start_broker(filename=os.path.basename(__file__), port=port)
  56. try:
  57. sock1 = mosq_test.do_client_connect(connect1_packet, connack1_packet, timeout=20, port=port)
  58. sock2 = mosq_test.do_client_connect(connect2_packet, connack2_packet, timeout=20, port=port)
  59. sock3 = mosq_test.do_client_connect(connect3_packet, connack3_packet, timeout=20, port=port)
  60. sock4 = mosq_test.do_client_connect(connect4_packet, connack4_packet, timeout=20, port=port)
  61. sock5 = mosq_test.do_client_connect(connect5_packet, connack5_packet, timeout=20, port=port)
  62. mosq_test.do_send_receive(sock1, subscribe1_packet, suback1_packet, "suback1")
  63. mosq_test.do_send_receive(sock2, subscribe2_packet, suback2_packet, "suback2")
  64. mosq_test.do_send_receive(sock3, subscribe3a_packet, suback3a_packet, "suback3a")
  65. mosq_test.do_send_receive(sock3, subscribe3b_packet, suback3b_packet, "suback3b")
  66. mosq_test.do_send_receive(sock4, subscribe4_packet, suback4_packet, "suback4")
  67. mosq_test.do_send_receive(sock5, subscribe5_packet, suback5_packet, "suback5")
  68. sock1.send(publish1_packet)
  69. mosq_test.expect_packet(sock1, "publish1 1", publish1_packet)
  70. mosq_test.expect_packet(sock2, "publish1 2", publish1_packet)
  71. mosq_test.expect_packet(sock3, "publish1 3", publish1_packet)
  72. sock1.send(publish2_packet)
  73. mosq_test.expect_packet(sock1, "publish2 1", publish2_packet)
  74. mosq_test.expect_packet(sock3, "publish2 3", publish2_packet)
  75. mosq_test.expect_packet(sock4, "publish2 4", publish2_packet)
  76. sock1.send(publish3_packet)
  77. mosq_test.expect_packet(sock1, "publish3 1", publish3_packet)
  78. mosq_test.expect_packet(sock3, "publish3 3", publish3_packet)
  79. mosq_test.expect_packet(sock5, "publish3 5", publish3_packet)
  80. mosq_test.do_send_receive(sock1, unsubscribe1_packet, unsuback1_packet, "unsuback1")
  81. mosq_test.do_send_receive(sock2, unsubscribe2_packet, unsuback2_packet, "unsuback2")
  82. mosq_test.do_send_receive(sock3, unsubscribe3a_packet, unsuback3a_packet, "unsuback3a")
  83. mosq_test.do_send_receive(sock3, unsubscribe3b_packet, unsuback3b_packet, "unsuback3b")
  84. mosq_test.do_send_receive(sock4, unsubscribe4_packet, unsuback4_packet, "unsuback4")
  85. mosq_test.do_send_receive(sock5, unsubscribe5_packet, unsuback5_packet, "unsuback5")
  86. rc = 0
  87. sock1.close()
  88. sock2.close()
  89. sock3.close()
  90. sock4.close()
  91. sock5.close()
  92. except mosq_test.TestError:
  93. pass
  94. finally:
  95. broker.terminate()
  96. broker.wait()
  97. (stdo, stde) = broker.communicate()
  98. if rc:
  99. print(stde.decode('utf-8'))
  100. exit(rc)