Merge pull request #1 from Brett55/dev
Bug fix for infinite loop when WaitTimeSeconds was set to 0
This commit is contained in:
commit
2a8b5d5bb1
@ -334,6 +334,8 @@ class SQSBackend(BaseBackend):
|
||||
:param string queue_name: The name of the queue to read from.
|
||||
:param int count: The maximum amount of messages to retrieve.
|
||||
:param int visibility_timeout: The number of seconds the message should remain invisible to other queue readers.
|
||||
:param int wait_seconds_timeout: The duration (in seconds) for which the call waits for a message to arrive in
|
||||
the queue before returning. If a message is available, the call returns sooner than WaitTimeSeconds
|
||||
"""
|
||||
queue = self.get_queue(queue_name)
|
||||
result = []
|
||||
@ -347,6 +349,10 @@ class SQSBackend(BaseBackend):
|
||||
break
|
||||
|
||||
if len(queue.messages) == 0:
|
||||
# we want to break here, otherwise it will be an infinite loop
|
||||
if wait_seconds_timeout == 0:
|
||||
break
|
||||
|
||||
import time
|
||||
time.sleep(0.001)
|
||||
continue
|
||||
|
@ -208,6 +208,35 @@ def test_send_message():
|
||||
messages[1]['Body'].should.equal(body_two)
|
||||
|
||||
|
||||
@mock_sqs
|
||||
def test_receive_messages_with_wait_seconds_timeout_of_zero():
|
||||
"""
|
||||
test that zero messages is returned with a wait_seconds_timeout of zero,
|
||||
previously this created an infinite loop and nothing was returned
|
||||
:return:
|
||||
"""
|
||||
|
||||
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||
queue = sqs.create_queue(QueueName="blah")
|
||||
|
||||
messages = queue.receive_messages(WaitTimeSeconds=0)
|
||||
messages.should.equal([])
|
||||
|
||||
|
||||
@mock_sqs
|
||||
def test_receive_messages_with_wait_seconds_timeout_of_negative_one():
|
||||
"""
|
||||
test that zero messages is returned with a wait_seconds_timeout of negative 1
|
||||
:return:
|
||||
"""
|
||||
|
||||
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||
queue = sqs.create_queue(QueueName="blah")
|
||||
|
||||
messages = queue.receive_messages(WaitTimeSeconds=-1)
|
||||
messages.should.equal([])
|
||||
|
||||
|
||||
@mock_sqs_deprecated
|
||||
def test_send_message_with_xml_characters():
|
||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||
|
Loading…
Reference in New Issue
Block a user