freddy 2.4.0 → 2.5.0.pre.rc.1

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: f2dcf734ec94fc66e09be25bed73991a329b9dc3bb112664cd762c45dc9e0e7c
4
- data.tar.gz: 5d929520fbf9c43857b3e8f1d97559402b0028169b657ec9a967eba36a395551
3
+ metadata.gz: 9e09e2059a52cd5e7395cdbd6a329c7d2531e479c6ef7113f11d8d2f2c198a72
4
+ data.tar.gz: 25b7ce6639e57cb65c03e3d87b3671528c948c3678d1fbf7dd39f5407929d4a7
5
5
  SHA512:
6
- metadata.gz: 33b5603b0775342f4271034dc083b654c5031cee2bf61e6a1d068afd1abe9e12e86579c85497016cb6f17085a2dbeb7efaa49a3957aafb391189e6d596795cd7
7
- data.tar.gz: 0ea71e0dd8abdc975477f89b9e1ca1d650ff50ab0f9f9d2e4bf65b49af94e35ee545359eb8779a6e4723fbab3dede9676baa646fb3c6b95b06649fb9653fc482
6
+ metadata.gz: b775211cbc18668d00ddf5214bd0d7f75a679db6c80c59e837a3f3403a5a430965bae52418245563e12e6e612b653e68dd81982cde8d443357e50f89d3bf7dd1
7
+ data.tar.gz: 4fdca691514bd170ce0456aff8f69544b98e70dd2083fbd6a909905cd7d28f216fff74ff3236654b18be3a35465239230c65cdc212355c63b1ee05d07a33a1a9
data/.rubocop.yml CHANGED
@@ -28,3 +28,6 @@ Style/FrozenStringLiteralComment:
28
28
 
29
29
  Naming/FileName:
30
30
  Enabled: no
31
+
32
+ Gemspec/RequireMFA:
33
+ Enabled: no
data/Gemfile CHANGED
@@ -4,7 +4,7 @@ gem 'hamster', '~> 3.0'
4
4
  gem 'opentelemetry-sdk', '~> 1.0.0.rc3'
5
5
  gem 'pry'
6
6
  gem 'rspec'
7
- gem 'rubocop', '~> 1.19'
7
+ gem 'rubocop', '~> 1.30'
8
8
  gem 'rubocop-rspec', '~> 2.4'
9
9
 
10
10
  gemspec
data/Gemfile.lock CHANGED
@@ -1,12 +1,12 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- freddy (2.4.0)
4
+ freddy (2.5.0.pre.rc.1)
5
5
  bunny (~> 2.11)
6
+ concurrent-ruby (~> 1.0)
6
7
  oj (~> 3.6)
7
8
  opentelemetry-api (~> 1.0.0.rc3)
8
9
  opentelemetry-semantic_conventions (~> 1.0)
9
- thread (~> 0.1)
10
10
  zlib (~> 1.1)
11
11
 
12
12
  GEM
@@ -23,7 +23,7 @@ GEM
23
23
  hamster (3.0.0)
24
24
  concurrent-ruby (~> 1.0)
25
25
  method_source (1.0.0)
26
- oj (3.13.11)
26
+ oj (3.13.14)
27
27
  opentelemetry-api (1.0.0.rc3)
28
28
  opentelemetry-common (0.19.1)
29
29
  opentelemetry-api (~> 1.0.0.rc3)
@@ -36,16 +36,16 @@ GEM
36
36
  opentelemetry-semantic_conventions
37
37
  opentelemetry-semantic_conventions (1.6.0)
38
38
  opentelemetry-api (~> 1.0.0.rc3)
39
- parallel (1.20.1)
40
- parser (3.0.2.0)
39
+ parallel (1.22.1)
40
+ parser (3.1.2.0)
41
41
  ast (~> 2.4.1)
42
42
  pry (0.14.1)
43
43
  coderay (~> 1.1)
44
44
  method_source (~> 1.0)
45
- rainbow (3.0.0)
45
+ rainbow (3.1.1)
46
46
  rake (13.0.6)
47
47
  rbtree (0.4.5)
48
- regexp_parser (2.1.1)
48
+ regexp_parser (2.5.0)
49
49
  rexml (3.2.5)
50
50
  rspec (3.10.0)
51
51
  rspec-core (~> 3.10.0)
@@ -60,17 +60,17 @@ GEM
60
60
  diff-lcs (>= 1.2.0, < 2.0)
61
61
  rspec-support (~> 3.10.0)
62
62
  rspec-support (3.10.2)
63
- rubocop (1.19.0)
63
+ rubocop (1.30.1)
64
64
  parallel (~> 1.10)
65
- parser (>= 3.0.0.0)
65
+ parser (>= 3.1.0.0)
66
66
  rainbow (>= 2.2.2, < 4.0)
67
67
  regexp_parser (>= 1.8, < 3.0)
68
- rexml
69
- rubocop-ast (>= 1.9.1, < 2.0)
68
+ rexml (>= 3.2.5, < 4.0)
69
+ rubocop-ast (>= 1.18.0, < 2.0)
70
70
  ruby-progressbar (~> 1.7)
71
71
  unicode-display_width (>= 1.4.0, < 3.0)
72
- rubocop-ast (1.10.0)
73
- parser (>= 3.0.1.1)
72
+ rubocop-ast (1.18.0)
73
+ parser (>= 3.1.1.0)
74
74
  rubocop-rspec (2.4.0)
75
75
  rubocop (~> 1.0)
76
76
  rubocop-ast (>= 1.1.0)
@@ -79,8 +79,7 @@ GEM
79
79
  sorted_set (1.0.3)
80
80
  rbtree
81
81
  set (~> 1.0)
82
- thread (0.2.2)
83
- unicode-display_width (2.0.0)
82
+ unicode-display_width (2.1.0)
84
83
  zlib (1.1.0)
85
84
 
86
85
  PLATFORMS
@@ -95,7 +94,7 @@ DEPENDENCIES
95
94
  pry
96
95
  rake
97
96
  rspec
98
- rubocop (~> 1.19)
97
+ rubocop (~> 1.30)
99
98
  rubocop-rspec (~> 2.4)
100
99
 
101
100
  BUNDLED WITH
data/freddy.gemspec CHANGED
@@ -15,16 +15,15 @@ Gem::Specification.new do |spec|
15
15
 
16
16
  spec.files = `git ls-files`.split($INPUT_RECORD_SEPARATOR)
17
17
  spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
18
- spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
19
18
  spec.require_paths = ['lib']
20
19
 
21
20
  spec.add_development_dependency 'bundler'
22
21
  spec.add_development_dependency 'rake'
23
22
 
24
23
  spec.add_dependency 'bunny', '~> 2.11'
24
+ spec.add_dependency 'concurrent-ruby', '~> 1.0'
25
25
  spec.add_dependency 'oj', '~> 3.6'
26
26
  spec.add_dependency 'opentelemetry-api', '~> 1.0.0.rc3'
27
27
  spec.add_dependency 'opentelemetry-semantic_conventions', '~> 1.0'
28
- spec.add_dependency 'thread', '~> 0.1'
29
28
  spec.add_dependency 'zlib', '~> 1.1'
30
29
  end
@@ -34,7 +34,7 @@ class Freddy
34
34
  end
35
35
 
36
36
  def process_message(delivery)
37
- @consume_thread_pool.process do
37
+ @consume_thread_pool.post do
38
38
  delivery.in_span do
39
39
  yield(delivery)
40
40
  end
@@ -46,7 +46,7 @@ class Freddy
46
46
  end
47
47
 
48
48
  def process_message(_queue, delivery)
49
- @consume_thread_pool.process do
49
+ @consume_thread_pool.post do
50
50
  delivery.in_span do
51
51
  yield delivery.payload, delivery.routing_key
52
52
  @channel.acknowledge(delivery.tag)
@@ -20,7 +20,8 @@ class Freddy
20
20
  # responder.shutdown
21
21
  def shutdown
22
22
  @consumer.cancel
23
- @consume_thread_pool.wait(:done)
23
+ @consume_thread_pool.shutdown
24
+ @consume_thread_pool.wait_for_termination
24
25
  end
25
26
  end
26
27
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  class Freddy
4
- VERSION = '2.4.0'
4
+ VERSION = '2.5.0-rc.1'
5
5
  end
data/lib/freddy.rb CHANGED
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'json'
4
- require 'thread/pool'
4
+ require 'concurrent'
5
5
  require 'securerandom'
6
6
  require 'opentelemetry'
7
7
  require 'opentelemetry/semantic_conventions'
@@ -85,7 +85,7 @@ class Freddy
85
85
  handler_adapter_factory = MessageHandlerAdapters::Factory.new(producer)
86
86
 
87
87
  Consumers::RespondToConsumer.consume(
88
- thread_pool: Thread.pool(@prefetch_buffer_size),
88
+ thread_pool: Concurrent::FixedThreadPool.new(@prefetch_buffer_size),
89
89
  destination: destination,
90
90
  channel: channel,
91
91
  handler_adapter_factory: handler_adapter_factory,
@@ -128,7 +128,7 @@ class Freddy
128
128
  @logger.debug "Tapping into messages that match #{pattern_or_patterns}"
129
129
 
130
130
  Consumers::TapIntoConsumer.consume(
131
- thread_pool: Thread.pool(@prefetch_buffer_size),
131
+ thread_pool: Concurrent::FixedThreadPool.new(@prefetch_buffer_size),
132
132
  patterns: Array(pattern_or_patterns),
133
133
  channel: @connection.create_channel(prefetch: @prefetch_buffer_size),
134
134
  options: options,
@@ -16,7 +16,7 @@ describe Freddy::Consumers::RespondToConsumer do
16
16
  let(:msg_handler_adapter_factory) { double(for: msg_handler_adapter) }
17
17
  let(:msg_handler_adapter) { Freddy::MessageHandlerAdapters::NoOpHandler.new }
18
18
  let(:prefetch_buffer_size) { 2 }
19
- let(:thread_pool) { Thread.pool(prefetch_buffer_size) }
19
+ let(:thread_pool) { Concurrent::FixedThreadPool.new(prefetch_buffer_size) }
20
20
 
21
21
  after do
22
22
  connection.close
@@ -31,12 +31,13 @@ describe Freddy::SyncResponseContainer do
31
31
  describe '#wait_for_response' do
32
32
  let(:timeout) { 2 }
33
33
  let(:response) { { msg: 'response' } }
34
- let(:delivery) { OpenStruct.new(type: 'success') }
35
34
 
36
35
  context 'when called after #call' do
37
36
  let(:max_wait_time_in_seconds) { 0.5 }
38
37
 
39
38
  before do
39
+ delivery = instance_double(Freddy::Delivery)
40
+ allow(delivery).to receive(:type).and_return('success')
40
41
  container.call(response, delivery)
41
42
  end
42
43
 
@@ -57,8 +57,8 @@ describe 'Tracing' do
57
57
  freddy.deliver_with_response(destination, {})
58
58
  names = exporter.finished_spans.map(&:name)
59
59
 
60
- expect(names.any? { |name| name.include?('amq.gen-') }).to eq(false)
61
- expect(names.any? { |name| name.include?('(response queue)') }).to eq(true)
60
+ expect(names.any? { |name| name.include?('amq.gen-') }).to be(false)
61
+ expect(names.any? { |name| name.include?('(response queue)') }).to be(true)
62
62
  end
63
63
  end
64
64
 
data/spec/spec_helper.rb CHANGED
@@ -18,8 +18,6 @@ OpenTelemetry::SDK.configure do |c|
18
18
  c.add_span_processor(span_processor)
19
19
  end
20
20
 
21
- Thread.abort_on_exception = true
22
-
23
21
  RSpec.configure do |config|
24
22
  config.run_all_when_everything_filtered = true
25
23
  config.filter_run :focus
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: freddy
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.4.0
4
+ version: 2.5.0.pre.rc.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Glia TechMovers
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-04-21 00:00:00.000000000 Z
11
+ date: 2022-06-13 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -53,61 +53,61 @@ dependencies:
53
53
  - !ruby/object:Gem::Version
54
54
  version: '2.11'
55
55
  - !ruby/object:Gem::Dependency
56
- name: oj
56
+ name: concurrent-ruby
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
59
  - - "~>"
60
60
  - !ruby/object:Gem::Version
61
- version: '3.6'
61
+ version: '1.0'
62
62
  type: :runtime
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: '3.6'
68
+ version: '1.0'
69
69
  - !ruby/object:Gem::Dependency
70
- name: opentelemetry-api
70
+ name: oj
71
71
  requirement: !ruby/object:Gem::Requirement
72
72
  requirements:
73
73
  - - "~>"
74
74
  - !ruby/object:Gem::Version
75
- version: 1.0.0.rc3
75
+ version: '3.6'
76
76
  type: :runtime
77
77
  prerelease: false
78
78
  version_requirements: !ruby/object:Gem::Requirement
79
79
  requirements:
80
80
  - - "~>"
81
81
  - !ruby/object:Gem::Version
82
- version: 1.0.0.rc3
82
+ version: '3.6'
83
83
  - !ruby/object:Gem::Dependency
84
- name: opentelemetry-semantic_conventions
84
+ name: opentelemetry-api
85
85
  requirement: !ruby/object:Gem::Requirement
86
86
  requirements:
87
87
  - - "~>"
88
88
  - !ruby/object:Gem::Version
89
- version: '1.0'
89
+ version: 1.0.0.rc3
90
90
  type: :runtime
91
91
  prerelease: false
92
92
  version_requirements: !ruby/object:Gem::Requirement
93
93
  requirements:
94
94
  - - "~>"
95
95
  - !ruby/object:Gem::Version
96
- version: '1.0'
96
+ version: 1.0.0.rc3
97
97
  - !ruby/object:Gem::Dependency
98
- name: thread
98
+ name: opentelemetry-semantic_conventions
99
99
  requirement: !ruby/object:Gem::Requirement
100
100
  requirements:
101
101
  - - "~>"
102
102
  - !ruby/object:Gem::Version
103
- version: '0.1'
103
+ version: '1.0'
104
104
  type: :runtime
105
105
  prerelease: false
106
106
  version_requirements: !ruby/object:Gem::Requirement
107
107
  requirements:
108
108
  - - "~>"
109
109
  - !ruby/object:Gem::Version
110
- version: '0.1'
110
+ version: '1.0'
111
111
  - !ruby/object:Gem::Dependency
112
112
  name: zlib
113
113
  requirement: !ruby/object:Gem::Requirement
@@ -194,25 +194,12 @@ required_ruby_version: !ruby/object:Gem::Requirement
194
194
  version: '2.7'
195
195
  required_rubygems_version: !ruby/object:Gem::Requirement
196
196
  requirements:
197
- - - ">="
197
+ - - ">"
198
198
  - !ruby/object:Gem::Version
199
- version: '0'
199
+ version: 1.3.1
200
200
  requirements: []
201
- rubygems_version: 3.1.6
201
+ rubygems_version: 3.0.9
202
202
  signing_key:
203
203
  specification_version: 4
204
204
  summary: API for inter-application messaging supporting acknowledgements and request-response
205
- test_files:
206
- - spec/.rubocop.yml
207
- - spec/freddy/consumers/respond_to_consumer_spec.rb
208
- - spec/freddy/error_response_spec.rb
209
- - spec/freddy/freddy_spec.rb
210
- - spec/freddy/message_handler_spec.rb
211
- - spec/freddy/payload_spec.rb
212
- - spec/freddy/responder_handler_spec.rb
213
- - spec/freddy/sync_response_container_spec.rb
214
- - spec/integration/concurrency_spec.rb
215
- - spec/integration/reply_spec.rb
216
- - spec/integration/tap_into_with_group_spec.rb
217
- - spec/integration/tracing_spec.rb
218
- - spec/spec_helper.rb
205
+ test_files: []