aws 1.11.38 → 2.1.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/README.markdown +20 -23
- data/lib/acf/right_acf_interface.rb +17 -17
- data/lib/aws.rb +27 -0
- data/lib/awsbase/right_awsbase.rb +8 -8
- data/lib/ec2/right_ec2.rb +37 -35
- data/lib/ec2/right_mon_interface.rb +25 -15
- data/lib/elb/right_elb_interface.rb +6 -6
- data/lib/right_aws.rb +6 -17
- data/lib/s3/right_s3.rb +58 -58
- data/lib/s3/right_s3_interface.rb +18 -18
- data/lib/sdb/active_sdb.rb +28 -28
- data/lib/sdb/right_sdb_interface.rb +18 -18
- data/lib/sqs/right_sqs.rb +13 -13
- data/lib/sqs/right_sqs_interface.rb +12 -12
- data/test/acf/test_right_acf.rb +10 -8
- data/test/ec2/test_helper.rb +1 -1
- data/test/ec2/test_mon.rb +17 -0
- data/test/ec2/test_right_ec2.rb +9 -7
- data/test/s3/test_helper.rb +2 -1
- data/test/s3/test_right_s3.rb +417 -411
- data/test/s3/test_right_s3_stubbed.rb +11 -9
- data/test/sdb/test_active_sdb.rb +11 -10
- data/test/sdb/test_right_sdb.rb +210 -242
- data/test/sqs/test_right_sqs.rb +190 -269
- data/test/test_credentials.rb +52 -40
- metadata +4 -3
- data/test/sqs/test_right_sqs_gen2.rb +0 -209
data/test/sqs/test_right_sqs.rb
CHANGED
@@ -1,291 +1,212 @@
|
|
1
1
|
require File.dirname(__FILE__) + '/test_helper.rb'
|
2
|
+
require File.dirname(__FILE__) + '/../test_credentials.rb'
|
3
|
+
|
2
4
|
|
3
5
|
class TestSqs < Test::Unit::TestCase
|
4
6
|
|
5
|
-
|
6
|
-
|
7
|
+
GRANTEE_EMAIL_ADDRESS = 'fester@example.com'
|
8
|
+
RIGHT_MESSAGE_TEXT = 'Right test message'
|
9
|
+
|
10
|
+
|
11
|
+
def setup
|
12
|
+
TestCredentials.get_credentials
|
13
|
+
@sqs = Aws::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key)
|
14
|
+
@queue_name = 'right_sqs_test_gen2_queue'
|
15
|
+
# for classes
|
16
|
+
@s = Aws::Sqs.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key)
|
17
|
+
end
|
18
|
+
|
19
|
+
# Wait for the queue to appear in the queues list.
|
20
|
+
# Amazon needs some time to after the queue creation to place
|
21
|
+
# it to the accessible queues list. If we dont want to get
|
22
|
+
# the additional faults then wait a bit...
|
23
|
+
def wait_for_queue_url(queue_name)
|
24
|
+
queue_url = nil
|
25
|
+
until queue_url
|
26
|
+
queue_url = @sqs.queue_url_by_name(queue_name)
|
27
|
+
unless queue_url
|
28
|
+
print '-'
|
29
|
+
STDOUT.flush
|
30
|
+
sleep 1
|
31
|
+
end
|
32
|
+
end
|
33
|
+
queue_url
|
34
|
+
end
|
35
|
+
|
36
|
+
|
37
|
+
#---------------------------
|
38
|
+
# Rightscale::SqsInterface
|
39
|
+
#---------------------------
|
40
|
+
|
41
|
+
def test_01_create_queue
|
42
|
+
queue_url = @sqs.create_queue @queue_name
|
43
|
+
assert queue_url[/http.*#{@queue_name}/], 'New queue creation failed'
|
44
|
+
end
|
45
|
+
|
46
|
+
def test_02_list_queues
|
47
|
+
wait_for_queue_url(@queue_name)
|
48
|
+
queues = @sqs.list_queues('right_')
|
49
|
+
assert queues.size>0, 'Must more that 0 queues in list'
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_03_set_and_get_queue_attributes
|
53
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
54
|
+
assert queue_url[/http.*#{@queue_name}/], "#{@queue_name} must exist!"
|
55
|
+
assert @sqs.set_queue_attributes(queue_url, 'VisibilityTimeout', 111), 'Set_queue_attributes fail'
|
56
|
+
sleep 20 # Amazon needs some time to change attribute
|
57
|
+
assert_equal '111', @sqs.get_queue_attributes(queue_url)['VisibilityTimeout'], 'New VisibilityTimeout must be equal to 111'
|
58
|
+
end
|
59
|
+
|
60
|
+
def test_06_send_message
|
61
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
62
|
+
# send 5 messages for the tests below
|
63
|
+
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
64
|
+
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
65
|
+
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
66
|
+
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
67
|
+
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
68
|
+
end
|
69
|
+
|
70
|
+
def test_07_get_queue_length
|
71
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
72
|
+
assert_equal 5, @sqs.get_queue_length(queue_url), 'Queue must have 5 messages'
|
73
|
+
end
|
74
|
+
|
75
|
+
def test_08_receive_message
|
76
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
77
|
+
r_message = @sqs.receive_message(queue_url, 1)[0]
|
78
|
+
assert r_message, "Receive returned no message(s), but this is not necessarily incorrect"
|
79
|
+
assert_equal RIGHT_MESSAGE_TEXT, r_message['Body'], 'Receive message got wrong message text'
|
80
|
+
end
|
81
|
+
|
82
|
+
def test_09_delete_message
|
83
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
84
|
+
message = @sqs.receive_message(queue_url)[0]
|
85
|
+
assert @sqs.delete_message(queue_url, message['ReceiptHandle']), 'Delete_message fail'
|
86
|
+
assert @sqs.pop_message(queue_url), 'Pop_message fail'
|
87
|
+
end
|
7
88
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
@queue_name = 'right_sqs_test_awesome_queue'
|
12
|
-
# for classes
|
13
|
-
@s = Rightscale::Sqs.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key)
|
14
|
-
end
|
15
|
-
|
16
|
-
# Wait for the queue to appears in the queues list.
|
17
|
-
# Amazon needs some time to after the queue creation to place
|
18
|
-
# it to the accessible queues list. If we dont want to get
|
19
|
-
# the additional faults then wait a bit...
|
20
|
-
def wait_for_queue_url(queue_name)
|
21
|
-
queue_url = nil
|
22
|
-
until queue_url
|
23
|
-
queue_url = @sqs.queue_url_by_name(queue_name)
|
24
|
-
unless queue_url
|
25
|
-
print '-'
|
26
|
-
STDOUT.flush
|
27
|
-
sleep 1
|
28
|
-
end
|
89
|
+
def test_10_clear_and_delete_queue
|
90
|
+
queue_url = @sqs.queue_url_by_name(@queue_name)
|
91
|
+
assert @sqs.delete_queue(queue_url)
|
29
92
|
end
|
30
|
-
queue_url
|
31
|
-
end
|
32
93
|
|
33
|
-
|
94
|
+
#---------------------------
|
95
|
+
# Aws::Sqs classes
|
96
|
+
#---------------------------
|
34
97
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
98
|
+
def test_20_sqs_create_delete_queue
|
99
|
+
assert @s, 'Aws::Sqs must exist'
|
100
|
+
# get queues list
|
101
|
+
queues_size = @s.queues.size
|
102
|
+
# create new queue
|
103
|
+
queue = @s.queue("#{@queue_name}_20", true)
|
104
|
+
# check that it is created
|
105
|
+
assert queue.is_a?(Aws::Sqs::Queue)
|
106
|
+
wait_for_queue_url(@queue_name)
|
107
|
+
# check that amount of queues has increased
|
108
|
+
assert_equal queues_size + 1, @s.queues.size
|
109
|
+
# delete queue
|
110
|
+
assert queue.delete
|
47
111
|
end
|
48
|
-
end
|
49
|
-
|
50
|
-
|
51
|
-
#---------------------------
|
52
|
-
# Rightscale::SqsInterface
|
53
|
-
#---------------------------
|
54
112
|
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
113
|
+
def test_21_queue_create
|
114
|
+
# create new queue
|
115
|
+
queue = Aws::Sqs::Queue.create(@s, "#{@queue_name}_21", true)
|
116
|
+
# check that it is created
|
117
|
+
assert queue.is_a?(Aws::Sqs::Queue)
|
118
|
+
wait_for_queue_url(@queue_name)
|
119
|
+
end
|
59
120
|
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
121
|
+
def test_22_queue_attributes
|
122
|
+
queue = Aws::Sqs::Queue.create(@s, "#{@queue_name}_21", false)
|
123
|
+
# get a list of attrinutes
|
124
|
+
attributes = queue.get_attribute
|
125
|
+
assert attributes.is_a?(Hash) && attributes.size>0
|
126
|
+
# get attribute value and increase it by 10
|
127
|
+
v = (queue.get_attribute('VisibilityTimeout').to_i + 10).to_s
|
128
|
+
# set attribute
|
129
|
+
assert queue.set_attribute('VisibilityTimeout', v)
|
130
|
+
# wait a bit
|
131
|
+
sleep 20
|
132
|
+
# check that attribute has changed
|
133
|
+
assert_equal v, queue.get_attribute('VisibilityTimeout')
|
134
|
+
# get queue visibility timeout
|
135
|
+
assert_equal v, queue.visibility
|
136
|
+
# change it
|
137
|
+
queue.visibility = queue.visibility.to_i + 10
|
138
|
+
# make sure that it is changed
|
139
|
+
assert v.to_i + 10, queue.visibility
|
140
|
+
end
|
65
141
|
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
@sqs.get_visibility_timeout(queue_url)
|
142
|
+
def test_24_send_size
|
143
|
+
queue = Aws::Sqs::Queue.create(@s, "#{@queue_name}_24", true)
|
144
|
+
# send 5 messages
|
145
|
+
assert queue.push('a1')
|
146
|
+
assert queue.push('a2')
|
147
|
+
assert queue.push('a3')
|
148
|
+
assert queue.push('a4')
|
149
|
+
assert queue.push('a5')
|
150
|
+
# check queue size
|
151
|
+
assert_equal 5, queue.size
|
152
|
+
# send one more
|
153
|
+
assert queue.push('a6')
|
154
|
+
# check queue size again
|
155
|
+
assert_equal 6, queue.size
|
81
156
|
end
|
82
|
-
end
|
83
|
-
|
84
|
-
def test_05_add_test_remove_grant
|
85
|
-
queue_url = @sqs.queue_url_by_name(@queue_name)
|
86
|
-
assert @sqs.add_grant(queue_url, GRANTEE_EMAIL_ADDRESS, 'FULLCONTROL'), 'Add grant fail'
|
87
|
-
grants_list = @sqs.list_grants(queue_url, GRANTEE_EMAIL_ADDRESS)
|
88
|
-
assert grants_list.size>0, 'List_grants must return at least 1 record for user #{GRANTEE_EMAIL_ADDRESS}'
|
89
|
-
assert @sqs.remove_grant(queue_url, GRANTEE_EMAIL_ADDRESS, 'FULLCONTROL'), 'Remove_grant fail'
|
90
|
-
end
|
91
|
-
|
92
|
-
def test_06_send_message
|
93
|
-
queue_url = @sqs.queue_url_by_name(@queue_name)
|
94
|
-
# send 5 messages for the tests below
|
95
|
-
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
96
|
-
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
97
|
-
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
98
|
-
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
99
|
-
assert @sqs.send_message(queue_url, RIGHT_MESSAGE_TEXT)
|
100
|
-
end
|
101
|
-
|
102
|
-
def test_07_get_queue_length
|
103
|
-
queue_url = @sqs.queue_url_by_name(@queue_name)
|
104
|
-
assert_equal 5, @sqs.get_queue_length(queue_url), 'Queue must have 5 messages'
|
105
|
-
end
|
106
157
|
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
queue_url = @sqs.queue_url_by_name(@queue_name)
|
125
|
-
assert_raise(Rightscale::AwsError) { @sqs.delete_queue(queue_url) }
|
126
|
-
## oops, force_clear_queue does not work any more - amazon expects for 60 secs timeout between
|
127
|
-
## queue deletion and recreation...
|
128
|
-
## assert @sqs.force_clear_queue(queue_url), 'Force_clear_queue fail'
|
129
|
-
assert @sqs.clear_queue(queue_url), 'Clear_queue fail'
|
130
|
-
assert @sqs.delete_queue(queue_url), 'Delete_queue fail'
|
131
|
-
end
|
132
|
-
|
133
|
-
#---------------------------
|
134
|
-
# Rightscale::Sqs classes
|
135
|
-
#---------------------------
|
158
|
+
def test_25_message_receive_pop_delete
|
159
|
+
queue = Aws::Sqs::Queue.create(@s, "#{@queue_name}_24", false)
|
160
|
+
# get queue size
|
161
|
+
size = queue.size
|
162
|
+
# get first message
|
163
|
+
m1 = queue.receive(10)
|
164
|
+
assert m1.is_a?(Aws::Sqs::Message)
|
165
|
+
# pop second message
|
166
|
+
m2 = queue.pop
|
167
|
+
assert m2.is_a?(Aws::Sqs::Message)
|
168
|
+
# make sure that queue size has decreased
|
169
|
+
assert_equal size-1, queue.size
|
170
|
+
# delete messsage
|
171
|
+
assert m1.delete
|
172
|
+
# make sure that queue size has decreased again
|
173
|
+
assert_equal size-2, queue.size
|
174
|
+
end
|
136
175
|
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
wait_for_queue_url(@queue_name)
|
146
|
-
# check that amount of queues has increased
|
147
|
-
assert_eventually_equal(queues_size + 1, 60, "The number of queues did not increase by one") do
|
148
|
-
@s.queues.size
|
176
|
+
def test_26
|
177
|
+
queue = Aws::Sqs::Queue.create(@s, "#{@queue_name}_24", false)
|
178
|
+
# lock message
|
179
|
+
queue.receive(100)
|
180
|
+
# clear queue
|
181
|
+
assert queue.clear
|
182
|
+
# queue size is greater than zero
|
183
|
+
assert queue.size>0
|
149
184
|
end
|
150
|
-
# delete queue
|
151
|
-
assert queue.delete
|
152
|
-
end
|
153
|
-
|
154
|
-
def test_21_queue_create
|
155
|
-
# create new queue
|
156
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_21", true)
|
157
|
-
# check that it is created
|
158
|
-
assert queue.is_a?(Rightscale::Sqs::Queue)
|
159
|
-
wait_for_queue_url(@queue_name)
|
160
|
-
end
|
161
|
-
|
162
|
-
def test_22_queue_attributes
|
163
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_21", false)
|
164
|
-
# get a list of attrinutes
|
165
|
-
attributes = queue.get_attribute
|
166
|
-
assert attributes.is_a?(Hash) && attributes.size>0
|
167
|
-
# get attribute value and increase it by 10
|
168
|
-
v = (queue.get_attribute('VisibilityTimeout').to_i + 10).to_s
|
169
|
-
# set attribute
|
170
|
-
assert queue.set_attribute('VisibilityTimeout', v)
|
171
|
-
# wait a bit
|
172
|
-
sleep 20
|
173
|
-
# check that attribute has changed
|
174
|
-
assert_equal v, queue.get_attribute('VisibilityTimeout')
|
175
|
-
# get queue visibility timeout
|
176
|
-
assert v.to_i, queue.visibility
|
177
|
-
# change it
|
178
|
-
queue.visibility += 10
|
179
|
-
# make sure that it is changed
|
180
|
-
assert v.to_i + 10, queue.visibility
|
181
|
-
end
|
182
|
-
|
183
|
-
def test_23_grantees
|
184
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_21", false)
|
185
|
-
# get a list of grantees
|
186
|
-
grantees = queue.grantees
|
187
|
-
# well, queue must exist at least some seconds before we could add grantees to it....
|
188
|
-
# otherwise we get "Queue does not exists" message. Hence we use the queue
|
189
|
-
# has been created at previous step.
|
190
|
-
#
|
191
|
-
# create new grantee
|
192
|
-
grantee = Rightscale::Sqs::Grantee.new(queue, GRANTEE_EMAIL_ADDRESS)
|
193
|
-
assert grantee.perms.empty?
|
194
|
-
# grant perms
|
195
|
-
assert grantee.grant('FULLCONTROL')
|
196
|
-
assert grantee.grant('RECEIVEMESSAGE')
|
197
|
-
assert_equal 2, grantee.perms.size
|
198
|
-
# make sure that amount of grantees has increased
|
199
|
-
assert grantees.size < queue.grantees.size
|
200
|
-
# revoke perms
|
201
|
-
assert grantee.revoke('RECEIVEMESSAGE')
|
202
|
-
assert_equal 1, grantee.perms.size
|
203
|
-
# remove grantee
|
204
|
-
assert grantee.drop
|
205
|
-
# Don't test this - just for cleanup purposes
|
206
|
-
queue.delete
|
207
|
-
end
|
208
|
-
|
209
|
-
def test_24_send_size
|
210
|
-
queue_url = @sqs.queue_url_by_name("#{@queue_name}_24")
|
211
|
-
@sqs.delete_queue(queue_url)
|
212
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_24", true)
|
213
|
-
# send 5 messages
|
214
|
-
assert queue.push('a1')
|
215
|
-
assert queue.push('a2')
|
216
|
-
assert queue.push('a3')
|
217
|
-
assert queue.push('a4')
|
218
|
-
assert queue.push('a5')
|
219
|
-
# check queue size
|
220
|
-
assert_equal 5, queue.size
|
221
|
-
# send one more
|
222
|
-
assert queue.push('a6')
|
223
|
-
# check queue size again
|
224
|
-
assert_equal 6, queue.size
|
225
|
-
end
|
226
|
-
|
227
|
-
def test_25_message_receive_pop_peek_delete
|
228
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_24", false)
|
229
|
-
# get queue size
|
230
|
-
size = queue.size
|
231
|
-
# get first message
|
232
|
-
m1 = queue.receive(10)
|
233
|
-
assert m1.is_a?(Rightscale::Sqs::Message)
|
234
|
-
# pop second message
|
235
|
-
m2 = queue.pop
|
236
|
-
assert m2.is_a?(Rightscale::Sqs::Message)
|
237
|
-
# make sure that queue size has decreased
|
238
|
-
assert_equal size-1, queue.size
|
239
|
-
# peek message 1
|
240
|
-
m1p = queue.peek(m1.id)
|
241
|
-
assert m1p.is_a?(Rightscale::Sqs::Message)
|
242
|
-
assert_equal m1.id, m1p.id
|
243
|
-
assert_equal m1.body, m1p.body
|
244
|
-
# change message visibility
|
245
|
-
assert m1.visibility = 30
|
246
|
-
# delete messsage
|
247
|
-
assert m1.delete
|
248
|
-
# make sure that queue size has decreased again
|
249
|
-
assert_equal size-2, queue.size
|
250
|
-
end
|
251
|
-
|
252
|
-
def test_26
|
253
|
-
queue = Rightscale::Sqs::Queue.create(@s, "#{@queue_name}_24", false)
|
254
|
-
# lock message
|
255
|
-
queue.receive(100)
|
256
|
-
# clear queue
|
257
|
-
assert queue.clear
|
258
|
-
# queue size is greater than zero
|
259
|
-
assert queue.size>0
|
260
|
-
queue.push('123456')
|
261
|
-
assert_raise(Rightscale::AwsError) { queue.delete }
|
262
|
-
assert queue.delete(true)
|
263
|
-
end
|
264
185
|
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
186
|
+
def test_27_set_amazon_problems
|
187
|
+
original_problems = Aws::SqsInterface.amazon_problems
|
188
|
+
assert(original_problems.length > 0)
|
189
|
+
Aws::SqsInterface.amazon_problems= original_problems << "A New Problem"
|
190
|
+
new_problems = Aws::SqsInterface.amazon_problems
|
191
|
+
assert_equal(new_problems, original_problems)
|
271
192
|
|
272
|
-
|
273
|
-
|
274
|
-
|
193
|
+
Aws::SqsInterface.amazon_problems= nil
|
194
|
+
assert_nil(Aws::SqsInterface.amazon_problems)
|
195
|
+
end
|
275
196
|
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
197
|
+
def test_28_check_threading_model
|
198
|
+
assert(!@sqs.multi_thread)
|
199
|
+
newsqs = Aws::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key, {:multi_thread => true})
|
200
|
+
assert(newsqs.multi_thread)
|
201
|
+
end
|
281
202
|
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
203
|
+
def test_29_signature_version_0
|
204
|
+
sqs = Aws::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key, :signature_version => '0')
|
205
|
+
assert_nothing_raised do
|
206
|
+
sqs.list_queues
|
207
|
+
end
|
208
|
+
# check that the request has correct signature version
|
209
|
+
assert sqs.last_request.path.include?('SignatureVersion=0')
|
286
210
|
end
|
287
|
-
|
288
|
-
assert sqs.last_request.path.include?('SignatureVersion=0')
|
289
|
-
end
|
290
|
-
|
211
|
+
|
291
212
|
end
|