4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
# File 'lib/turd/tcp.rb', line 4
def self.connect(request_definition)
response = String.new
read_after = nil
read_before = nil
begin
total_before = Time.now.to_f
TCPSocket.open(request_definition[:options][:host], request_definition[:options][:port]) do |socket|
read_before = Time.now.to_f
response = socket.gets
read_after = Time.now.to_f
end
total_after = Time.now.to_f
rescue Errno::ETIMEDOUT
ensure
total_after = Time.now.to_f
end
if read_after && read_before
read_time = read_after - read_before
else
read_time = nil
end
{
:response => response,
:total_time => total_after - total_before,
:read_time => read_time
}
end
|