moto/tests/test_sqs/test_sqs.py

1560 lines
50 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
from __future__ import unicode_literals
2019-11-02 19:34:35 +00:00
import base64
import json
2017-10-29 19:11:52 +00:00
import os
2019-11-02 19:34:35 +00:00
import time
import uuid
2017-02-12 00:41:04 +00:00
2013-02-24 03:26:46 +00:00
import boto
import boto3
import botocore.exceptions
import six
2013-08-03 21:21:25 +00:00
import sure # noqa
2017-02-12 00:41:04 +00:00
import tests.backport_assert_raises # noqa
2019-11-02 19:34:35 +00:00
from boto.exception import SQSError
from boto.sqs.message import Message, RawMessage
from botocore.exceptions import ClientError
from freezegun import freeze_time
from moto import mock_sqs, mock_sqs_deprecated, settings
2017-10-29 19:11:52 +00:00
from nose import SkipTest
2019-11-02 19:34:35 +00:00
from nose.tools import assert_raises
from tests.helpers import requires_boto_gte
from moto.iam.models import ACCOUNT_ID
2014-11-16 22:57:46 +00:00
2017-09-22 19:08:20 +00:00
@mock_sqs
def test_create_fifo_queue_fail():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2017-09-22 19:08:20 +00:00
try:
2019-10-31 15:44:26 +00:00
sqs.create_queue(QueueName="test-queue", Attributes={"FifoQueue": "true"})
2017-09-22 19:08:20 +00:00
except botocore.exceptions.ClientError as err:
2019-10-31 15:44:26 +00:00
err.response["Error"]["Code"].should.equal("InvalidParameterValue")
2017-09-22 19:08:20 +00:00
else:
2019-11-02 19:34:35 +00:00
raise RuntimeError("Should of raised InvalidParameterValue Exception")
2017-09-22 19:08:20 +00:00
2017-10-10 19:51:48 +00:00
@mock_sqs
def test_create_queue_with_same_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2019-10-31 15:44:26 +00:00
dlq_url = sqs.create_queue(QueueName="test-queue-dlq")["QueueUrl"]
dlq_arn = sqs.get_queue_attributes(QueueUrl=dlq_url)["Attributes"]["QueueArn"]
attributes = {
2019-10-31 15:44:26 +00:00
"DelaySeconds": "900",
"MaximumMessageSize": "262144",
"MessageRetentionPeriod": "1209600",
"ReceiveMessageWaitTimeSeconds": "20",
"RedrivePolicy": '{"deadLetterTargetArn": "%s", "maxReceiveCount": 100}'
% (dlq_arn),
"VisibilityTimeout": "43200",
}
2019-10-31 15:44:26 +00:00
sqs.create_queue(QueueName="test-queue", Attributes=attributes)
2019-10-31 15:44:26 +00:00
sqs.create_queue(QueueName="test-queue", Attributes=attributes)
@mock_sqs
def test_create_queue_with_different_attributes_fail():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2019-10-31 15:44:26 +00:00
sqs.create_queue(QueueName="test-queue", Attributes={"VisibilityTimeout": "10"})
try:
2019-10-31 15:44:26 +00:00
sqs.create_queue(QueueName="test-queue", Attributes={"VisibilityTimeout": "60"})
except botocore.exceptions.ClientError as err:
2019-10-31 15:44:26 +00:00
err.response["Error"]["Code"].should.equal("QueueAlreadyExists")
else:
2019-10-31 15:44:26 +00:00
raise RuntimeError("Should of raised QueueAlreadyExists Exception")
2017-09-22 19:08:20 +00:00
@mock_sqs
def test_create_fifo_queue():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2017-09-22 19:08:20 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue.fifo", Attributes={"FifoQueue": "true"}
2017-09-22 19:08:20 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = resp["QueueUrl"]
2017-09-22 19:08:20 +00:00
response = sqs.get_queue_attributes(QueueUrl=queue_url)
2019-10-31 15:44:26 +00:00
response["Attributes"].should.contain("FifoQueue")
response["Attributes"]["FifoQueue"].should.equal("true")
2017-09-22 19:08:20 +00:00
2013-02-24 03:26:46 +00:00
@mock_sqs
def test_create_queue():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2017-10-10 19:51:48 +00:00
2019-10-31 15:44:26 +00:00
new_queue = sqs.create_queue(QueueName="test-queue")
2017-02-12 00:41:04 +00:00
new_queue.should_not.be.none
2019-10-31 15:44:26 +00:00
new_queue.should.have.property("url").should.contain("test-queue")
2017-02-12 00:41:04 +00:00
2019-10-31 15:44:26 +00:00
queue = sqs.get_queue_by_name(QueueName="test-queue")
queue.attributes.get("QueueArn").should_not.be.none
queue.attributes.get("QueueArn").split(":")[-1].should.equal("test-queue")
queue.attributes.get("QueueArn").split(":")[3].should.equal("us-east-1")
queue.attributes.get("VisibilityTimeout").should_not.be.none
queue.attributes.get("VisibilityTimeout").should.equal("30")
2013-02-24 03:26:46 +00:00
@mock_sqs
def test_create_queue_kms():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
new_queue = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue",
Attributes={
2019-10-31 15:44:26 +00:00
"KmsMasterKeyId": "master-key-id",
"KmsDataKeyReusePeriodSeconds": "600",
},
)
new_queue.should_not.be.none
2019-10-31 15:44:26 +00:00
queue = sqs.get_queue_by_name(QueueName="test-queue")
2019-10-31 15:44:26 +00:00
queue.attributes.get("KmsMasterKeyId").should.equal("master-key-id")
queue.attributes.get("KmsDataKeyReusePeriodSeconds").should.equal("600")
2019-10-13 12:51:31 +00:00
@mock_sqs
def test_create_queue_with_tags():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2019-10-13 12:51:31 +00:00
response = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue-with-tags", tags={"tag_key_1": "tag_value_1"}
2019-10-13 12:51:31 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = response["QueueUrl"]
2019-10-13 12:51:31 +00:00
2019-10-31 15:44:26 +00:00
client.list_queue_tags(QueueUrl=queue_url)["Tags"].should.equal(
{"tag_key_1": "tag_value_1"}
)
2019-10-13 12:51:31 +00:00
2019-10-26 20:26:48 +00:00
@mock_sqs
def test_get_queue_url():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
client.create_queue(QueueName="test-queue")
2019-10-26 20:26:48 +00:00
2019-10-31 15:44:26 +00:00
response = client.get_queue_url(QueueName="test-queue")
2019-10-26 20:26:48 +00:00
2019-10-31 15:44:26 +00:00
response.should.have.key("QueueUrl").which.should.contain("test-queue")
2019-10-26 20:26:48 +00:00
@mock_sqs
def test_get_queue_url_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2019-10-26 20:26:48 +00:00
2019-10-31 15:44:26 +00:00
client.get_queue_url.when.called_with(QueueName="non-existing-queue").should.throw(
ClientError, "The specified queue does not exist for this wsdl version."
2019-10-26 20:26:48 +00:00
)
2017-02-12 00:41:04 +00:00
@mock_sqs
2017-10-10 19:51:48 +00:00
def test_get_nonexistent_queue():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2017-10-10 19:51:48 +00:00
with assert_raises(ClientError) as err:
2019-10-31 15:44:26 +00:00
sqs.get_queue_by_name(QueueName="nonexisting-queue")
2017-10-10 19:51:48 +00:00
ex = err.exception
2019-10-31 15:44:26 +00:00
ex.operation_name.should.equal("GetQueueUrl")
ex.response["Error"]["Code"].should.equal("AWS.SimpleQueueService.NonExistentQueue")
2017-10-10 19:51:48 +00:00
with assert_raises(ClientError) as err:
2019-10-31 15:44:26 +00:00
sqs.Queue("http://whatever-incorrect-queue-address").load()
2017-10-10 19:51:48 +00:00
ex = err.exception
2019-10-31 15:44:26 +00:00
ex.operation_name.should.equal("GetQueueAttributes")
ex.response["Error"]["Code"].should.equal("AWS.SimpleQueueService.NonExistentQueue")
2013-02-24 03:26:46 +00:00
2017-09-22 19:08:20 +00:00
@mock_sqs
def test_message_send_without_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="blah")
2019-10-31 15:44:26 +00:00
msg = queue.send_message(MessageBody="derp")
msg.get("MD5OfMessageBody").should.equal("58fd9edd83341c29f1aebba81c31e257")
msg.shouldnt.have.key("MD5OfMessageAttributes")
msg.get("MessageId").should_not.contain(" \n")
messages = queue.receive_messages()
messages.should.have.length_of(1)
2013-02-24 03:26:46 +00:00
2017-09-22 19:08:20 +00:00
2014-11-16 22:57:46 +00:00
@mock_sqs
def test_message_send_with_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2017-02-12 00:41:04 +00:00
queue = sqs.create_queue(QueueName="blah")
msg = queue.send_message(
MessageBody="derp",
MessageAttributes={
2019-10-31 15:44:26 +00:00
"timestamp": {"StringValue": "1493147359900", "DataType": "Number"}
},
)
2019-10-31 15:44:26 +00:00
msg.get("MD5OfMessageBody").should.equal("58fd9edd83341c29f1aebba81c31e257")
msg.get("MD5OfMessageAttributes").should.equal("235c5c510d26fb653d073faed50ae77c")
msg.get("MessageId").should_not.contain(" \n")
messages = queue.receive_messages()
messages.should.have.length_of(1)
2017-02-12 00:41:04 +00:00
@mock_sqs
def test_message_with_complex_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="blah")
msg = queue.send_message(
MessageBody="derp",
MessageAttributes={
2019-10-31 15:44:26 +00:00
"ccc": {"StringValue": "testjunk", "DataType": "String"},
"aaa": {"BinaryValue": b"\x02\x03\x04", "DataType": "Binary"},
"zzz": {"DataType": "Number", "StringValue": "0230.01"},
"öther_encodings": {"DataType": "String", "StringValue": "T\xFCst"},
},
)
2019-10-31 15:44:26 +00:00
msg.get("MD5OfMessageBody").should.equal("58fd9edd83341c29f1aebba81c31e257")
msg.get("MD5OfMessageAttributes").should.equal("8ae21a7957029ef04146b42aeaa18a22")
msg.get("MessageId").should_not.contain(" \n")
2017-02-12 00:41:04 +00:00
messages = queue.receive_messages()
messages.should.have.length_of(1)
2014-11-16 22:57:46 +00:00
@mock_sqs
def test_send_message_with_message_group_id():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(
QueueName="test-group-id.fifo", Attributes={"FifoQueue": "true"}
)
sent = queue.send_message(
MessageBody="mydata",
MessageDeduplicationId="dedupe_id_1",
MessageGroupId="group_id_1",
)
messages = queue.receive_messages()
messages.should.have.length_of(1)
message_attributes = messages[0].attributes
2019-10-31 15:44:26 +00:00
message_attributes.should.contain("MessageGroupId")
message_attributes["MessageGroupId"].should.equal("group_id_1")
message_attributes.should.contain("MessageDeduplicationId")
message_attributes["MessageDeduplicationId"].should.equal("dedupe_id_1")
@mock_sqs
def test_send_message_with_unicode_characters():
2019-10-31 15:44:26 +00:00
body_one = "Héllo!😀"
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="blah")
msg = queue.send_message(MessageBody=body_one)
messages = queue.receive_messages()
message_body = messages[0].body
message_body.should.equal(body_one)
2017-02-12 00:41:04 +00:00
@mock_sqs
def test_set_queue_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2017-02-12 00:41:04 +00:00
queue = sqs.create_queue(QueueName="blah")
2014-11-16 22:57:46 +00:00
2019-10-31 15:44:26 +00:00
queue.attributes["VisibilityTimeout"].should.equal("30")
2014-11-16 22:57:46 +00:00
2017-02-12 00:41:04 +00:00
queue.set_attributes(Attributes={"VisibilityTimeout": "45"})
2019-10-31 15:44:26 +00:00
queue.attributes["VisibilityTimeout"].should.equal("45")
2014-11-16 22:57:46 +00:00
@mock_sqs
2017-02-12 00:41:04 +00:00
def test_create_queues_in_multiple_region():
2019-10-31 15:44:26 +00:00
west1_conn = boto3.client("sqs", region_name="us-west-1")
2017-02-12 00:41:04 +00:00
west1_conn.create_queue(QueueName="blah")
2019-10-31 15:44:26 +00:00
west2_conn = boto3.client("sqs", region_name="us-west-2")
2017-02-12 00:41:04 +00:00
west2_conn.create_queue(QueueName="test-queue")
2019-10-31 15:44:26 +00:00
list(west1_conn.list_queues()["QueueUrls"]).should.have.length_of(1)
list(west2_conn.list_queues()["QueueUrls"]).should.have.length_of(1)
2017-03-05 15:09:19 +00:00
if settings.TEST_SERVER_MODE:
2019-10-31 15:44:26 +00:00
base_url = "http://localhost:5000"
2017-03-05 15:09:19 +00:00
else:
2019-10-31 15:44:26 +00:00
base_url = "https://us-west-1.queue.amazonaws.com"
2017-03-05 15:09:19 +00:00
2019-10-31 15:44:26 +00:00
west1_conn.list_queues()["QueueUrls"][0].should.equal(
"{base_url}/{AccountId}/blah".format(base_url=base_url,AccountId=ACCCOUNT_ID)
2019-10-31 15:44:26 +00:00
)
@mock_sqs
def test_get_queue_with_prefix():
2019-10-31 15:44:26 +00:00
conn = boto3.client("sqs", region_name="us-west-1")
2017-02-12 00:41:04 +00:00
conn.create_queue(QueueName="prefixa-queue")
conn.create_queue(QueueName="prefixb-queue")
conn.create_queue(QueueName="test-queue")
2019-10-31 15:44:26 +00:00
conn.list_queues()["QueueUrls"].should.have.length_of(3)
2019-10-31 15:44:26 +00:00
queue = conn.list_queues(QueueNamePrefix="test-")["QueueUrls"]
queue.should.have.length_of(1)
2017-03-05 15:09:19 +00:00
if settings.TEST_SERVER_MODE:
2019-10-31 15:44:26 +00:00
base_url = "http://localhost:5000"
2017-03-05 15:09:19 +00:00
else:
2019-10-31 15:44:26 +00:00
base_url = "https://us-west-1.queue.amazonaws.com"
2017-03-05 15:09:19 +00:00
2017-02-24 02:37:43 +00:00
queue[0].should.equal(
"{base_url}/{AccountId}/test-queue".format(base_url=base_url, AccountId=ACCOUNT_ID)
2019-10-31 15:44:26 +00:00
)
2013-02-24 03:26:46 +00:00
@mock_sqs
def test_delete_queue():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
conn = boto3.client("sqs", region_name="us-east-1")
conn.create_queue(QueueName="test-queue", Attributes={"VisibilityTimeout": "3"})
queue = sqs.Queue("test-queue")
2013-02-24 03:26:46 +00:00
2019-10-31 15:44:26 +00:00
conn.list_queues()["QueueUrls"].should.have.length_of(1)
2013-02-24 03:26:46 +00:00
queue.delete()
2019-10-31 15:44:26 +00:00
conn.list_queues().get("QueueUrls").should.equal(None)
2013-02-24 03:26:46 +00:00
2017-02-12 00:41:04 +00:00
with assert_raises(botocore.exceptions.ClientError):
queue.delete()
2013-02-24 03:35:05 +00:00
@mock_sqs
def test_get_queue_attributes():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
response = client.create_queue(QueueName="test-queue")
queue_url = response["QueueUrl"]
response = client.get_queue_attributes(QueueUrl=queue_url)
2019-10-31 15:44:26 +00:00
response["Attributes"]["ApproximateNumberOfMessages"].should.equal("0")
response["Attributes"]["ApproximateNumberOfMessagesDelayed"].should.equal("0")
response["Attributes"]["ApproximateNumberOfMessagesNotVisible"].should.equal("0")
response["Attributes"]["CreatedTimestamp"].should.be.a(six.string_types)
response["Attributes"]["DelaySeconds"].should.equal("0")
response["Attributes"]["LastModifiedTimestamp"].should.be.a(six.string_types)
response["Attributes"]["MaximumMessageSize"].should.equal("65536")
response["Attributes"]["MessageRetentionPeriod"].should.equal("345600")
response["Attributes"]["QueueArn"].should.equal(
"arn:aws:sqs:us-east-1:{}:test-queue".format(ACCOUNT_ID)
2019-10-31 15:44:26 +00:00
)
response["Attributes"]["ReceiveMessageWaitTimeSeconds"].should.equal("0")
response["Attributes"]["VisibilityTimeout"].should.equal("30")
response = client.get_queue_attributes(
QueueUrl=queue_url,
AttributeNames=[
2019-10-31 15:44:26 +00:00
"ApproximateNumberOfMessages",
"MaximumMessageSize",
"QueueArn",
"VisibilityTimeout",
],
)
2019-10-31 15:44:26 +00:00
response["Attributes"].should.equal(
{
"ApproximateNumberOfMessages": "0",
"MaximumMessageSize": "65536",
"QueueArn": "arn:aws:sqs:us-east-1:{}:test-queue".format(ACCOUNT_ID),
2019-10-31 15:44:26 +00:00
"VisibilityTimeout": "30",
}
)
# should not return any attributes, if it was not set before
response = client.get_queue_attributes(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, AttributeNames=["KmsMasterKeyId"]
)
2019-10-31 15:44:26 +00:00
response.should_not.have.key("Attributes")
@mock_sqs
def test_get_queue_attributes_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
response = client.create_queue(QueueName="test-queue")
queue_url = response["QueueUrl"]
client.get_queue_attributes.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-non-existing"
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
)
client.get_queue_attributes.when.called_with(
QueueUrl=queue_url,
2019-10-31 15:44:26 +00:00
AttributeNames=["QueueArn", "not-existing", "VisibilityTimeout"],
).should.throw(ClientError, "Unknown Attribute not-existing.")
client.get_queue_attributes.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, AttributeNames=[""]
).should.throw(ClientError, "Unknown Attribute .")
client.get_queue_attributes.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, AttributeNames=[]
).should.throw(ClientError, "Unknown Attribute .")
2013-02-24 03:35:05 +00:00
@mock_sqs
def test_set_queue_attribute():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
conn = boto3.client("sqs", region_name="us-east-1")
conn.create_queue(QueueName="test-queue", Attributes={"VisibilityTimeout": "3"})
2013-02-24 03:35:05 +00:00
2017-02-12 00:41:04 +00:00
queue = sqs.Queue("test-queue")
2019-10-31 15:44:26 +00:00
queue.attributes["VisibilityTimeout"].should.equal("3")
2013-02-24 03:35:05 +00:00
2019-10-31 15:44:26 +00:00
queue.set_attributes(Attributes={"VisibilityTimeout": "45"})
2017-02-12 00:41:04 +00:00
queue = sqs.Queue("test-queue")
2019-10-31 15:44:26 +00:00
queue.attributes["VisibilityTimeout"].should.equal("45")
2013-02-24 16:06:42 +00:00
@mock_sqs
def test_send_receive_message_without_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
conn = boto3.client("sqs", region_name="us-east-1")
2017-02-12 00:41:04 +00:00
conn.create_queue(QueueName="test-queue")
queue = sqs.Queue("test-queue")
2014-06-23 18:53:46 +00:00
2019-10-31 15:44:26 +00:00
body_one = "this is a test message"
body_two = "this is another test message"
2013-02-24 16:06:42 +00:00
queue.send_message(MessageBody=body_one)
queue.send_message(MessageBody=body_two)
2013-02-24 16:06:42 +00:00
2019-10-31 15:44:26 +00:00
messages = conn.receive_message(QueueUrl=queue.url, MaxNumberOfMessages=2)[
"Messages"
]
2014-06-23 18:53:46 +00:00
message1 = messages[0]
message2 = messages[1]
2019-10-31 15:44:26 +00:00
message1["Body"].should.equal(body_one)
message2["Body"].should.equal(body_two)
2019-10-31 15:44:26 +00:00
message1.shouldnt.have.key("MD5OfMessageAttributes")
message2.shouldnt.have.key("MD5OfMessageAttributes")
2017-09-22 19:08:20 +00:00
@mock_sqs
def test_send_receive_message_with_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
conn = boto3.client("sqs", region_name="us-east-1")
conn.create_queue(QueueName="test-queue")
queue = sqs.Queue("test-queue")
2019-10-31 15:44:26 +00:00
body_one = "this is a test message"
body_two = "this is another test message"
queue.send_message(
MessageBody=body_one,
MessageAttributes={
2019-10-31 15:44:26 +00:00
"timestamp": {"StringValue": "1493147359900", "DataType": "Number"}
},
)
queue.send_message(
MessageBody=body_two,
MessageAttributes={
2019-10-31 15:44:26 +00:00
"timestamp": {"StringValue": "1493147359901", "DataType": "Number"}
},
)
2019-10-31 15:44:26 +00:00
messages = conn.receive_message(QueueUrl=queue.url, MaxNumberOfMessages=2)[
"Messages"
]
message1 = messages[0]
message2 = messages[1]
2019-10-31 15:44:26 +00:00
message1.get("Body").should.equal(body_one)
message2.get("Body").should.equal(body_two)
2019-10-31 15:44:26 +00:00
message1.get("MD5OfMessageAttributes").should.equal(
"235c5c510d26fb653d073faed50ae77c"
)
message2.get("MD5OfMessageAttributes").should.equal(
"994258b45346a2cc3f9cbb611aa7af30"
)
@mock_sqs
def test_send_receive_message_timestamps():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
conn = boto3.client("sqs", region_name="us-east-1")
conn.create_queue(QueueName="test-queue")
queue = sqs.Queue("test-queue")
2019-01-18 16:32:45 +00:00
response = queue.send_message(MessageBody="derp")
2019-10-31 15:44:26 +00:00
assert response["ResponseMetadata"]["RequestId"]
2019-01-18 16:32:45 +00:00
2019-10-31 15:44:26 +00:00
messages = conn.receive_message(QueueUrl=queue.url, MaxNumberOfMessages=1)[
"Messages"
]
message = messages[0]
2019-10-31 15:44:26 +00:00
sent_timestamp = message.get("Attributes").get("SentTimestamp")
approximate_first_receive_timestamp = message.get("Attributes").get(
"ApproximateFirstReceiveTimestamp"
)
int.when.called_with(sent_timestamp).shouldnt.throw(ValueError)
int.when.called_with(approximate_first_receive_timestamp).shouldnt.throw(ValueError)
@mock_sqs
def test_max_number_of_messages_invalid_param():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="test-queue")
with assert_raises(ClientError):
queue.receive_messages(MaxNumberOfMessages=11)
with assert_raises(ClientError):
queue.receive_messages(MaxNumberOfMessages=0)
# no error but also no messages returned
queue.receive_messages(MaxNumberOfMessages=1, WaitTimeSeconds=0)
@mock_sqs
def test_wait_time_seconds_invalid_param():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="test-queue")
with assert_raises(ClientError):
queue.receive_messages(WaitTimeSeconds=-1)
with assert_raises(ClientError):
queue.receive_messages(WaitTimeSeconds=21)
# no error but also no messages returned
queue.receive_messages(WaitTimeSeconds=0)
@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:
"""
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(QueueName="blah")
messages = queue.receive_messages(WaitTimeSeconds=0)
messages.should.equal([])
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2014-10-22 20:03:42 +00:00
def test_send_message_with_xml_characters():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2014-10-22 20:03:42 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "< & >"
2014-10-22 20:03:42 +00:00
queue.write(queue.new_message(body_one))
messages = conn.receive_message(queue, number_messages=1)
messages[0].get_body().should.equal(body_one)
@requires_boto_gte("2.28")
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_send_message_with_attributes():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
queue.set_message_class(RawMessage)
2014-11-16 22:57:46 +00:00
2019-10-31 15:44:26 +00:00
body = "this is a test message"
message = queue.new_message(body)
2019-10-31 15:44:26 +00:00
BASE64_BINARY = base64.b64encode(b"binary value").decode("utf-8")
message_attributes = {
2019-10-31 15:44:26 +00:00
"test.attribute_name": {
"data_type": "String",
"string_value": "attribute value",
},
"test.binary_attribute": {"data_type": "Binary", "binary_value": BASE64_BINARY},
"test.number_attribute": {
"data_type": "Number",
"string_value": "string value",
},
}
message.message_attributes = message_attributes
queue.write(message)
messages = conn.receive_message(queue)
messages[0].get_body().should.equal(body)
for name, value in message_attributes.items():
dict(messages[0].message_attributes[name]).should.equal(value)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_send_message_with_delay():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "this is a test message"
body_two = "this is another test message"
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body_one), delay_seconds=3)
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body_two))
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=2)
assert len(messages) == 1
message = messages[0]
2014-06-23 18:53:46 +00:00
assert message.get_body().should.equal(body_two)
queue.count().should.equal(0)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_send_large_message_fails():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "test message" * 200000
huge_message = queue.new_message(body_one)
queue.write.when.called_with(huge_message).should.throw(SQSError)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2014-06-22 18:34:32 +00:00
def test_message_becomes_inflight_when_received():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=2)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "this is a test message"
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body_one))
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
queue.count().should.equal(0)
assert len(messages) == 1
# Wait
time.sleep(3)
queue.count().should.equal(1)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_receive_message_with_explicit_visibility_timeout():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "this is another test message"
queue.write(queue.new_message(body_one))
queue.count().should.equal(1)
2019-10-31 15:44:26 +00:00
messages = conn.receive_message(queue, number_messages=1, visibility_timeout=0)
assert len(messages) == 1
# Message should remain visible
queue.count().should.equal(1)
2017-02-24 02:37:43 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_change_message_visibility():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=2)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "this is another test message"
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body_one))
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
queue.count().should.equal(0)
messages[0].change_visibility(2)
# Wait
time.sleep(1)
# Message is not visible
queue.count().should.equal(0)
time.sleep(2)
# Message now becomes visible
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
messages[0].delete()
queue.count().should.equal(0)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_message_attributes():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=2)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body_one = "this is another test message"
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body_one))
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
queue.count().should.equal(0)
assert len(messages) == 1
message_attributes = messages[0].attributes
2019-10-31 15:44:26 +00:00
assert message_attributes.get("ApproximateFirstReceiveTimestamp")
assert int(message_attributes.get("ApproximateReceiveCount")) == 1
assert message_attributes.get("SentTimestamp")
assert message_attributes.get("SenderId")
2013-02-24 16:06:42 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2013-03-23 13:44:53 +00:00
def test_read_message_from_queue():
conn = boto.connect_sqs()
2019-10-31 15:44:26 +00:00
queue = conn.create_queue("testqueue")
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
body = "foo bar baz"
2014-06-23 18:53:46 +00:00
queue.write(queue.new_message(body))
2013-03-23 13:44:53 +00:00
message = queue.read(1)
2014-06-23 18:53:46 +00:00
message.get_body().should.equal(body)
2013-03-23 13:44:53 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2013-02-24 16:06:42 +00:00
def test_queue_length():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2013-02-24 16:06:42 +00:00
2019-10-31 15:44:26 +00:00
queue.write(queue.new_message("this is a test message"))
queue.write(queue.new_message("this is another test message"))
2013-02-24 16:06:42 +00:00
queue.count().should.equal(2)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2013-02-24 16:06:42 +00:00
def test_delete_message():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2013-02-24 16:06:42 +00:00
2019-10-31 15:44:26 +00:00
queue.write(queue.new_message("this is a test message"))
queue.write(queue.new_message("this is another test message"))
queue.count().should.equal(2)
2013-02-24 16:06:42 +00:00
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
2013-02-24 16:06:42 +00:00
messages[0].delete()
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
messages[0].delete()
queue.count().should.equal(0)
2013-02-24 16:06:42 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2013-02-24 16:06:42 +00:00
def test_send_batch_operation():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2013-02-24 16:06:42 +00:00
2013-03-23 13:44:53 +00:00
# See https://github.com/boto/boto/issues/831
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
queue.write_batch(
[
("my_first_message", "test message 1", 0),
("my_second_message", "test message 2", 0),
("my_third_message", "test message 3", 0),
]
)
2013-02-24 16:06:42 +00:00
messages = queue.get_messages(3)
messages[0].get_body().should.equal("test message 1")
# Test that pulling more messages doesn't break anything
messages = queue.get_messages(2)
@requires_boto_gte("2.28")
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_send_batch_operation_with_message_attributes():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
queue.set_message_class(RawMessage)
2019-10-31 15:44:26 +00:00
message_tuple = (
"my_first_message",
"test message 1",
0,
{"name1": {"data_type": "String", "string_value": "foo"}},
)
queue.write_batch([message_tuple])
messages = queue.get_messages()
messages[0].get_body().should.equal("test message 1")
for name, value in message_tuple[3].items():
dict(messages[0].message_attributes[name]).should.equal(value)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2013-02-24 16:06:42 +00:00
def test_delete_batch_operation():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
queue = conn.create_queue("test-queue", visibility_timeout=3)
2013-02-24 16:06:42 +00:00
2019-10-31 15:44:26 +00:00
conn.send_message_batch(
queue,
[
("my_first_message", "test message 1", 0),
("my_second_message", "test message 2", 0),
("my_third_message", "test message 3", 0),
],
)
2013-02-24 16:06:42 +00:00
messages = queue.get_messages(2)
queue.delete_message_batch(messages)
queue.count().should.equal(1)
2013-02-28 02:56:54 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_queue_attributes():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
2019-10-31 15:44:26 +00:00
queue_name = "test-queue"
visibility_timeout = 3
2019-10-31 15:44:26 +00:00
queue = conn.create_queue(queue_name, visibility_timeout=visibility_timeout)
attributes = queue.get_attributes()
2019-10-31 15:44:26 +00:00
attributes["QueueArn"].should.look_like(
"arn:aws:sqs:us-east-1:{AccountId}:{name}".format(AccountId=ACCOUNT_ID,name=queue_name)
2019-10-31 15:44:26 +00:00
)
2019-10-31 15:44:26 +00:00
attributes["VisibilityTimeout"].should.look_like(str(visibility_timeout))
attribute_names = queue.get_attributes().keys()
2019-10-31 15:44:26 +00:00
attribute_names.should.contain("ApproximateNumberOfMessagesNotVisible")
attribute_names.should.contain("MessageRetentionPeriod")
attribute_names.should.contain("ApproximateNumberOfMessagesDelayed")
attribute_names.should.contain("MaximumMessageSize")
attribute_names.should.contain("CreatedTimestamp")
attribute_names.should.contain("ApproximateNumberOfMessages")
attribute_names.should.contain("ReceiveMessageWaitTimeSeconds")
attribute_names.should.contain("DelaySeconds")
attribute_names.should.contain("VisibilityTimeout")
attribute_names.should.contain("LastModifiedTimestamp")
attribute_names.should.contain("QueueArn")
2014-06-20 21:29:40 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2014-06-20 21:29:40 +00:00
def test_change_message_visibility_on_invalid_receipt():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
2014-06-20 21:29:40 +00:00
queue = conn.create_queue("test-queue", visibility_timeout=1)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2014-06-20 21:29:40 +00:00
2019-10-31 15:44:26 +00:00
queue.write(queue.new_message("this is another test message"))
2014-06-20 21:29:40 +00:00
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
original_message = messages[0]
queue.count().should.equal(0)
time.sleep(2)
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
2019-10-31 15:44:26 +00:00
original_message.change_visibility.when.called_with(100).should.throw(SQSError)
2014-06-20 21:29:40 +00:00
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
2014-06-20 21:29:40 +00:00
def test_change_message_visibility_on_visible_message():
2019-10-31 15:44:26 +00:00
conn = boto.connect_sqs("the_key", "the_secret")
2014-06-20 21:29:40 +00:00
queue = conn.create_queue("test-queue", visibility_timeout=1)
2014-06-23 18:53:46 +00:00
queue.set_message_class(RawMessage)
2014-06-20 21:29:40 +00:00
2019-10-31 15:44:26 +00:00
queue.write(queue.new_message("this is another test message"))
2014-06-20 21:29:40 +00:00
queue.count().should.equal(1)
messages = conn.receive_message(queue, number_messages=1)
assert len(messages) == 1
original_message = messages[0]
queue.count().should.equal(0)
time.sleep(2)
queue.count().should.equal(1)
2019-10-31 15:44:26 +00:00
original_message.change_visibility.when.called_with(100).should.throw(SQSError)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_purge_action():
conn = boto.sqs.connect_to_region("us-east-1")
2019-10-31 15:44:26 +00:00
queue = conn.create_queue("new-queue")
queue.write(queue.new_message("this is another test message"))
queue.count().should.equal(1)
queue.purge()
queue.count().should.equal(0)
2017-02-16 03:35:45 +00:00
@mock_sqs_deprecated
def test_delete_message_after_visibility_timeout():
VISIBILITY_TIMEOUT = 1
conn = boto.sqs.connect_to_region("us-east-1")
2019-10-31 15:44:26 +00:00
new_queue = conn.create_queue("new-queue", visibility_timeout=VISIBILITY_TIMEOUT)
m1 = Message()
2019-10-31 15:44:26 +00:00
m1.set_body("Message 1!")
new_queue.write(m1)
assert new_queue.count() == 1
m1_retrieved = new_queue.read()
time.sleep(VISIBILITY_TIMEOUT + 1)
m1_retrieved.delete()
assert new_queue.count() == 0
2017-10-29 18:59:40 +00:00
@mock_sqs
def test_delete_message_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
response = client.create_queue(QueueName="test-queue")
queue_url = response["QueueUrl"]
client.send_message(QueueUrl=queue_url, MessageBody="body")
response = client.receive_message(QueueUrl=queue_url)
receipt_handle = response["Messages"][0]["ReceiptHandle"]
client.delete_message.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-not-existing", ReceiptHandle=receipt_handle
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
)
client.delete_message.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, ReceiptHandle="not-existing"
).should.throw(ClientError, "The input receipt handle is invalid.")
2019-10-26 20:08:45 +00:00
@mock_sqs
def test_send_message_batch():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
response = client.create_queue(QueueName="test-queue")
queue_url = response["QueueUrl"]
2019-10-26 20:08:45 +00:00
response = client.send_message_batch(
QueueUrl=queue_url,
Entries=[
{
2019-10-31 15:44:26 +00:00
"Id": "id_1",
"MessageBody": "body_1",
"DelaySeconds": 0,
"MessageAttributes": {
"attribute_name_1": {
"StringValue": "attribute_value_1",
"DataType": "String",
2019-10-26 20:08:45 +00:00
}
2019-10-31 15:44:26 +00:00
},
2019-10-26 20:08:45 +00:00
},
{
2019-10-31 15:44:26 +00:00
"Id": "id_2",
"MessageBody": "body_2",
"DelaySeconds": 0,
"MessageAttributes": {
"attribute_name_2": {"StringValue": "123", "DataType": "Number"}
},
},
],
2019-10-26 20:08:45 +00:00
)
2019-10-31 15:44:26 +00:00
sorted([entry["Id"] for entry in response["Successful"]]).should.equal(
["id_1", "id_2"]
2019-10-26 20:08:45 +00:00
)
2019-10-31 15:44:26 +00:00
response = client.receive_message(QueueUrl=queue_url, MaxNumberOfMessages=10)
response["Messages"][0]["Body"].should.equal("body_1")
response["Messages"][0]["MessageAttributes"].should.equal(
{"attribute_name_1": {"StringValue": "attribute_value_1", "DataType": "String"}}
)
response["Messages"][1]["Body"].should.equal("body_2")
response["Messages"][1]["MessageAttributes"].should.equal(
{"attribute_name_2": {"StringValue": "123", "DataType": "Number"}}
)
2019-10-26 20:08:45 +00:00
@mock_sqs
def test_send_message_batch_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2019-10-31 15:44:26 +00:00
response = client.create_queue(QueueName="test-queue")
queue_url = response["QueueUrl"]
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-not-existing",
Entries=[{"Id": "id_1", "MessageBody": "body_1"}],
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
)
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=[]
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"There should be at least one SendMessageBatchRequestEntry in the request.",
)
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=[{"Id": "", "MessageBody": "body_1"}]
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"A batch entry id can only contain alphanumeric characters, "
"hyphens and underscores. It can be at most 80 letters long.",
)
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=[{"Id": ".!@#$%^&*()+=", "MessageBody": "body_1"}]
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"A batch entry id can only contain alphanumeric characters, "
"hyphens and underscores. It can be at most 80 letters long.",
)
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=[{"Id": "i" * 81, "MessageBody": "body_1"}]
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"A batch entry id can only contain alphanumeric characters, "
"hyphens and underscores. It can be at most 80 letters long.",
)
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=[{"Id": "id_1", "MessageBody": "b" * 262145}]
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"Batch requests cannot be longer than 262144 bytes. "
"You have sent 262145 bytes.",
)
# only the first duplicated Id is reported
client.send_message_batch.when.called_with(
QueueUrl=queue_url,
Entries=[
2019-10-31 15:44:26 +00:00
{"Id": "id_1", "MessageBody": "body_1"},
{"Id": "id_2", "MessageBody": "body_2"},
{"Id": "id_2", "MessageBody": "body_2"},
{"Id": "id_1", "MessageBody": "body_1"},
],
).should.throw(ClientError, "Id id_2 repeated.")
entries = [
{"Id": "id_{}".format(i), "MessageBody": "body_{}".format(i)} for i in range(11)
]
client.send_message_batch.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Entries=entries
).should.throw(
ClientError,
2019-10-31 15:44:26 +00:00
"Maximum number of entries per request are 10. " "You have sent 11.",
)
2017-10-29 18:59:40 +00:00
@mock_sqs
2017-10-29 19:11:52 +00:00
def test_batch_change_message_visibility():
2019-10-31 15:44:26 +00:00
if os.environ.get("TEST_SERVER_MODE", "false").lower() == "true":
raise SkipTest("Cant manipulate time in server mode")
2017-10-29 19:11:52 +00:00
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 12:00:00"):
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2017-10-29 18:59:40 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue.fifo", Attributes={"FifoQueue": "true"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = resp["QueueUrl"]
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
sqs.send_message(QueueUrl=queue_url, MessageBody="msg1")
sqs.send_message(QueueUrl=queue_url, MessageBody="msg2")
sqs.send_message(QueueUrl=queue_url, MessageBody="msg3")
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 12:01:00"):
receive_resp = sqs.receive_message(QueueUrl=queue_url, MaxNumberOfMessages=2)
2019-10-31 15:44:26 +00:00
len(receive_resp["Messages"]).should.equal(2)
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
handles = [item["ReceiptHandle"] for item in receive_resp["Messages"]]
entries = [
{
"Id": str(uuid.uuid4()),
"ReceiptHandle": handle,
"VisibilityTimeout": 43200,
}
for handle in handles
]
2017-10-29 18:59:40 +00:00
resp = sqs.change_message_visibility_batch(QueueUrl=queue_url, Entries=entries)
2019-10-31 15:44:26 +00:00
len(resp["Successful"]).should.equal(2)
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 14:00:00"):
resp = sqs.receive_message(QueueUrl=queue_url, MaxNumberOfMessages=3)
2019-10-31 15:44:26 +00:00
len(resp["Messages"]).should.equal(1)
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 16:00:00"):
resp = sqs.receive_message(QueueUrl=queue_url, MaxNumberOfMessages=3)
2019-10-31 15:44:26 +00:00
len(resp["Messages"]).should.equal(1)
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-02 12:00:00"):
resp = sqs.receive_message(QueueUrl=queue_url, MaxNumberOfMessages=3)
2019-10-31 15:44:26 +00:00
len(resp["Messages"]).should.equal(3)
2017-10-29 18:59:40 +00:00
@mock_sqs
def test_permissions():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2017-10-29 18:59:40 +00:00
resp = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue.fifo", Attributes={"FifoQueue": "true"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = resp["QueueUrl"]
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
client.add_permission(
QueueUrl=queue_url,
Label="account1",
AWSAccountIds=["111111111111"],
Actions=["*"],
)
client.add_permission(
QueueUrl=queue_url,
Label="account2",
AWSAccountIds=["222211111111"],
Actions=["SendMessage"],
)
2017-10-29 18:59:40 +00:00
with assert_raises(ClientError):
2019-10-31 15:44:26 +00:00
client.add_permission(
QueueUrl=queue_url,
Label="account2",
AWSAccountIds=["222211111111"],
Actions=["SomeRubbish"],
)
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
client.remove_permission(QueueUrl=queue_url, Label="account2")
2017-10-29 18:59:40 +00:00
with assert_raises(ClientError):
2019-10-31 15:44:26 +00:00
client.remove_permission(QueueUrl=queue_url, Label="non_existant")
2017-10-29 18:59:40 +00:00
@mock_sqs
def test_tags():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2017-10-29 18:59:40 +00:00
resp = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue.fifo", Attributes={"FifoQueue": "true"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = resp["QueueUrl"]
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
client.tag_queue(QueueUrl=queue_url, Tags={"test1": "value1", "test2": "value2"})
2017-10-29 18:59:40 +00:00
resp = client.list_queue_tags(QueueUrl=queue_url)
2019-10-31 15:44:26 +00:00
resp["Tags"].should.contain("test1")
resp["Tags"].should.contain("test2")
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
client.untag_queue(QueueUrl=queue_url, TagKeys=["test2"])
2017-10-29 18:59:40 +00:00
resp = client.list_queue_tags(QueueUrl=queue_url)
2019-10-31 15:44:26 +00:00
resp["Tags"].should.contain("test1")
resp["Tags"].should_not.contain("test2")
2017-10-29 18:59:40 +00:00
2019-10-13 12:51:31 +00:00
# removing a non existing tag should not raise any error
2019-10-31 15:44:26 +00:00
client.untag_queue(QueueUrl=queue_url, TagKeys=["not-existing-tag"])
client.list_queue_tags(QueueUrl=queue_url)["Tags"].should.equal({"test1": "value1"})
2019-10-13 12:51:31 +00:00
@mock_sqs
def test_list_queue_tags_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
response = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue-with-tags", tags={"tag_key_1": "tag_value_X"}
)
2019-10-31 15:44:26 +00:00
queue_url = response["QueueUrl"]
client.list_queue_tags.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-not-existing"
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
)
2019-10-17 20:36:37 +00:00
@mock_sqs
def test_tag_queue_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2019-10-17 20:36:37 +00:00
response = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue-with-tags", tags={"tag_key_1": "tag_value_X"}
2019-10-17 20:36:37 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = response["QueueUrl"]
2019-10-17 20:36:37 +00:00
client.tag_queue.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-not-existing", Tags={"tag_key_1": "tag_value_1"}
2019-10-17 20:36:37 +00:00
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
2019-10-17 20:36:37 +00:00
)
2019-10-31 15:44:26 +00:00
client.tag_queue.when.called_with(QueueUrl=queue_url, Tags={}).should.throw(
ClientError, "The request must contain the parameter Tags."
2019-10-17 20:36:37 +00:00
)
2019-10-31 15:44:26 +00:00
too_many_tags = {
"tag_key_{}".format(i): "tag_value_{}".format(i) for i in range(51)
}
2019-10-17 20:36:37 +00:00
client.tag_queue.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url, Tags=too_many_tags
).should.throw(ClientError, "Too many tags added for queue test-queue-with-tags.")
2019-10-17 20:36:37 +00:00
# when the request fails, the tags should not be updated
2019-10-31 15:44:26 +00:00
client.list_queue_tags(QueueUrl=queue_url)["Tags"].should.equal(
{"tag_key_1": "tag_value_X"}
2019-10-17 20:36:37 +00:00
)
2019-10-13 12:51:31 +00:00
@mock_sqs
def test_untag_queue_errors():
2019-10-31 15:44:26 +00:00
client = boto3.client("sqs", region_name="us-east-1")
2019-10-13 12:51:31 +00:00
response = client.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue-with-tags", tags={"tag_key_1": "tag_value_1"}
2019-10-13 12:51:31 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url = response["QueueUrl"]
2019-10-13 12:51:31 +00:00
client.untag_queue.when.called_with(
2019-10-31 15:44:26 +00:00
QueueUrl=queue_url + "-not-existing", TagKeys=["tag_key_1"]
2019-10-13 12:51:31 +00:00
).should.throw(
2019-10-31 15:44:26 +00:00
ClientError, "The specified queue does not exist for this wsdl version."
2019-10-13 12:51:31 +00:00
)
2019-10-31 15:44:26 +00:00
client.untag_queue.when.called_with(QueueUrl=queue_url, TagKeys=[]).should.throw(
ClientError, "Tag keys must be between 1 and 128 characters in length."
2019-10-13 12:51:31 +00:00
)
2017-10-29 18:59:40 +00:00
@mock_sqs
def test_create_fifo_queue_with_dlq():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2017-10-29 18:59:40 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue.fifo", Attributes={"FifoQueue": "true"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url1 = resp["QueueUrl"]
queue_arn1 = sqs.get_queue_attributes(QueueUrl=queue_url1)["Attributes"]["QueueArn"]
2017-10-29 18:59:40 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue", Attributes={"FifoQueue": "false"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url2 = resp["QueueUrl"]
queue_arn2 = sqs.get_queue_attributes(QueueUrl=queue_url2)["Attributes"]["QueueArn"]
2017-10-29 18:59:40 +00:00
sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue.fifo",
2017-10-29 18:59:40 +00:00
Attributes={
2019-10-31 15:44:26 +00:00
"FifoQueue": "true",
"RedrivePolicy": json.dumps(
{"deadLetterTargetArn": queue_arn1, "maxReceiveCount": 2}
),
},
2017-10-29 18:59:40 +00:00
)
# Cant have fifo queue with non fifo DLQ
with assert_raises(ClientError):
sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue2.fifo",
2017-10-29 18:59:40 +00:00
Attributes={
2019-10-31 15:44:26 +00:00
"FifoQueue": "true",
"RedrivePolicy": json.dumps(
{"deadLetterTargetArn": queue_arn2, "maxReceiveCount": 2}
),
},
2017-10-29 18:59:40 +00:00
)
@mock_sqs
def test_queue_with_dlq():
2019-10-31 15:44:26 +00:00
if os.environ.get("TEST_SERVER_MODE", "false").lower() == "true":
raise SkipTest("Cant manipulate time in server mode")
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 12:00:00"):
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-dlr-queue.fifo", Attributes={"FifoQueue": "true"}
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url1 = resp["QueueUrl"]
queue_arn1 = sqs.get_queue_attributes(QueueUrl=queue_url1)["Attributes"][
"QueueArn"
]
2017-10-29 18:59:40 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue.fifo",
2017-10-29 18:59:40 +00:00
Attributes={
2019-10-31 15:44:26 +00:00
"FifoQueue": "true",
"RedrivePolicy": json.dumps(
{"deadLetterTargetArn": queue_arn1, "maxReceiveCount": 2}
),
},
2017-10-29 18:59:40 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url2 = resp["QueueUrl"]
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
sqs.send_message(QueueUrl=queue_url2, MessageBody="msg1")
sqs.send_message(QueueUrl=queue_url2, MessageBody="msg2")
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 13:00:00"):
2019-10-31 15:44:26 +00:00
resp = sqs.receive_message(
QueueUrl=queue_url2, VisibilityTimeout=30, WaitTimeSeconds=0
)
resp["Messages"][0]["Body"].should.equal("msg1")
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 13:01:00"):
2019-10-31 15:44:26 +00:00
resp = sqs.receive_message(
QueueUrl=queue_url2, VisibilityTimeout=30, WaitTimeSeconds=0
)
resp["Messages"][0]["Body"].should.equal("msg1")
2017-10-29 18:59:40 +00:00
with freeze_time("2015-01-01 13:02:00"):
2019-10-31 15:44:26 +00:00
resp = sqs.receive_message(
QueueUrl=queue_url2, VisibilityTimeout=30, WaitTimeSeconds=0
)
len(resp["Messages"]).should.equal(1)
2017-10-29 18:59:40 +00:00
2019-10-31 15:44:26 +00:00
resp = sqs.receive_message(
QueueUrl=queue_url1, VisibilityTimeout=30, WaitTimeSeconds=0
)
resp["Messages"][0]["Body"].should.equal("msg1")
2017-10-29 18:59:40 +00:00
# Might as well test list source queues
resp = sqs.list_dead_letter_source_queues(QueueUrl=queue_url1)
2019-10-31 15:44:26 +00:00
resp["queueUrls"][0].should.equal(queue_url2)
2018-01-18 23:58:20 +00:00
2018-01-18 23:58:20 +00:00
@mock_sqs
def test_redrive_policy_available():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
2018-01-18 23:58:20 +00:00
2019-10-31 15:44:26 +00:00
resp = sqs.create_queue(QueueName="test-deadletter")
queue_url1 = resp["QueueUrl"]
queue_arn1 = sqs.get_queue_attributes(QueueUrl=queue_url1)["Attributes"]["QueueArn"]
redrive_policy = {"deadLetterTargetArn": queue_arn1, "maxReceiveCount": 1}
2018-01-18 23:58:20 +00:00
resp = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue", Attributes={"RedrivePolicy": json.dumps(redrive_policy)}
2018-01-18 23:58:20 +00:00
)
2019-10-31 15:44:26 +00:00
queue_url2 = resp["QueueUrl"]
attributes = sqs.get_queue_attributes(QueueUrl=queue_url2)["Attributes"]
assert "RedrivePolicy" in attributes
assert json.loads(attributes["RedrivePolicy"]) == redrive_policy
# Cant have redrive policy without maxReceiveCount
with assert_raises(ClientError):
sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue2",
Attributes={
2019-10-31 15:44:26 +00:00
"FifoQueue": "true",
"RedrivePolicy": json.dumps({"deadLetterTargetArn": queue_arn1}),
},
)
@mock_sqs
def test_redrive_policy_non_existent_queue():
2019-10-31 15:44:26 +00:00
sqs = boto3.client("sqs", region_name="us-east-1")
redrive_policy = {
"deadLetterTargetArn": "arn:aws:sqs:us-east-1:{}:no-queue".format(ACCOUNT_ID),
2019-10-31 15:44:26 +00:00
"maxReceiveCount": 1,
}
with assert_raises(ClientError):
sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue",
Attributes={"RedrivePolicy": json.dumps(redrive_policy)},
)
@mock_sqs
def test_redrive_policy_set_attributes():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2019-10-31 15:44:26 +00:00
queue = sqs.create_queue(QueueName="test-queue")
deadletter_queue = sqs.create_queue(QueueName="test-deadletter")
redrive_policy = {
2019-10-31 15:44:26 +00:00
"deadLetterTargetArn": deadletter_queue.attributes["QueueArn"],
"maxReceiveCount": 1,
}
2019-10-31 15:44:26 +00:00
queue.set_attributes(Attributes={"RedrivePolicy": json.dumps(redrive_policy)})
2019-10-31 15:44:26 +00:00
copy = sqs.get_queue_by_name(QueueName="test-queue")
assert "RedrivePolicy" in copy.attributes
copy_policy = json.loads(copy.attributes["RedrivePolicy"])
assert copy_policy == redrive_policy
@mock_sqs
def test_redrive_policy_set_attributes_with_string_value():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
2019-10-31 15:44:26 +00:00
queue = sqs.create_queue(QueueName="test-queue")
deadletter_queue = sqs.create_queue(QueueName="test-deadletter")
2019-10-31 15:44:26 +00:00
queue.set_attributes(
Attributes={
"RedrivePolicy": json.dumps(
{
"deadLetterTargetArn": deadletter_queue.attributes["QueueArn"],
"maxReceiveCount": "1",
}
)
}
)
2019-10-31 15:44:26 +00:00
copy = sqs.get_queue_by_name(QueueName="test-queue")
assert "RedrivePolicy" in copy.attributes
copy_policy = json.loads(copy.attributes["RedrivePolicy"])
assert copy_policy == {
2019-10-31 15:44:26 +00:00
"deadLetterTargetArn": deadletter_queue.attributes["QueueArn"],
"maxReceiveCount": 1,
}
@mock_sqs
def test_receive_messages_with_message_group_id():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(
QueueName="test-queue.fifo", Attributes={"FifoQueue": "true"}
)
2019-10-31 15:44:26 +00:00
queue.set_attributes(Attributes={"VisibilityTimeout": "3600"})
queue.send_message(MessageBody="message-1", MessageGroupId="group")
queue.send_message(MessageBody="message-2", MessageGroupId="group")
messages = queue.receive_messages()
messages.should.have.length_of(1)
message = messages[0]
# received message is not deleted!
messages = queue.receive_messages(WaitTimeSeconds=0)
messages.should.have.length_of(0)
# message is now processed, next one should be available
message.delete()
messages = queue.receive_messages()
messages.should.have.length_of(1)
@mock_sqs
def test_receive_messages_with_message_group_id_on_requeue():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(
QueueName="test-queue.fifo", Attributes={"FifoQueue": "true"}
)
2019-10-31 15:44:26 +00:00
queue.set_attributes(Attributes={"VisibilityTimeout": "3600"})
queue.send_message(MessageBody="message-1", MessageGroupId="group")
queue.send_message(MessageBody="message-2", MessageGroupId="group")
messages = queue.receive_messages()
messages.should.have.length_of(1)
message = messages[0]
# received message is not deleted!
messages = queue.receive_messages(WaitTimeSeconds=0)
messages.should.have.length_of(0)
# message is now available again, next one should be available
message.change_visibility(VisibilityTimeout=0)
messages = queue.receive_messages()
messages.should.have.length_of(1)
messages[0].message_id.should.equal(message.message_id)
@mock_sqs
def test_receive_messages_with_message_group_id_on_visibility_timeout():
2019-10-31 15:44:26 +00:00
if os.environ.get("TEST_SERVER_MODE", "false").lower() == "true":
raise SkipTest("Cant manipulate time in server mode")
with freeze_time("2015-01-01 12:00:00"):
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(
QueueName="test-queue.fifo", Attributes={"FifoQueue": "true"}
)
2019-10-31 15:44:26 +00:00
queue.set_attributes(Attributes={"VisibilityTimeout": "3600"})
queue.send_message(MessageBody="message-1", MessageGroupId="group")
queue.send_message(MessageBody="message-2", MessageGroupId="group")
messages = queue.receive_messages()
messages.should.have.length_of(1)
message = messages[0]
# received message is not deleted!
messages = queue.receive_messages(WaitTimeSeconds=0)
messages.should.have.length_of(0)
message.change_visibility(VisibilityTimeout=10)
with freeze_time("2015-01-01 12:00:05"):
# no timeout yet
messages = queue.receive_messages(WaitTimeSeconds=0)
messages.should.have.length_of(0)
with freeze_time("2015-01-01 12:00:15"):
# message is now available again, next one should be available
messages = queue.receive_messages()
messages.should.have.length_of(1)
messages[0].message_id.should.equal(message.message_id)
2019-10-31 15:44:26 +00:00
@mock_sqs
def test_receive_message_for_queue_with_receive_message_wait_time_seconds_set():
2019-10-31 15:44:26 +00:00
sqs = boto3.resource("sqs", region_name="us-east-1")
queue = sqs.create_queue(
2019-10-31 15:44:26 +00:00
QueueName="test-queue", Attributes={"ReceiveMessageWaitTimeSeconds": "2"}
)
queue.receive_messages()