amqp-subscribe-many 0.1.5 → 0.1.6

Sign up to get free protection for your applications and to get access to all the features.
data/Rakefile CHANGED
@@ -49,7 +49,7 @@ Jeweler::RubygemsDotOrgTasks.new
49
49
 
50
50
  Jeweler::Tasks.new do |gem|
51
51
  gem.name = "amqp-subscribe-many"
52
- gem.version = "0.1.5"
52
+ gem.version = "0.1.6"
53
53
  gem.homepage = "http://github.com/brendanhay/amqp-subscribe-many"
54
54
  gem.license = "MPL"
55
55
  gem.summary = "An implementation of the publish one, subscribe many pattern"
@@ -5,11 +5,11 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{amqp-subscribe-many}
8
- s.version = "0.1.5"
8
+ s.version = "0.1.6"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = [%q{brendanhay}]
12
- s.date = %q{2012-09-07}
12
+ s.date = %q{2012-09-19}
13
13
  s.description = %q{Codifies best practices and configuration when consuming from multiple AMQP brokers simultaneously}
14
14
  s.email = %q{brendan@soundcloud.com}
15
15
  s.extra_rdoc_files = [
@@ -58,6 +58,8 @@ module Messaging
58
58
 
59
59
  # Invoked when a message is received from any of the subscriptions.
60
60
  #
61
+ # @param meta [AMQP::Header] A wrapper around the AMQP headers, and ruby-amqp metadata
62
+ # @param payload [String] The message payload
61
63
  # @raise [NotImplementedError]
62
64
  # @api protected
63
65
  def on_message(meta, payload)
@@ -115,14 +117,27 @@ module Messaging
115
117
  ex = declare_exchange(channel, exchange, type, config.exchange_options)
116
118
  q = declare_queue(channel, ex, queue, key, config.queue_options)
117
119
 
118
- q.subscribe(:ack => true) do |meta, payload|
120
+ # Expliclity create an AMQP::Consumer rather than using
121
+ # AMQP::Queue.subscription, which is a global singleton
122
+ # and prevents the creation of multiple subscriptions
123
+ AMQP::Consumer.new(channel, q).consume.on_delivery do |meta, payload|
119
124
  log.debug("Receieved message on channel #{meta.channel.id} from queue #{queue.inspect}")
120
125
 
121
- # If this raises an exception, the connection
122
- # will be closed, and the message requeued by the broker.
123
- on_message(meta, payload)
124
-
125
- meta.ack
126
+ # If an exception is raised in on_message, the message will not be
127
+ # acknowledged and the exception will be logged and re-raised
128
+ begin
129
+ on_message(meta, payload)
130
+
131
+ meta.ack
132
+ rescue => ex
133
+ log.error("Exception: #{ex}, " \
134
+ "Payload: #{payload.inspect}, " \
135
+ "Headers: #{meta.headers.inspect}\n" \
136
+ "Backtrace:\n#{ex.backtrace.join('\n')}")
137
+
138
+ # Re-raise the exception
139
+ raise ex
140
+ end
126
141
  end
127
142
  end
128
143
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: amqp-subscribe-many
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.5
4
+ version: 0.1.6
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-09-07 00:00:00.000000000 Z
12
+ date: 2012-09-19 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: amqp
16
- requirement: &70256241444900 !ruby/object:Gem::Requirement
16
+ requirement: &70235814586420 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 0.9.6
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *70256241444900
24
+ version_requirements: *70235814586420
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: bundler
27
- requirement: &70256241482320 !ruby/object:Gem::Requirement
27
+ requirement: &70235814585520 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *70256241482320
35
+ version_requirements: *70235814585520
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: minitest
38
- requirement: &70256241481600 !ruby/object:Gem::Requirement
38
+ requirement: &70235814584860 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '3.0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *70256241481600
46
+ version_requirements: *70235814584860
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: simplecov
49
- requirement: &70256241480400 !ruby/object:Gem::Requirement
49
+ requirement: &70235814584100 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *70256241480400
57
+ version_requirements: *70235814584100
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: mocha
60
- requirement: &70256241477160 !ruby/object:Gem::Requirement
60
+ requirement: &70235814583200 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *70256241477160
68
+ version_requirements: *70235814583200
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: jeweler
71
- requirement: &70256241476540 !ruby/object:Gem::Requirement
71
+ requirement: &70235814582520 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *70256241476540
79
+ version_requirements: *70235814582520
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: redcarpet
82
- requirement: &70256241475320 !ruby/object:Gem::Requirement
82
+ requirement: &70235814581820 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: '0'
88
88
  type: :development
89
89
  prerelease: false
90
- version_requirements: *70256241475320
90
+ version_requirements: *70235814581820
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: yard
93
- requirement: &70256241490260 !ruby/object:Gem::Requirement
93
+ requirement: &70235814581200 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ! '>='
@@ -98,7 +98,7 @@ dependencies:
98
98
  version: '0'
99
99
  type: :development
100
100
  prerelease: false
101
- version_requirements: *70256241490260
101
+ version_requirements: *70235814581200
102
102
  description: Codifies best practices and configuration when consuming from multiple
103
103
  AMQP brokers simultaneously
104
104
  email: brendan@soundcloud.com
@@ -145,7 +145,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
145
145
  version: '0'
146
146
  segments:
147
147
  - 0
148
- hash: 2625083279973371652
148
+ hash: 1747811653672625853
149
149
  required_rubygems_version: !ruby/object:Gem::Requirement
150
150
  none: false
151
151
  requirements: