moto/tests/test_sqs/test_server.py
2024-01-27 19:38:09 +00:00

96 lines
3.0 KiB
Python

import re
import threading
import time
import moto.server as server
from moto.core.utils import utcnow
def test_sqs_list_identities():
backend = server.create_backend_app("sqs")
test_client = backend.test_client()
res = test_client.get("/?Action=ListQueues")
assert b"ListQueuesResponse" in res.data
# Make sure that we can receive messages from queues whose name contains dots (".")
# The AWS API mandates that the names of FIFO queues use the suffix ".fifo"
# See: https://github.com/getmoto/moto/issues/866
for queue_name in ("testqueue", "otherqueue.fifo"):
res = test_client.put(f"/?Action=CreateQueue&QueueName={queue_name}")
res = test_client.put(
f"/123/{queue_name}?MessageBody=test-message&Action=SendMessage"
)
res = test_client.get(
f"/123/{queue_name}?Action=ReceiveMessage&MaxNumberOfMessages=1"
)
message = re.search("<Body>(.*?)</Body>", res.data.decode("utf-8")).groups()[0]
assert message == "test-message"
res = test_client.get("/?Action=ListQueues&QueueNamePrefix=other")
assert b"otherqueue.fifo" in res.data
assert b"testqueue" not in res.data
def test_messages_polling():
backend = server.create_backend_app("sqs")
test_client = backend.test_client()
messages = []
test_client.put("/?Action=CreateQueue&QueueName=testqueue")
def insert_messages():
messages_count = 5
while messages_count > 0:
test_client.put(
"/123/testqueue?MessageBody=test-message&Action=SendMessage"
"&Attribute.1.Name=WaitTimeSeconds&Attribute.1.Value=10"
)
messages_count -= 1
time.sleep(0.5)
def get_messages():
count = 0
while count < 5:
msg_res = test_client.get(
"/123/testqueue?Action=ReceiveMessage&MaxNumberOfMessages=1&WaitTimeSeconds=5"
)
new_msgs = re.findall("<Body>(.*?)</Body>", msg_res.data.decode("utf-8"))
count += len(new_msgs)
messages.append(new_msgs)
get_messages_thread = threading.Thread(target=get_messages)
insert_messages_thread = threading.Thread(target=insert_messages)
get_messages_thread.start()
insert_messages_thread.start()
get_messages_thread.join()
insert_messages_thread.join()
# got each message in a separate call to ReceiveMessage, despite the long
# WaitTimeSeconds
assert len(messages) == 5
def test_no_messages_polling_timeout():
backend = server.create_backend_app("sqs")
queue_name = "test-queue"
test_client = backend.test_client()
test_client.put(f"/?Action=CreateQueue&QueueName={queue_name}")
wait_seconds = 5
start = utcnow()
test_client.get(
f"/123/{queue_name}?Action=ReceiveMessage&"
f"MaxNumberOfMessages=1&WaitTimeSeconds={wait_seconds}"
)
end = utcnow()
duration = end - start
assert duration.seconds >= wait_seconds
assert duration.seconds <= wait_seconds + (wait_seconds / 2)