throughput_protocols.py 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. #
  45. #
  46. if self.state is self.states.DONE:
  47. return True
  48. #
  49. return False
  50. #
  51. #
  52. class ServerProtocol(basic_protocols.Protocol):
  53. def __init__(self, socket, conn_id, group_id_callback=None, bandwidth_callback=None, use_acceleration=None):
  54. self.socket = socket
  55. self.conn_id = conn_id
  56. self.group_id_callback = group_id_callback
  57. self.bandwidth_callback = bandwidth_callback
  58. self.use_acceleration = use_acceleration
  59. #
  60. self.states = enum.Enum('SERVER_CONN_STATES', 'READY_TO_BEGIN RECV_GROUP_ID PULL_DATA DONE')
  61. self.state = self.states.READY_TO_BEGIN
  62. #
  63. self.sub_protocol = None
  64. #
  65. def _run_iteration(self, block=True):
  66. if self.state is self.states.READY_TO_BEGIN:
  67. self.sub_protocol = basic_protocols.ReceiveDataProtocol(self.socket)
  68. self.state = self.states.RECV_GROUP_ID
  69. #
  70. if self.state is self.states.RECV_GROUP_ID:
  71. if self.sub_protocol.run(block=block):
  72. group_id = int.from_bytes(self.sub_protocol.received_data, byteorder='big', signed=False)
  73. if group_id == 0:
  74. # a group of 0 means no group
  75. group_id = None
  76. #
  77. self.group_id_callback(self.conn_id, group_id)
  78. self.sub_protocol = basic_protocols.PullDataProtocol(self.socket, use_acceleration=self.use_acceleration)
  79. self.state = self.states.PULL_DATA
  80. #
  81. #
  82. if self.state is self.states.PULL_DATA:
  83. if self.sub_protocol.run(block=block):
  84. if self.bandwidth_callback:
  85. self.bandwidth_callback(self.conn_id, self.sub_protocol.data_size, self.sub_protocol.calc_transfer_rate())
  86. #
  87. self.state = self.states.DONE
  88. #
  89. #
  90. if self.state is self.states.DONE:
  91. return True
  92. #
  93. return False
  94. #
  95. #