nonnative 1.15.0 → 1.20.0

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
  SHA256:
3
- metadata.gz: 9da36cc51d6dd5d1a440767c808455d81dacbf9aa425c185b6d3c3cba24ba949
4
- data.tar.gz: b5f13df29130761c28cf96f277392ab7b7a9f0a479ed7539d54b3ffc207687bf
3
+ metadata.gz: b63357ad2bb8db426b0c2958835121c3fad6611240fbf74b3695d262850cc043
4
+ data.tar.gz: 2e69404a282502b0b244dccd62c471d32d80b12e624a26ef158a5400eca057ba
5
5
  SHA512:
6
- metadata.gz: 7a7efe67bb02696eec25e19ff231199219a4e709fb74b746d3d7326358131331f7cb6300e9ec466eec1a7d644d31968d9015ca2a94187d8870fa5c8e6fdf20a1
7
- data.tar.gz: 2ef73fa52844639694efa346214f95f6705ffbfeea2b8ab6a1476948cd485a7aaf7269150be72b43dd7d660021c77beb8c61a875a10782061557963824c30e03
6
+ metadata.gz: 289a4846e961fa08c9b851c81db5b66ee0689970dd4a6469ce1d344d19cfeb2bea26317510a203e50d7b5601d734489deabd95fdcb5966f2d8d687e8dd1de174
7
+ data.tar.gz: 6cf36198555ed5c189a37fac91a4d6f61b2a4361a3a0380b4c4c24040b22dc7d18b060ab708cb343e9af9ec95a346c7e84193307f250aa29f42dcb601ddde575
@@ -6,10 +6,10 @@ Layout/LineLength:
6
6
  Max: 120
7
7
 
8
8
  Metrics/MethodLength:
9
- Max: 15
9
+ Max: 20
10
10
 
11
11
  Metrics/BlockLength:
12
- Max: 35
12
+ Max: 60
13
13
 
14
14
  Metrics/AbcSize:
15
15
  Max: 20
@@ -58,3 +58,12 @@ Style/RedundantRegexpEscape:
58
58
 
59
59
  Style/RedundantFetchBlock:
60
60
  Enabled: true
61
+
62
+ Style/AccessorGrouping:
63
+ Enabled: true
64
+
65
+ Style/BisectedAttrAccessor:
66
+ Enabled: true
67
+
68
+ Style/RedundantAssignment:
69
+ Enabled: true
@@ -1,9 +1,11 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- nonnative (1.15.0)
4
+ nonnative (1.20.0)
5
+ concurrent-ruby (~> 1.0, >= 1.0.5)
5
6
  cucumber (~> 3.1, >= 3.1.2)
6
- grpc (~> 1.28)
7
+ grpc (~> 1.30, >= 1.30.1)
8
+ puma (~> 4.3, >= 4.3.3)
7
9
  rest-client (~> 2.1)
8
10
  rspec-benchmark (~> 0.6.0)
9
11
  rspec-expectations (~> 3.9, >= 3.9.2)
@@ -46,7 +48,7 @@ GEM
46
48
  cucumber-expressions (6.0.1)
47
49
  cucumber-tag_expressions (1.1.1)
48
50
  cucumber-wire (0.0.1)
49
- diff-lcs (1.4.2)
51
+ diff-lcs (1.4.4)
50
52
  docile (1.3.2)
51
53
  domain_name (0.5.20190701)
52
54
  unf (>= 0.0.5, < 1.0.0)
@@ -56,10 +58,10 @@ GEM
56
58
  google-protobuf (3.12.2)
57
59
  googleapis-common-protos-types (1.0.5)
58
60
  google-protobuf (~> 3.11)
59
- grpc (1.28.0)
60
- google-protobuf (~> 3.11)
61
+ grpc (1.30.1)
62
+ google-protobuf (~> 3.12)
61
63
  googleapis-common-protos-types (~> 1.0)
62
- grpc-tools (1.28.0)
64
+ grpc-tools (1.30.1)
63
65
  http-accept (1.7.0)
64
66
  http-cookie (1.0.3)
