08-tls-psk-bridge.py 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #!/usr/bin/env python3
  2. from mosq_test_helper import *
  3. if sys.version < '2.7':
  4. print("WARNING: SSL not supported on Python 2.6")
  5. exit(0)
  6. def write_config1(filename, port1, port2):
  7. with open(filename, 'w') as f:
  8. f.write("allow_anonymous true\n")
  9. f.write("\n")
  10. f.write("psk_file 08-tls-psk-bridge.psk\n")
  11. f.write("\n")
  12. f.write("port %d\n" % (port1))
  13. f.write("\n")
  14. f.write("listener %d\n" % (port2))
  15. f.write("psk_hint hint\n")
  16. def write_config2(filename, port2, port3):
  17. with open(filename, 'w') as f:
  18. f.write("port %d\n" % (port3))
  19. f.write("allow_anonymous true\n")
  20. f.write("\n")
  21. f.write("connection bridge-psk\n")
  22. f.write("address localhost:%d\n" % (port2))
  23. f.write("topic psk/test out\n")
  24. f.write("bridge_identity psk-test\n")
  25. f.write("bridge_psk deadbeef\n")
  26. (port1, port2, port3) = mosq_test.get_port(3)
  27. conf_file1 = "08-tls-psk-bridge.conf"
  28. conf_file2 = "08-tls-psk-bridge.conf2"
  29. write_config1(conf_file1, port1, port2)
  30. write_config2(conf_file2, port2, port3)
  31. env = dict(os.environ)
  32. env['LD_LIBRARY_PATH'] = '../../lib:../../lib/cpp'
  33. try:
  34. pp = env['PYTHONPATH']
  35. except KeyError:
  36. pp = ''
  37. env['PYTHONPATH'] = '../../lib/python:'+pp
  38. rc = 1
  39. keepalive = 60
  40. connect_packet = mosq_test.gen_connect("no-psk-test-client", keepalive=keepalive)
  41. connack_packet = mosq_test.gen_connack(rc=0)
  42. mid = 1
  43. subscribe_packet = mosq_test.gen_subscribe(mid, "psk/test", 0)
  44. suback_packet = mosq_test.gen_suback(mid, 0)
  45. publish_packet = mosq_test.gen_publish(topic="psk/test", payload="message", qos=0)
  46. bridge_cmd = ['../../src/mosquitto', '-c', '08-tls-psk-bridge.conf2']
  47. broker = mosq_test.start_broker(filename=os.path.basename(__file__), use_conf=True, port=port1)
  48. bridge = mosq_test.start_broker(filename=os.path.basename(__file__)+'_bridge', cmd=bridge_cmd, port=port3)
  49. pub = None
  50. try:
  51. sock = mosq_test.do_client_connect(connect_packet, connack_packet, timeout=30, port=port1)
  52. mosq_test.do_send_receive(sock, subscribe_packet, suback_packet, "suback")
  53. pub = subprocess.Popen(['./c/08-tls-psk-bridge.test', str(port3)], env=env, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
  54. if pub.wait():
  55. raise ValueError
  56. (stdo, stde) = pub.communicate()
  57. mosq_test.expect_packet(sock, "publish", publish_packet)
  58. rc = 0
  59. sock.close()
  60. except mosq_test.TestError:
  61. pass
  62. finally:
  63. os.remove(conf_file1)
  64. os.remove(conf_file2)
  65. time.sleep(1)
  66. broker.terminate()
  67. broker.wait()
  68. time.sleep(1)
  69. bridge.terminate()
  70. bridge.wait()
  71. (stdo, stde) = broker.communicate()
  72. if rc:
  73. print(stde.decode('utf-8'))
  74. (stdo, stde) = bridge.communicate()
  75. print(stde.decode('utf-8'))
  76. if pub:
  77. (stdo, stde) = pub.communicate()
  78. print(stdo.decode('utf-8'))
  79. exit(rc)