amqp 0.7.0.pre → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +4 -0
- data/.rspec +2 -0
- data/CHANGELOG +8 -2
- data/CONTRIBUTORS +22 -0
- data/Gemfile +3 -3
- data/README.md +20 -11
- data/Rakefile +30 -6
- data/amqp.gemspec +1 -1
- data/bin/cleanify.rb +50 -0
- data/examples/amqp/simple.rb +6 -4
- data/examples/mq/ack.rb +8 -6
- data/examples/mq/automatic_binding_for_default_direct_exchange.rb +65 -0
- data/examples/mq/callbacks.rb +9 -1
- data/examples/mq/clock.rb +17 -17
- data/examples/mq/hashtable.rb +19 -10
- data/examples/mq/internal.rb +13 -11
- data/examples/mq/logger.rb +38 -36
- data/examples/mq/multiclock.rb +16 -7
- data/examples/mq/pingpong.rb +16 -7
- data/examples/mq/pop.rb +8 -6
- data/examples/mq/primes-simple.rb +2 -0
- data/examples/mq/primes.rb +7 -5
- data/examples/mq/stocks.rb +14 -5
- data/lib/amqp.rb +12 -8
- data/lib/amqp/buffer.rb +35 -158
- data/lib/amqp/client.rb +34 -22
- data/lib/amqp/frame.rb +8 -64
- data/lib/amqp/protocol.rb +21 -70
- data/lib/amqp/server.rb +11 -9
- data/lib/amqp/spec.rb +8 -6
- data/lib/amqp/version.rb +2 -0
- data/lib/ext/blankslate.rb +3 -1
- data/lib/ext/em.rb +2 -0
- data/lib/ext/emfork.rb +13 -11
- data/lib/mq.rb +253 -156
- data/lib/mq/collection.rb +6 -88
- data/lib/mq/exchange.rb +70 -13
- data/lib/mq/header.rb +12 -6
- data/lib/mq/logger.rb +9 -7
- data/lib/mq/queue.rb +42 -30
- data/lib/mq/rpc.rb +6 -4
- data/protocol/codegen.rb +20 -18
- data/research/api.rb +10 -46
- data/research/primes-forked.rb +9 -7
- data/research/primes-processes.rb +74 -72
- data/research/primes-threaded.rb +9 -7
- data/spec/integration/automatic_binding_for_default_direct_exchange_spec.rb +61 -0
- data/spec/mq_helper.rb +70 -0
- data/spec/spec_helper.rb +84 -29
- data/spec/unit/amqp/buffer_spec.rb +178 -0
- data/spec/unit/amqp/client_spec.rb +472 -0
- data/spec/unit/amqp/frame_spec.rb +60 -0
- data/spec/unit/amqp/misc_spec.rb +123 -0
- data/spec/unit/amqp/protocol_spec.rb +53 -0
- data/spec/unit/mq/channel_close_spec.rb +15 -0
- data/spec/unit/mq/collection_spec.rb +129 -0
- data/spec/unit/mq/exchange_declaration_spec.rb +524 -0
- data/spec/unit/mq/misc_spec.rb +228 -0
- data/spec/unit/mq/mq_basic_spec.rb +39 -0
- data/spec/unit/mq/queue_declaration_spec.rb +97 -0
- data/spec/unit/mq/queue_spec.rb +71 -0
- metadata +33 -21
- data/Gemfile.lock +0 -16
- data/old/README +0 -30
- data/old/Rakefile +0 -12
- data/old/amqp-0.8.json +0 -606
- data/old/amqp_spec.rb +0 -796
- data/old/amqpc.rb +0 -695
- data/old/codegen.rb +0 -148
- data/spec/channel_close_spec.rb +0 -13
- data/spec/sync_async_spec.rb +0 -52
data/old/codegen.rb
DELETED
@@ -1,148 +0,0 @@
|
|
1
|
-
require 'rubygems'
|
2
|
-
require 'json'
|
3
|
-
|
4
|
-
s = JSON.parse(File.read('amqp-0.8.json'))
|
5
|
-
|
6
|
-
# require 'pp'
|
7
|
-
# pp(s)
|
8
|
-
# exit
|
9
|
-
|
10
|
-
require 'erb'
|
11
|
-
|
12
|
-
puts ERB.new(%q[
|
13
|
-
module AMQP
|
14
|
-
HEADER = <%= s['name'].dump %>.freeze
|
15
|
-
VERSION_MAJOR = <%= s['major-version'] %>
|
16
|
-
VERSION_MINOR = <%= s['minor-version'] %>
|
17
|
-
PORT = <%= s['port'] %>
|
18
|
-
|
19
|
-
class Frame
|
20
|
-
TYPES = [
|
21
|
-
nil,
|
22
|
-
<%- s['constants'].select{|c| (1..8).include? c['value'] }.each do |c| -%>
|
23
|
-
:<%= c['name'].tr('-', '_').gsub(/^FRAME_/,'').upcase -%>,
|
24
|
-
<%- end -%>
|
25
|
-
]
|
26
|
-
FOOTER = <%= frame_end = s['constants'].find{|c| c['name'] == 'FRAME-END' }['value'] %>
|
27
|
-
end
|
28
|
-
|
29
|
-
RESPONSES = {
|
30
|
-
<%- s['constants'].select{|c| c['value'] != frame_end and (200..500).include? c['value'] }.each do |c| -%>
|
31
|
-
<%= c['value'] %> => :<%= c['name'].tr('-', '_').gsub(/^FRAME_/,'').upcase -%>,
|
32
|
-
<%- end -%>
|
33
|
-
}
|
34
|
-
|
35
|
-
FIELDS = [
|
36
|
-
<%- s['domains'].select{|d| d.first == d.last }.each do |d| -%>
|
37
|
-
:<%= d.first -%>,
|
38
|
-
<%- end -%>
|
39
|
-
]
|
40
|
-
|
41
|
-
module Protocol
|
42
|
-
class Class
|
43
|
-
class << self
|
44
|
-
FIELDS.each do |f|
|
45
|
-
class_eval %[
|
46
|
-
def #{f} name
|
47
|
-
properties << [ :#{f}, name ] unless properties.include?([:#{f}, name])
|
48
|
-
attr_accessor name
|
49
|
-
end
|
50
|
-
]
|
51
|
-
end
|
52
|
-
|
53
|
-
def properties() @properties ||= [] end
|
54
|
-
|
55
|
-
def id() self::ID end
|
56
|
-
def name() self::NAME end
|
57
|
-
end
|
58
|
-
|
59
|
-
class Method
|
60
|
-
class << self
|
61
|
-
FIELDS.each do |f|
|
62
|
-
class_eval %[
|
63
|
-
def #{f} name
|
64
|
-
arguments << [ :#{f}, name ] unless arguments.include?([:#{f}, name])
|
65
|
-
attr_accessor name
|
66
|
-
end
|
67
|
-
]
|
68
|
-
end
|
69
|
-
|
70
|
-
def arguments() @arguments ||= [] end
|
71
|
-
|
72
|
-
def parent() Protocol.const_get(self.to_s[/Protocol::(.+?)::/,1]) end
|
73
|
-
def id() self::ID end
|
74
|
-
def name() self::NAME end
|
75
|
-
end
|
76
|
-
|
77
|
-
def == b
|
78
|
-
self.class.arguments.inject(true) do |eql, (type, name)|
|
79
|
-
eql and __send__("#{name}") == b.__send__("#{name}")
|
80
|
-
end
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
def self.methods() @methods ||= {} end
|
85
|
-
|
86
|
-
def self.Method(id, name)
|
87
|
-
@_base_methods ||= {}
|
88
|
-
@_base_methods[id] ||= ::Class.new(Method) do
|
89
|
-
class_eval %[
|
90
|
-
def self.inherited klass
|
91
|
-
klass.const_set(:ID, #{id})
|
92
|
-
klass.const_set(:NAME, :#{name.to_s})
|
93
|
-
klass.parent.methods[#{id}] = klass
|
94
|
-
klass.parent.methods[klass::NAME] = klass
|
95
|
-
end
|
96
|
-
]
|
97
|
-
end
|
98
|
-
end
|
99
|
-
end
|
100
|
-
|
101
|
-
def self.classes() @classes ||= {} end
|
102
|
-
|
103
|
-
def self.Class(id, name)
|
104
|
-
@_base_classes ||= {}
|
105
|
-
@_base_classes[id] ||= ::Class.new(Class) do
|
106
|
-
class_eval %[
|
107
|
-
def self.inherited klass
|
108
|
-
klass.const_set(:ID, #{id})
|
109
|
-
klass.const_set(:NAME, :#{name.to_s})
|
110
|
-
Protocol.classes[#{id}] = klass
|
111
|
-
Protocol.classes[klass::NAME] = klass
|
112
|
-
end
|
113
|
-
]
|
114
|
-
end
|
115
|
-
end
|
116
|
-
|
117
|
-
<%- s['classes'].each do |c| -%>
|
118
|
-
class <%= c['name'].capitalize.ljust(12) %> < Class(<%= c['id'] %>, :<%= c['name'] %>); end
|
119
|
-
<%- end -%>
|
120
|
-
|
121
|
-
<%- s['classes'].each do |c| -%>
|
122
|
-
class <%= c['name'].capitalize %>
|
123
|
-
<%- c['properties'].each do |p| -%>
|
124
|
-
<%= p['type'].ljust(10) %> :<%= p['name'].tr('-','_') %>
|
125
|
-
<%- end if c['properties'] -%>
|
126
|
-
|
127
|
-
<%- c['methods'].each do |m| -%>
|
128
|
-
class <%= m['name'].capitalize.gsub(/-(.)/){ "#{$1.upcase}"}.ljust(12) %> < Method(<%= m['id'] %>, :<%= m['name'].tr('- ','_') %>); end
|
129
|
-
<%- end -%>
|
130
|
-
|
131
|
-
<%- c['methods'].each do |m| -%>
|
132
|
-
class <%= m['name'].capitalize.gsub(/-(.)/){ "#{$1.upcase}"} %>
|
133
|
-
<%- m['arguments'].each do |a| -%>
|
134
|
-
<%- if a['domain'] -%>
|
135
|
-
<%= s['domains'].find{|k,v| k == a['domain']}.last.ljust(10) %> :<%= a['name'].tr('- ','_') %>
|
136
|
-
<%- else -%>
|
137
|
-
<%= a['type'].ljust(10) %> :<%= a['name'].tr('- ','_') %>
|
138
|
-
<%- end -%>
|
139
|
-
<%- end if m['arguments'] -%>
|
140
|
-
end
|
141
|
-
|
142
|
-
<%- end -%>
|
143
|
-
end
|
144
|
-
|
145
|
-
<%- end -%>
|
146
|
-
end
|
147
|
-
end
|
148
|
-
].gsub!(/^ /,''), nil, '>-%').result(binding)
|
data/spec/channel_close_spec.rb
DELETED
@@ -1,13 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
|
3
|
-
require File.expand_path("../spec_helper", __FILE__)
|
4
|
-
|
5
|
-
EM.describe "MQ#close(&callback)" do
|
6
|
-
default_timeout 5
|
7
|
-
|
8
|
-
should "take a callback which will run when we get back Channel.Close-Ok" do
|
9
|
-
MQ.new.close do |amq|
|
10
|
-
done
|
11
|
-
end
|
12
|
-
end
|
13
|
-
end
|
data/spec/sync_async_spec.rb
DELETED
@@ -1,52 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
|
3
|
-
require File.expand_path("../spec_helper", __FILE__)
|
4
|
-
|
5
|
-
EM.describe MQ::Queue do
|
6
|
-
default_timeout 5
|
7
|
-
|
8
|
-
before do
|
9
|
-
@mq = MQ.new
|
10
|
-
end
|
11
|
-
|
12
|
-
# Queue.Declare
|
13
|
-
should "update MQ::Queue#name by the name generated by the broker" do
|
14
|
-
@mq.queue("") do |queue, *args|
|
15
|
-
queue.name.should.not.be.empty
|
16
|
-
done
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
# PENDING: this spec is currently failing
|
21
|
-
# https://github.com/tmm1/amqp/issues/issue/31
|
22
|
-
should "be able to access message count" do
|
23
|
-
name = Array.new(16) { rand(256) }.pack("C*").unpack("H*").first
|
24
|
-
exchange = MQ.fanout("fanout")
|
25
|
-
@mq.queue!(name) do |queue, *args|
|
26
|
-
queue.bind(exchange) do
|
27
|
-
3.times { exchange.publish("foobar") }
|
28
|
-
# We have 1 channel per 1 MQ instance, so we can just send a sync request
|
29
|
-
# and once the requst is finished, we can be sure that the previous one is
|
30
|
-
# finished as well. So we can be sure that all the Basic.Publish actions are done.
|
31
|
-
@mq.queue!(name) do |queue, message_count, *args|
|
32
|
-
message_count.should.eql 3
|
33
|
-
done
|
34
|
-
end
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
# TODO: this will require quite a lot of code, but it should be tested anyway.
|
40
|
-
# should "be able to access consumer count" do
|
41
|
-
# end
|
42
|
-
|
43
|
-
# Queue.Bind
|
44
|
-
should "work with a callback" do
|
45
|
-
exchange = MQ.fanout("fanout")
|
46
|
-
@mq.queue("") do |queue, *args|
|
47
|
-
queue.bind(exchange) do |*args|
|
48
|
-
done
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|