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.
@@ -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
- GRANTEE_EMAIL_ADDRESS = 'madhur@amazon.com'
6
- RIGHT_MESSAGE_TEXT = 'Right test message'
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
- def setup
10
- @sqs = Rightscale::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key)
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
- def assert_eventually_equal(value, timeout=30, failmsg="", &block)
37
- start_time = Time.now.to_i
38
- tries = 0
39
- while(yield != value) do
40
- tries += 1
41
- print '-'
42
- STDOUT.flush
43
- s = Time.now.to_i - start_time
44
- flunk("Timeout: #{failmsg}: did not equal \"#{value}\" after #{tries} tries in #{s}s.") if s > timeout
45
- sleep(1)
46
- setup if (tries % 10) == 0
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
- def test_01_create_queue
56
- queue_url = @sqs.create_queue @queue_name
57
- assert queue_url[/http.*#{@queue_name}/], 'New queue creation fail'
58
- end
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
- def test_02_list_queues
61
- wait_for_queue_url(@queue_name)
62
- queues = @sqs.list_queues('right_')
63
- assert queues.size>0, 'Must more that 0 queues in list'
64
- end
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
- def test_03_set_and_get_queue_attributes
67
- queue_url = @sqs.queue_url_by_name(@queue_name)
68
- assert queue_url[/http.*#{@queue_name}/], "#{@queue_name} must exist!"
69
- assert @sqs.set_queue_attributes(queue_url, 'VisibilityTimeout', 111), 'Set_queue_attributes fail'
70
- sleep 20 # Amazon needs some time to change attribute
71
- assert_equal '111', @sqs.get_queue_attributes(queue_url)['VisibilityTimeout'], 'New VisibilityTimeout must be equal to 111'
72
- end
73
-
74
- def test_04_set_and_get_visibility_timeout
75
- queue_url = @sqs.queue_url_by_name(@queue_name)
76
- assert @sqs.set_visibility_timeout(queue_url, 222), 'Set_visibility_timeout fail'
77
- sleep 20 # Amazon needs some time to change attribute
78
- #assert_equal 222, @sqs.get_visibility_timeout(queue_url), 'Get_visibility_timeout must return to 222'
79
- assert_eventually_equal(222, 60, 'Get_visibility_timeout must return to 222') do
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
- def test_08_receive_message
108
- queue_url = @sqs.queue_url_by_name(@queue_name)
109
- r_message = @sqs.receive_message(queue_url, 1)
110
- assert_equal RIGHT_MESSAGE_TEXT, r_message[:body], 'Receive message get wron message text'
111
- p_message = @sqs.peek_message(queue_url, r_message[:id])
112
- assert_equal r_message[:body], p_message[:body], 'Received and Peeked messages must be equal'
113
- assert @sqs.change_message_visibility(queue_url, r_message[:id], 0), 'Change_message_visibility fail'
114
- end
115
-
116
- def test_09_delete_message
117
- queue_url = @sqs.queue_url_by_name(@queue_name)
118
- message = @sqs.receive_message(queue_url)
119
- assert @sqs.delete_message(queue_url, message[:id]), 'Delete_message fail'
120
- assert @sqs.pop_message(queue_url), 'Pop_message fail'
121
- end
122
-
123
- def test_10_clear_and_delete_queue
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
- def test_20_sqs_create_delete_queue
138
- assert @s, 'Rightscale::Sqs must exist'
139
- # get queues list
140
- queues_size = @s.queues.size
141
- # create new queue
142
- queue = @s.queue("#{@queue_name}_20", true)
143
- # check that it is created
144
- assert queue.is_a?(Rightscale::Sqs::Queue)
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
- def test_27_set_amazon_problems
266
- original_problems = Rightscale::SqsInterface.amazon_problems
267
- assert(original_problems.length > 0)
268
- Rightscale::SqsInterface.amazon_problems= original_problems << "A New Problem"
269
- new_problems = Rightscale::SqsInterface.amazon_problems
270
- assert_equal(new_problems, original_problems)
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
- Rightscale::SqsInterface.amazon_problems= nil
273
- assert_nil(Rightscale::SqsInterface.amazon_problems)
274
- end
193
+ Aws::SqsInterface.amazon_problems= nil
194
+ assert_nil(Aws::SqsInterface.amazon_problems)
195
+ end
275
196
 
276
- def test_28_check_threading_model
277
- assert(!@sqs.multi_thread)
278
- newsqs = Rightscale::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key, {:multi_thread => true})
279
- assert(newsqs.multi_thread)
280
- end
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
- def test_29_signature_version_0
283
- sqs = Rightscale::SqsInterface.new(TestCredentials.aws_access_key_id, TestCredentials.aws_secret_access_key, :signature_version => '0')
284
- assert_nothing_raised do
285
- sqs.list_queues
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
- # check that the request has correct signature version
288
- assert sqs.last_request.path.include?('SignatureVersion=0')
289
- end
290
-
211
+
291
212
  end