throughput_protocols.py 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #!/usr/bin/python3
  2. #
  3. import basic_protocols
  4. import logging
  5. import enum
  6. import time
  7. import socket
  8. #
  9. class ClientProtocol(basic_protocols.Protocol):
  10. def __init__(self, socket, total_bytes, wait_until=None, send_buffer_len=None, use_acceleration=None):
  11. self.socket = socket
  12. self.total_bytes = total_bytes
  13. self.wait_until = wait_until
  14. self.send_buffer_len = send_buffer_len
  15. self.use_acceleration = use_acceleration
  16. #
  17. self.states = enum.Enum('CLIENT_CONN_STATES', 'READY_TO_BEGIN SEND_GROUP_ID PUSH_DATA DONE')
  18. self.state = self.states.READY_TO_BEGIN
  19. #
  20. self.sub_protocol = None
  21. self.group_id = int(self.wait_until*1000) if self.wait_until is not None else 0
  22. # a group id of 0 means no group
  23. #
  24. def _run_iteration(self, block=True):
  25. if self.state is self.states.READY_TO_BEGIN:
  26. group_id_bytes = self.group_id.to_bytes(8, byteorder='big', signed=False)
  27. self.sub_protocol = basic_protocols.SendDataProtocol(self.socket, group_id_bytes)
  28. self.state = self.states.SEND_GROUP_ID
  29. #
  30. if self.state is self.states.SEND_GROUP_ID:
  31. if block and self.wait_until is not None:
  32. time.sleep(self.wait_until-time.time())
  33. #
  34. if (self.wait_until is None or time.time() >= self.wait_until) and self.sub_protocol.run(block=block):
  35. self.sub_protocol = basic_protocols.PushDataProtocol(self.socket, self.total_bytes,
  36. send_buffer_len=self.send_buffer_len,
  37. use_acceleration=self.use_acceleration)
  38. self.state = self.states.PUSH_DATA
  39. #
  40. #
  41. if self.state is self.states.PUSH_DATA:
  42. if self.sub_protocol.run(block=block):
  43. self.state = self.states.DONE
  44. return True
  45. #
  46. #
  47. return False
  48. #
  49. #
  50. class ServerProtocol(basic_protocols.Protocol):
  51. def __init__(self, socket, conn_id, group_id_callback=None, bandwidth_callback=None, use_acceleration=None):
  52. self.socket = socket
  53. self.conn_id = conn_id
  54. self.group_id_callback = group_id_callback
  55. self.bandwidth_callback = bandwidth_callback
  56. self.use_acceleration = use_acceleration
  57. #
  58. self.states = enum.Enum('SERVER_CONN_STATES', 'READY_TO_BEGIN RECV_GROUP_ID PULL_DATA DONE')
  59. self.state = self.states.READY_TO_BEGIN
  60. #
  61. self.sub_protocol = None
  62. #
  63. def _run_iteration(self, block=True):
  64. if self.state is self.states.READY_TO_BEGIN:
  65. self.sub_protocol = basic_protocols.ReceiveDataProtocol(self.socket)
  66. self.state = self.states.RECV_GROUP_ID
  67. #
  68. if self.state is self.states.RECV_GROUP_ID:
  69. if self.sub_protocol.run(block=block):
  70. group_id = int.from_bytes(self.sub_protocol.received_data, byteorder='big', signed=False)
  71. if group_id == 0:
  72. # a group of 0 means no group
  73. group_id = None
  74. #
  75. self.group_id_callback(self.conn_id, group_id)
  76. self.sub_protocol = basic_protocols.PullDataProtocol(self.socket, use_acceleration=self.use_acceleration)
  77. self.state = self.states.PULL_DATA
  78. #
  79. #
  80. if self.state is self.states.PULL_DATA:
  81. if self.sub_protocol.run(block=block):
  82. self.state = self.states.DONE
  83. if self.bandwidth_callback:
  84. self.bandwidth_callback(self.conn_id, self.sub_protocol.data_size, self.sub_protocol.calc_transfer_rate())
  85. #
  86. return True
  87. #
  88. #
  89. return False
  90. #
  91. #