65
67
  domain_name (~> 0.5)
@@ -79,7 +81,8 @@ GEM
79
81
  mustermann (1.1.1)
80
82
  ruby2_keywords (~> 0.0.1)
81
83
  netrc (0.11.0)
82
- nokogiri (1.10.9)
84
+ nio4r (2.5.2)
85
+ nokogiri (1.10.10)
83
86
  mini_portile2 (~> 2.4.0)
84
87
  parallel (1.19.2)
85
88
  parser (2.7.1.4)
@@ -89,6 +92,8 @@ GEM
89
92
  tty-color (~> 0.5)
90
93
  protocol (2.0.0)
91
94
  ruby_parser (~> 3.0)
95
+ puma (4.3.5)
96
+ nio4r (~> 2.0)
92
97
  rack (2.2.3)
93
98
  rack-protection (2.0.8.1)
94
99
  rack
@@ -121,13 +126,13 @@ GEM
121
126
  diff-lcs (>= 1.2.0, < 2.0)
122
127
  rspec-support (~> 3.9.0)
123
128
  rspec-support (3.9.3)
124
- rubocop (0.86.0)
129
+ rubocop (0.87.1)
125
130
  parallel (~> 1.10)
126
- parser (>= 2.7.0.1)
131
+ parser (>= 2.7.1.1)
127
132
  rainbow (>= 2.2.2, < 4.0)
128
133
  regexp_parser (>= 1.7)
129
134
  rexml
130
- rubocop-ast (>= 0.0.3, < 1.0)
135
+ rubocop-ast (>= 0.1.0, < 1.0)
131
136
  ruby-progressbar (~> 1.7)
132
137
  unicode-display_width (>= 1.4.0, < 2.0)
133
138
  rubocop-ast (0.1.0)
@@ -183,12 +188,12 @@ PLATFORMS
183
188
  DEPENDENCIES
184
189
  bundler (~> 2.1, >= 2.1.4)
185
190
  chutney (~> 2.0, >= 2.0.3.1)
186
- grpc-tools (~> 1.28)
191
+ grpc-tools (~> 1.30, >= 1.30.1)
187
192
  nonnative!
188
193
  rake (~> 13.0, >= 13.0.1)
189
- rubocop (~> 0.86.0)
194
+ rubocop (~> 0.87.1)
190
195
  simplecov (~> 0.17.1)
191
- solargraph (~> 0.39.7)
196
+ solargraph (~> 0.39.11)
192
197
 
193
198
  BUNDLED WITH
194
199
  2.1.4
data/Makefile CHANGED
@@ -7,7 +7,7 @@ outdated-dependencies:
7
7
  bundle outdated --only-explicit
8
8
 
9
9
  features: clean
10
- bundle exec cucumber --profile report $(feature)
10
+ bundle exec cucumber --profile report --fail-fast $(feature)
11
11
 
12
12
  analysis:
13
13
  bundle exec rubocop
data/README.md CHANGED
@@ -249,8 +249,8 @@ module Nonnative
249
249
  end
250
250
 
251
251
  class GRPCServer < Nonnative::GRPCServer
252
- def configure(grpc)
253
- grpc.handle(GreeterService.new)
252
+ def svc
253
+ GreeterService.new
254
254
  end
255
255
  end
256
256
  end
@@ -309,8 +309,10 @@ Nonnative.configure do |config|
309
309
  config.strategy = :manual
310
310
 
311
311
  config.server do |d|
312
- d.proxy.type = 'chaos'
313
- d.proxy.port = 20_000
312
+ d.proxy = {
313
+ type: 'chaos',
314
+ port: 20_000
315
+ }
314
316
  end
315
317
  end
316
318
  ```
@@ -4,11 +4,13 @@ require 'socket'
4
4
  require 'timeout'
5
5
  require 'thwait'
6
6
  require 'yaml'
7
- require 'webrick'
8
7
 
9
8
  require 'grpc'
10
9
  require 'sinatra'
11
10
  require 'rest-client'
11
+ require 'puma'
12
+ require 'puma/server'
13
+ require 'concurrent'
12
14
 
13
15
  require 'nonnative/version'
14
16
  require 'nonnative/error'
@@ -34,10 +36,10 @@ require 'nonnative/proxy'
34
36
  require 'nonnative/no_proxy'
35
37
  require 'nonnative/chaos_proxy'
36
38
 
37
- Thread.abort_on_exception = true
38
-
39
39
  module Nonnative
40
40
  class << self
41
+ attr_reader :pool
42
+
41
43
  def load_configuration(path)
42
44
  @configuration ||= Nonnative::Configuration.load_file(path) # rubocop:disable Naming/MemoizedInstanceVariableName
43
45
  end
@@ -2,6 +2,14 @@
2
2
 
3
3
  module Nonnative
4
4
  class ChaosProxy < Nonnative::Proxy
5
+ def initialize(service)
6
+ @connections = Concurrent::Hash.new
7
+ @mutex = Mutex.new
8
+ @state = :none
9
+
10
+ super service
11
+ end
12
+
5
13
  def start
6
14
  @tcp_server = ::TCPServer.new('0.0.0.0', service.port)
7
15
  @thread = Thread.new { perform_start }
@@ -12,21 +20,32 @@ module Nonnative
12
20
  tcp_server.close
13
21
  end
14
22
 
23
+ def close_all
24
+ apply_state :close_all
25
+ end
26
+
27
+ def reset
28
+ apply_state :none
29
+ end
30
+
15
31
  def port
16
32
  service.proxy.port
17
33
  end
18
34
 
19
35
  private
20
36
 
21
- attr_reader :tcp_server, :thread
37
+ attr_reader :tcp_server, :thread, :connections, :mutex, :state
22
38
 
23
39
  def perform_start
24
40
  loop do
25
- Thread.start(tcp_server.accept) { |local_socket| connect(local_socket) }
41
+ thread = Thread.start(tcp_server.accept) { |local_socket| connect(local_socket) }
42
+ connections[thread.object_id] = thread
26
43
  end
27
44
  end
28
45
 
29
46
  def connect(local_socket)
47
+ return local_socket.close if state?(:close_all)
48
+
30
49
  remote_socket = create_remote_socket
31
50
  return unless remote_socket
32
51
 
@@ -36,9 +55,12 @@ module Nonnative
36
55
  break if write(ready, local_socket, remote_socket)
37
56
  break if write(ready, remote_socket, local_socket)
38
57
  end
58
+ rescue Errno::ECONNRESET
59
+ # Just ignore it.
39
60
  ensure
40
61
  local_socket.close
41
62
  remote_socket&.close
63
+ connections.delete(Thread.current.object_id)
42
64
  end
43
65
 
44
66
  def create_remote_socket
@@ -60,5 +82,13 @@ module Nonnative
60
82
 
61
83
  false
62
84
  end
85
+
86
+ def apply_state(state)
87
+ mutex.synchronize { @state = state }
88
+ end
89
+
90
+ def state?(state)
91
+ mutex.synchronize { @state == state }
92
+ end
63
93
  end
64
94
  end
@@ -42,8 +42,10 @@ module Nonnative
42
42
  proxy = fd['proxy']
43
43
 
44
44
  if proxy
45
- s.proxy.type = proxy['type']
46
- s.proxy.port = proxy['port']
45
+ s.proxy = {
46
+ type: proxy['type'],
47
+ port: proxy['port']
48
+ }
47
49
  end
48
50
  end
49
51
  end
@@ -56,9 +58,7 @@ module Nonnative
56
58
  self.servers = []
57
59
  end
58
60
 
59
- attr_accessor :strategy
60
- attr_accessor :processes
61
- attr_accessor :servers
61
+ attr_accessor :strategy, :processes, :servers
62
62
 
63
63
  def process
64
64
  process = Nonnative::ConfigurationProcess.new
@@ -2,11 +2,6 @@
2
2
 
3
3
  module Nonnative
4
4
  class ConfigurationProcess
5
- attr_accessor :name
6
- attr_accessor :command
7
- attr_accessor :timeout
8
- attr_accessor :port
9
- attr_accessor :file
10
- attr_accessor :signal
5
+ attr_accessor :name, :command, :timeout, :port, :file, :signal
11
6
  end
12
7
  end
@@ -2,8 +2,7 @@
2
2
 
3
3
  module Nonnative
4
4
  class ConfigurationProxy
5
- attr_accessor :type
6
- attr_accessor :port
5
+ attr_accessor :type, :port
7
6
 
8
7
  def initialize
9
8
  self.type = 'none'
@@ -2,14 +2,17 @@
2
2
 
3
3
  module Nonnative
4
4
  class ConfigurationServer
5
- attr_accessor :name
6
- attr_accessor :klass
7
- attr_accessor :timeout
8
- attr_accessor :port
9
- attr_accessor :proxy
5
+ attr_accessor :name, :klass, :timeout, :port
6
+
7
+ attr_reader :proxy
10
8
 
11
9
  def initialize
12
- self.proxy = Nonnative::ConfigurationProxy.new
10
+ @proxy = Nonnative::ConfigurationProxy.new
11
+ end
12
+
13
+ def proxy=(value)
14
+ proxy.type = value[:type]
15
+ proxy.port = value[:port]
13
16
  end
14
17
  end
15
18
  end
@@ -4,20 +4,15 @@ module Nonnative
4
4
  class GRPCServer < Nonnative::Server
5
5
  def initialize(service)
6
6
  @server = GRPC::RpcServer.new
7
+ server.handle(svc)
7
8
 
8
9
  super service
9
10
  end
10
11
 
11
- def configure(server)
12
- # Classes will add configuration
13
- end
14
-
15
12
  protected
16
13
 
17
14
  def perform_start
18
15
  server.add_http2_port("0.0.0.0:#{proxy.port}", :this_port_is_insecure)
19
- configure server
20
-
21
16
  server.run
22
17
  end
23
18
 
@@ -26,7 +21,15 @@ module Nonnative
26
21
  end
27
22
 
28
23
  def wait_start
29
- server.wait_till_running(service.timeout)
24
+ timeout.perform do
25
+ super until server.running?
26
+ end
27
+ end
28
+
29
+ def wait_stop
30
+ timeout.perform do
31
+ super until server.stopped?
32
+ end
30
33
  end
31
34
 
32
35
  private
@@ -2,23 +2,33 @@
2
2
 
3
3
  module Nonnative
4
4
  class HTTPServer < Nonnative::Server
5
+ def initialize(service)
6
+ @server = Puma::Server.new(app, Puma::Events.strings)
7
+
8
+ super service
9
+ end
10
+
5
11
  protected
6
12
 
7
13
  def perform_start
8
- options = {
9
- Host: '0.0.0.0',
10
- Port: proxy.port,
11
- Logger: ::WEBrick::Log.new('/dev/null'),
12
- AccessLog: []
13
- }
14
-
15
- Rack::Handler::WEBrick.run(app, options) do |server|
16
- @server = server
17
- end
14
+ server.add_tcp_listener '0.0.0.0', proxy.port
15
+ server.run.join
18
16
  end
19
17
 
20
18
  def perform_stop
21
- server.shutdown
19
+ server.stop(true)
20
+ end
21
+
22
+ def wait_start
23
+ timeout.perform do
24
+ super until server.running
25
+ end
26
+ end
27
+
28
+ def wait_stop
29
+ timeout.perform do
30
+ super while server.running
31
+ end
22
32
  end
23
33
 
24
34
  private
@@ -7,13 +7,16 @@ module Nonnative
7
7
  end
8
8
 
9
9
  def start(&block)
10
- all = processes + servers
11
- process_all(all, :start, :open?, &block)
10
+ [servers, processes].each { |t| process(t, :start, :open?, &block) }
12
11
  end
13
12
 
14
13
  def stop(&block)
15
- all = processes + servers
16
- process_all(all, :stop, :closed?, &block)
14
+ [processes, servers].each { |t| process(t, :stop, :closed?, &block) }
15
+ end
16
+
17
+ def server_by_name(name)
18
+ index = configuration.servers.find_index { |s| s.name == name }
19
+ servers[index].first
17
20
  end
18
21
 
19
22
  private
@@ -32,7 +35,7 @@ module Nonnative
32
35
  end
33
36
  end
34
37
 
35
- def process_all(all, type_method, port_method, &block)
38
+ def process(all, type_method, port_method, &block)
36
39
  types = []
37
40
  pids = []
38
41
  threads = []
@@ -2,8 +2,9 @@
2
2
 
3
3
  module Nonnative
4
4
  class Server < Nonnative::Service
5
+ attr_reader :proxy
6
+
5
7
  def initialize(service)
6
- @id = SecureRandom.hex(5)
7
8
  @proxy = Nonnative::ProxyFactory.create(service)
8
9
 
9
10
  super service
@@ -17,7 +18,7 @@ module Nonnative
17
18
  wait_start
18
19
  end
19
20
 
20
- id
21
+ object_id
21
22
  end
22
23
 
23
24
  def stop
@@ -30,15 +31,11 @@ module Nonnative
30
31
  wait_stop
31
32
  end
32
33
 
33
- id
34
+ object_id
34
35
  end
35
36
 
36
- protected
37
-
38
- attr_reader :id
39
-
40
37
  private
41
38
 
42
- attr_reader :proxy, :thread
39
+ attr_reader :thread
43
40
  end
44
41
  end
@@ -16,11 +16,11 @@ module Nonnative
16
16
  attr_reader :service, :timeout
17
17
 
18
18
  def wait_start
19
- sleep 0.2
19
+ sleep 0.1
20
20
  end
21
21
 
22
22
  def wait_stop
23
- sleep 0.2
23
+ sleep 0.1
24
24
  end
25
25
  end
26
26
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Nonnative
4
- VERSION = '1.15.0'
4
+ VERSION = '1.20.0'
5
5
  end
@@ -24,8 +24,10 @@ Gem::Specification.new do |spec|
24
24
  spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
25
25
  spec.require_paths = ['lib']
26
26
 
27
+ spec.add_dependency 'concurrent-ruby', '~> 1.0', '>= 1.0.5'
27
28
  spec.add_dependency 'cucumber', '~> 3.1', '>= 3.1.2'
28
- spec.add_dependency 'grpc', '~> 1.28'
29
+ spec.add_dependency 'grpc', '~> 1.30', '>= 1.30.1'
30
+ spec.add_dependency 'puma', '~> 4.3', '>= 4.3.3'
29
31
  spec.add_dependency 'rest-client', '~> 2.1'
30
32
  spec.add_dependency 'rspec-benchmark', '~> 0.6.0'
31
33
  spec.add_dependency 'rspec-expectations', '~> 3.9', '>= 3.9.2'
@@ -33,9 +35,9 @@ Gem::Specification.new do |spec|
33
35
 
34
36
  spec.add_development_dependency 'bundler', '~> 2.1', '>= 2.1.4'
35
37
  spec.add_development_dependency 'chutney', '~> 2.0', '>= 2.0.3.1'
36
- spec.add_development_dependency 'grpc-tools', '~> 1.28'
38
+ spec.add_development_dependency 'grpc-tools', '~> 1.30', '>= 1.30.1'
37
39
  spec.add_development_dependency 'rake', '~> 13.0', '>= 13.0.1'
38
- spec.add_development_dependency 'rubocop', '~> 0.86.0'
40
+ spec.add_development_dependency 'rubocop', '~> 0.87.1'
39
41
  spec.add_development_dependency 'simplecov', '~> 0.17.1'
40
- spec.add_development_dependency 'solargraph', '~> 0.39.7'
42
+ spec.add_development_dependency 'solargraph', '~> 0.39.11'
41
43
  end
metadata CHANGED
@@ -1,15 +1,35 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: nonnative
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.15.0
4
+ version: 1.20.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Alex Falkowski
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-07-03 00:00:00.000000000 Z
11
+ date: 2020-07-09 00:00:00.000000000 Z
12
12
  dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: concurrent-ruby
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.0'
20
+ - - ">="
21
+ - !ruby/object:Gem::Version
22
+ version: 1.0.5
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - "~>"
28
+ - !ruby/object:Gem::Version
29
+ version: '1.0'
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: 1.0.5
13
33
  - !ruby/object:Gem::Dependency
14
34
  name: cucumber
15
35
  requirement: !ruby/object:Gem::Requirement
@@ -36,14 +56,40 @@ dependencies:
36
56
  requirements:
37
57
  - - "~>"
38
58
  - !ruby/object:Gem::Version
39
- version: '1.28'
59
+ version: '1.30'
60
+ - - ">="
61
+ - !ruby/object:Gem::Version
62
+ version: 1.30.1
63
+ type: :runtime
64
+ prerelease: false
65
+ version_requirements: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - "~>"
68
+ - !ruby/object:Gem::Version
69
+ version: '1.30'
70
+ - - ">="
71
+ - !ruby/object:Gem::Version
72
+ version: 1.30.1
73
+ - !ruby/object:Gem::Dependency
74
+ name: puma
75
+ requirement: !ruby/object:Gem::Requirement
76
+ requirements:
77
+ - - "~>"
78
+ - !ruby/object:Gem::Version
79
+ version: '4.3'
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: 4.3.3
40
83
  type: :runtime
41
84
  prerelease: false
42
85
  version_requirements: !ruby/object:Gem::Requirement
43
86
  requirements:
44
87
  - - "~>"
45
88
  - !ruby/object:Gem::Version
46
- version: '1.28'
89
+ version: '4.3'
90
+ - - ">="
91
+ - !ruby/object:Gem::Version
92
+ version: 4.3.3
47
93
  - !ruby/object:Gem::Dependency
48
94
  name: rest-client
49
95
  requirement: !ruby/object:Gem::Requirement
@@ -158,14 +204,20 @@ dependencies:
158
204
  requirements:
159
205
  - - "~>"
160
206
  - !ruby/object:Gem::Version
161
- version: '1.28'
207
+ version: '1.30'
208
+ - - ">="
209
+ - !ruby/object:Gem::Version
210
+ version: 1.30.1
162
211
  type: :development
163
212
  prerelease: false
164
213
  version_requirements: !ruby/object:Gem::Requirement
165
214
  requirements:
166
215
  - - "~>"
167
216
  - !ruby/object:Gem::Version
168
- version: '1.28'
217
+ version: '1.30'
218
+ - - ">="
219
+ - !ruby/object:Gem::Version
220
+ version: 1.30.1
169
221
  - !ruby/object:Gem::Dependency
170
222
  name: rake
171
223
  requirement: !ruby/object:Gem::Requirement
@@ -192,14 +244,14 @@ dependencies:
192
244
  requirements:
193
245
  - - "~>"
194
246
  - !ruby/object:Gem::Version
195
- version: 0.86.0
247
+ version: 0.87.1
196
248
  type: :development
197
249
  prerelease: false
198
250
  version_requirements: !ruby/object:Gem::Requirement
199
251
  requirements:
200
252
  - - "~>"
201
253
  - !ruby/object:Gem::Version
202
- version: 0.86.0
254
+ version: 0.87.1
203
255
  - !ruby/object:Gem::Dependency
204
256
  name: simplecov
205
257
  requirement: !ruby/object:Gem::Requirement
@@ -220,14 +272,14 @@ dependencies:
220
272
  requirements:
221
273
  - - "~>"
222
274
  - !ruby/object:Gem::Version
223
- version: 0.39.7
275
+ version: 0.39.11
224
276
  type: :development
225
277
  prerelease: false
226
278
  version_requirements: !ruby/object:Gem::Requirement
227
279
  requirements:
228
280
  - - "~>"
229
281
  - !ruby/object:Gem::Version
230
- version: 0.39.7
282
+ version: 0.39.11
231
283
  description: Allows you to keep using the power of ruby to test other systems
232
284
  email:
233
285
  - alexrfalkowski@gmail.com