pigato 0.4.5 → 0.4.6

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: fcd910a31e9734d1dbeba19bd7b87dca615ed89f
4
- data.tar.gz: 4f014edc60b82b36cb2687630413bdb8cfb0391e
3
+ metadata.gz: 465b8b4e13bd04eac19e0735fd6d218c99eaa4d9
4
+ data.tar.gz: 8f832511a07fe421e03aa2e2d5a5b77576807680
5
5
  SHA512:
6
- metadata.gz: 2a817fb5c725e82543b7e6fea605c5417e82189cf003e1a745e222e010522672f270fb5d046f4f2a34c16a5d6a1a6a8959a0dddbe97afce2a25805803891d0b1
7
- data.tar.gz: 2d63bc85e8702c03214726d61207e4bffcaf5b2e003a641396cd1cfa3880fa97e582b244d26db0fa9672e10fbf54fdf1f576f687e4f314d4c21add7fc75b83a8
6
+ metadata.gz: 8fffd135c10bd7e2c2f6b596b7832312dcdc6a36cef4a0b43f49785cae9d1e609047e0f9474ce8e44cf0491cbf715050caec481107cd0e25219372dd254e67ff
7
+ data.tar.gz: 3f9e800b944bbdbe71fc700a5d2be36e012b69fdd1d7beb84e13c4d59778241e95b0090460ffdcd5f9ebffd130ce303a229ecadffae3b8dadbd196f83646dc38
@@ -8,17 +8,18 @@ require 'thread'
8
8
  def start
9
9
  ts = []
10
10
 
11
- (0..10).each do |tid|
11
+ (0..5).each do |tid|
12
12
  ts << Thread.new {
13
13
  client = Pigato::Client.new('tcp://127.0.0.1:55555', { :autostart => true, :timeout => 20000 })
14
14
 
15
- requests = 1000
15
+ requests = 50000
16
16
  success = 0
17
17
  d1 = Time.now
18
18
  requests.times do |i|
19
19
  begin
20
- res = client.request('echo', 'Hello world1')
21
- if res
20
+ sw = "Hello world #{i}"
21
+ res = client.request('echo', sw)
22
+ if res == sw
22
23
  success += 1
23
24
  else
24
25
  puts "nil reply"
@@ -35,7 +36,7 @@ def start
35
36
  end
36
37
  end
37
38
 
38
- (0..4).each do |pid|
39
+ (0..2).each do |pid|
39
40
  pid = fork do
40
41
  start
41
42
  end
@@ -42,10 +42,12 @@ class Pigato::Client < Pigato::Base
42
42
  res = send msg
43
43
  return nil if res.nil?
44
44
 
45
+ rtimer = Time.now + (@conf[:timeout] * 0.001)
46
+
45
47
  res = []
46
- while 1 do
48
+ while Time.now <= rtimer do
47
49
  chunk = _recv rid
48
- break if chunk == nil
50
+ next if chunk == nil
49
51
  res << Oj.load(chunk[4])
50
52
  break if chunk[0] == Pigato::W_REPLY
51
53
  end
@@ -58,7 +60,7 @@ class Pigato::Client < Pigato::Base
58
60
  def _recv rid
59
61
  iid = get_iid
60
62
  socket = @@sockets[iid]
61
- socket.rcvtimeo = @conf[:timeout]
63
+ socket.rcvtimeo = 2500
62
64
 
63
65
  data = []
64
66
 
@@ -70,8 +72,8 @@ class Pigato::Client < Pigato::Base
70
72
 
71
73
  if data[3] != rid
72
74
  data = []
73
- if conf[:logger]
74
- conf[:logger].error("PigatoClient: RID mismatch")
75
+ if @conf[:logger]
76
+ @conf[:logger].error("PigatoClient: RID mismatch #{data[3]}/#{rid}")
75
77
  end
76
78
  end
77
79
 
@@ -1,3 +1,3 @@
1
1
  module Pigato
2
- VERSION = "0.4.5"
2
+ VERSION = "0.4.6"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: pigato
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.5
4
+ version: 0.4.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Paolo Ardoino
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2016-02-25 00:00:00.000000000 Z
11
+ date: 2016-02-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler