Merge branch 'master' of github.com:spulec/moto into feat-s3-if-modified-since
This commit is contained in:
commit
9b2c19c909
@ -7,7 +7,7 @@ class IAMNotFoundException(RESTError):
|
|||||||
|
|
||||||
def __init__(self, message):
|
def __init__(self, message):
|
||||||
super(IAMNotFoundException, self).__init__(
|
super(IAMNotFoundException, self).__init__(
|
||||||
"Not Found", message)
|
"NoSuchEntity", message)
|
||||||
|
|
||||||
|
|
||||||
class IAMConflictException(RESTError):
|
class IAMConflictException(RESTError):
|
||||||
|
@ -569,6 +569,13 @@ class IAMBackend(BaseBackend):
|
|||||||
return role
|
return role
|
||||||
raise IAMNotFoundException("Role {0} not found".format(role_name))
|
raise IAMNotFoundException("Role {0} not found".format(role_name))
|
||||||
|
|
||||||
|
def delete_role(self, role_name):
|
||||||
|
for role in self.get_roles():
|
||||||
|
if role.name == role_name:
|
||||||
|
del self.roles[role.id]
|
||||||
|
return
|
||||||
|
raise IAMNotFoundException("Role {0} not found".format(role_name))
|
||||||
|
|
||||||
def get_roles(self):
|
def get_roles(self):
|
||||||
return self.roles.values()
|
return self.roles.values()
|
||||||
|
|
||||||
|
@ -62,6 +62,12 @@ class IamResponse(BaseResponse):
|
|||||||
template = self.response_template(GET_ROLE_TEMPLATE)
|
template = self.response_template(GET_ROLE_TEMPLATE)
|
||||||
return template.render(role=role)
|
return template.render(role=role)
|
||||||
|
|
||||||
|
def delete_role(self):
|
||||||
|
role_name = self._get_param('RoleName')
|
||||||
|
iam_backend.delete_role(role_name)
|
||||||
|
template = self.response_template(GENERIC_EMPTY_TEMPLATE)
|
||||||
|
return template.render(name="DeleteRoleResponse")
|
||||||
|
|
||||||
def list_role_policies(self):
|
def list_role_policies(self):
|
||||||
role_name = self._get_param('RoleName')
|
role_name = self._get_param('RoleName')
|
||||||
role_policies_names = iam_backend.list_role_policies(role_name)
|
role_policies_names = iam_backend.list_role_policies(role_name)
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
import base64
|
||||||
import hashlib
|
import hashlib
|
||||||
import re
|
import re
|
||||||
|
import six
|
||||||
|
import struct
|
||||||
from xml.sax.saxutils import escape
|
from xml.sax.saxutils import escape
|
||||||
|
|
||||||
import boto.sqs
|
import boto.sqs
|
||||||
@ -17,6 +20,8 @@ from .exceptions import (
|
|||||||
DEFAULT_ACCOUNT_ID = 123456789012
|
DEFAULT_ACCOUNT_ID = 123456789012
|
||||||
DEFAULT_SENDER_ID = "AIDAIT2UOQQY3AUEKVGXU"
|
DEFAULT_SENDER_ID = "AIDAIT2UOQQY3AUEKVGXU"
|
||||||
|
|
||||||
|
TRANSPORT_TYPE_ENCODINGS = {'String': b'\x01', 'Binary': b'\x02', 'Number': b'\x01'}
|
||||||
|
|
||||||
|
|
||||||
class Message(BaseModel):
|
class Message(BaseModel):
|
||||||
|
|
||||||
@ -33,10 +38,58 @@ class Message(BaseModel):
|
|||||||
self.delayed_until = 0
|
self.delayed_until = 0
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def md5(self):
|
def body_md5(self):
|
||||||
body_md5 = hashlib.md5()
|
md5 = hashlib.md5()
|
||||||
body_md5.update(self._body.encode('utf-8'))
|
md5.update(self._body.encode('utf-8'))
|
||||||
return body_md5.hexdigest()
|
return md5.hexdigest()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def attribute_md5(self):
|
||||||
|
"""
|
||||||
|
The MD5 of all attributes is calculated by first generating a
|
||||||
|
utf-8 string from each attribute and MD5-ing the concatenation
|
||||||
|
of them all. Each attribute is encoded with some bytes that
|
||||||
|
describe the length of each part and the type of attribute.
|
||||||
|
|
||||||
|
Not yet implemented:
|
||||||
|
List types (https://github.com/aws/aws-sdk-java/blob/7844c64cf248aed889811bf2e871ad6b276a89ca/aws-java-sdk-sqs/src/main/java/com/amazonaws/services/sqs/MessageMD5ChecksumHandler.java#L58k)
|
||||||
|
"""
|
||||||
|
def utf8(str):
|
||||||
|
if isinstance(str, six.string_types):
|
||||||
|
return str.encode('utf-8')
|
||||||
|
return str
|
||||||
|
md5 = hashlib.md5()
|
||||||
|
for name in sorted(self.message_attributes.keys()):
|
||||||
|
attr = self.message_attributes[name]
|
||||||
|
data_type = attr['data_type']
|
||||||
|
|
||||||
|
encoded = utf8('')
|
||||||
|
# Each part of each attribute is encoded right after it's
|
||||||
|
# own length is packed into a 4-byte integer
|
||||||
|
# 'timestamp' -> b'\x00\x00\x00\t'
|
||||||
|
encoded += struct.pack("!I", len(utf8(name))) + utf8(name)
|
||||||
|
# The datatype is additionally given a final byte
|
||||||
|
# representing which type it is
|
||||||
|
encoded += struct.pack("!I", len(data_type)) + utf8(data_type)
|
||||||
|
encoded += TRANSPORT_TYPE_ENCODINGS[data_type]
|
||||||
|
|
||||||
|
if data_type == 'String' or data_type == 'Number':
|
||||||
|
value = attr['string_value']
|
||||||
|
elif data_type == 'Binary':
|
||||||
|
print(data_type, attr['binary_value'], type(attr['binary_value']))
|
||||||
|
value = base64.b64decode(attr['binary_value'])
|
||||||
|
else:
|
||||||
|
print("Moto hasn't implemented MD5 hashing for {} attributes".format(data_type))
|
||||||
|
# The following should be enough of a clue to users that
|
||||||
|
# they are not, in fact, looking at a correct MD5 while
|
||||||
|
# also following the character and length constraints of
|
||||||
|
# MD5 so as not to break client softwre
|
||||||
|
return('deadbeefdeadbeefdeadbeefdeadbeef')
|
||||||
|
|
||||||
|
encoded += struct.pack("!I", len(utf8(value))) + utf8(value)
|
||||||
|
|
||||||
|
md5.update(encoded)
|
||||||
|
return md5.hexdigest()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def body(self):
|
def body(self):
|
||||||
|
@ -337,11 +337,9 @@ SET_QUEUE_ATTRIBUTE_RESPONSE = """<SetQueueAttributesResponse>
|
|||||||
SEND_MESSAGE_RESPONSE = """<SendMessageResponse>
|
SEND_MESSAGE_RESPONSE = """<SendMessageResponse>
|
||||||
<SendMessageResult>
|
<SendMessageResult>
|
||||||
<MD5OfMessageBody>
|
<MD5OfMessageBody>
|
||||||
{{- message.md5 -}}
|
{{- message.body_md5 -}}
|
||||||
</MD5OfMessageBody>
|
</MD5OfMessageBody>
|
||||||
{% if message.message_attributes.items()|count > 0 %}
|
<MD5OfMessageAttributes>{{- message.attribute_md5 -}}</MD5OfMessageAttributes>
|
||||||
<MD5OfMessageAttributes>324758f82d026ac6ec5b31a3b192d1e3</MD5OfMessageAttributes>
|
|
||||||
{% endif %}
|
|
||||||
<MessageId>
|
<MessageId>
|
||||||
{{- message.id -}}
|
{{- message.id -}}
|
||||||
</MessageId>
|
</MessageId>
|
||||||
@ -357,7 +355,7 @@ RECEIVE_MESSAGE_RESPONSE = """<ReceiveMessageResponse>
|
|||||||
<Message>
|
<Message>
|
||||||
<MessageId>{{ message.id }}</MessageId>
|
<MessageId>{{ message.id }}</MessageId>
|
||||||
<ReceiptHandle>{{ message.receipt_handle }}</ReceiptHandle>
|
<ReceiptHandle>{{ message.receipt_handle }}</ReceiptHandle>
|
||||||
<MD5OfBody>{{ message.md5 }}</MD5OfBody>
|
<MD5OfBody>{{ message.body_md5 }}</MD5OfBody>
|
||||||
<Body>{{ message.body }}</Body>
|
<Body>{{ message.body }}</Body>
|
||||||
<Attribute>
|
<Attribute>
|
||||||
<Name>SenderId</Name>
|
<Name>SenderId</Name>
|
||||||
@ -375,9 +373,7 @@ RECEIVE_MESSAGE_RESPONSE = """<ReceiveMessageResponse>
|
|||||||
<Name>ApproximateFirstReceiveTimestamp</Name>
|
<Name>ApproximateFirstReceiveTimestamp</Name>
|
||||||
<Value>{{ message.approximate_first_receive_timestamp }}</Value>
|
<Value>{{ message.approximate_first_receive_timestamp }}</Value>
|
||||||
</Attribute>
|
</Attribute>
|
||||||
{% if message.message_attributes.items()|count > 0 %}
|
<MD5OfMessageAttributes>{{- message.attribute_md5 -}}</MD5OfMessageAttributes>
|
||||||
<MD5OfMessageAttributes>324758f82d026ac6ec5b31a3b192d1e3</MD5OfMessageAttributes>
|
|
||||||
{% endif %}
|
|
||||||
{% for name, value in message.message_attributes.items() %}
|
{% for name, value in message.message_attributes.items() %}
|
||||||
<MessageAttribute>
|
<MessageAttribute>
|
||||||
<Name>{{ name }}</Name>
|
<Name>{{ name }}</Name>
|
||||||
@ -405,10 +401,8 @@ SEND_MESSAGE_BATCH_RESPONSE = """<SendMessageBatchResponse>
|
|||||||
<SendMessageBatchResultEntry>
|
<SendMessageBatchResultEntry>
|
||||||
<Id>{{ message.user_id }}</Id>
|
<Id>{{ message.user_id }}</Id>
|
||||||
<MessageId>{{ message.id }}</MessageId>
|
<MessageId>{{ message.id }}</MessageId>
|
||||||
<MD5OfMessageBody>{{ message.md5 }}</MD5OfMessageBody>
|
<MD5OfMessageBody>{{ message.body_md5 }}</MD5OfMessageBody>
|
||||||
{% if message.message_attributes.items()|count > 0 %}
|
<MD5OfMessageAttributes>{{- message.attribute_md5 -}}</MD5OfMessageAttributes>
|
||||||
<MD5OfMessageAttributes>324758f82d026ac6ec5b31a3b192d1e3</MD5OfMessageAttributes>
|
|
||||||
{% endif %}
|
|
||||||
</SendMessageBatchResultEntry>
|
</SendMessageBatchResultEntry>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</SendMessageBatchResult>
|
</SendMessageBatchResult>
|
||||||
|
@ -8,7 +8,7 @@ from boto.exception import BotoServerError
|
|||||||
from botocore.exceptions import ClientError
|
from botocore.exceptions import ClientError
|
||||||
from moto import mock_iam, mock_iam_deprecated
|
from moto import mock_iam, mock_iam_deprecated
|
||||||
from moto.iam.models import aws_managed_policies
|
from moto.iam.models import aws_managed_policies
|
||||||
from nose.tools import assert_raises, assert_equals, assert_not_equals
|
from nose.tools import assert_raises, assert_equals
|
||||||
from nose.tools import raises
|
from nose.tools import raises
|
||||||
|
|
||||||
from tests.helpers import requires_boto_gte
|
from tests.helpers import requires_boto_gte
|
||||||
@ -114,6 +114,23 @@ def test_remove_role_from_instance_profile():
|
|||||||
dict(profile.roles).should.be.empty
|
dict(profile.roles).should.be.empty
|
||||||
|
|
||||||
|
|
||||||
|
@mock_iam()
|
||||||
|
def test_delete_role():
|
||||||
|
conn = boto3.client('iam', region_name='us-east-1')
|
||||||
|
|
||||||
|
with assert_raises(ClientError):
|
||||||
|
conn.delete_role(RoleName="my-role")
|
||||||
|
|
||||||
|
conn.create_role(RoleName="my-role", AssumeRolePolicyDocument="some policy", Path="/my-path/")
|
||||||
|
role = conn.get_role(RoleName="my-role")
|
||||||
|
role.get('Role').get('Arn').should.equal('arn:aws:iam::123456789012:role/my-path/my-role')
|
||||||
|
|
||||||
|
conn.delete_role(RoleName="my-role")
|
||||||
|
|
||||||
|
with assert_raises(ClientError):
|
||||||
|
conn.get_role(RoleName="my-role")
|
||||||
|
|
||||||
|
|
||||||
@mock_iam_deprecated()
|
@mock_iam_deprecated()
|
||||||
def test_list_instance_profiles():
|
def test_list_instance_profiles():
|
||||||
conn = boto.connect_iam()
|
conn = boto.connect_iam()
|
||||||
|
@ -7,6 +7,7 @@ import botocore.exceptions
|
|||||||
from boto.exception import SQSError
|
from boto.exception import SQSError
|
||||||
from boto.sqs.message import RawMessage, Message
|
from boto.sqs.message import RawMessage, Message
|
||||||
|
|
||||||
|
import base64
|
||||||
import requests
|
import requests
|
||||||
import sure # noqa
|
import sure # noqa
|
||||||
import time
|
import time
|
||||||
@ -43,10 +44,44 @@ def test_get_inexistent_queue():
|
|||||||
def test_message_send():
|
def test_message_send():
|
||||||
sqs = boto3.resource('sqs', region_name='us-east-1')
|
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||||
queue = sqs.create_queue(QueueName="blah")
|
queue = sqs.create_queue(QueueName="blah")
|
||||||
msg = queue.send_message(MessageBody="derp")
|
msg = queue.send_message(
|
||||||
|
MessageBody="derp",
|
||||||
|
MessageAttributes={
|
||||||
|
'timestamp': {
|
||||||
|
'StringValue': '1493147359900',
|
||||||
|
'DataType': 'Number',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
msg.get('MD5OfMessageBody').should.equal(
|
msg.get('MD5OfMessageBody').should.equal(
|
||||||
'58fd9edd83341c29f1aebba81c31e257')
|
'58fd9edd83341c29f1aebba81c31e257')
|
||||||
|
msg.get('MD5OfMessageAttributes').should.equal(
|
||||||
|
'235c5c510d26fb653d073faed50ae77c')
|
||||||
|
msg.get('ResponseMetadata', {}).get('RequestId').should.equal(
|
||||||
|
'27daac76-34dd-47df-bd01-1f6e873584a0')
|
||||||
|
msg.get('MessageId').should_not.contain(' \n')
|
||||||
|
|
||||||
|
messages = queue.receive_messages()
|
||||||
|
messages.should.have.length_of(1)
|
||||||
|
|
||||||
|
|
||||||
|
@mock_sqs
|
||||||
|
def test_message_with_complex_attributes():
|
||||||
|
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||||
|
queue = sqs.create_queue(QueueName="blah")
|
||||||
|
msg = queue.send_message(
|
||||||
|
MessageBody="derp",
|
||||||
|
MessageAttributes={
|
||||||
|
'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'}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
msg.get('MD5OfMessageBody').should.equal(
|
||||||
|
'58fd9edd83341c29f1aebba81c31e257')
|
||||||
|
msg.get('MD5OfMessageAttributes').should.equal(
|
||||||
|
'8ae21a7957029ef04146b42aeaa18a22')
|
||||||
msg.get('ResponseMetadata', {}).get('RequestId').should.equal(
|
msg.get('ResponseMetadata', {}).get('RequestId').should.equal(
|
||||||
'27daac76-34dd-47df-bd01-1f6e873584a0')
|
'27daac76-34dd-47df-bd01-1f6e873584a0')
|
||||||
msg.get('MessageId').should_not.contain(' \n')
|
msg.get('MessageId').should_not.contain(' \n')
|
||||||
@ -126,7 +161,7 @@ def test_delete_queue():
|
|||||||
sqs = boto3.resource('sqs', region_name='us-east-1')
|
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||||
conn = boto3.client("sqs", region_name='us-east-1')
|
conn = boto3.client("sqs", region_name='us-east-1')
|
||||||
conn.create_queue(QueueName="test-queue",
|
conn.create_queue(QueueName="test-queue",
|
||||||
Attributes={"VisibilityTimeout": "60"})
|
Attributes={"VisibilityTimeout": "3"})
|
||||||
queue = sqs.Queue('test-queue')
|
queue = sqs.Queue('test-queue')
|
||||||
|
|
||||||
conn.list_queues()['QueueUrls'].should.have.length_of(1)
|
conn.list_queues()['QueueUrls'].should.have.length_of(1)
|
||||||
@ -143,10 +178,10 @@ def test_set_queue_attribute():
|
|||||||
sqs = boto3.resource('sqs', region_name='us-east-1')
|
sqs = boto3.resource('sqs', region_name='us-east-1')
|
||||||
conn = boto3.client("sqs", region_name='us-east-1')
|
conn = boto3.client("sqs", region_name='us-east-1')
|
||||||
conn.create_queue(QueueName="test-queue",
|
conn.create_queue(QueueName="test-queue",
|
||||||
Attributes={"VisibilityTimeout": '60'})
|
Attributes={"VisibilityTimeout": '3'})
|
||||||
|
|
||||||
queue = sqs.Queue("test-queue")
|
queue = sqs.Queue("test-queue")
|
||||||
queue.attributes['VisibilityTimeout'].should.equal('60')
|
queue.attributes['VisibilityTimeout'].should.equal('3')
|
||||||
|
|
||||||
queue.set_attributes(Attributes={"VisibilityTimeout": '45'})
|
queue.set_attributes(Attributes={"VisibilityTimeout": '45'})
|
||||||
queue = sqs.Queue("test-queue")
|
queue = sqs.Queue("test-queue")
|
||||||
@ -176,7 +211,7 @@ def test_send_message():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_send_message_with_xml_characters():
|
def test_send_message_with_xml_characters():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
body_one = '< & >'
|
body_one = '< & >'
|
||||||
@ -192,14 +227,15 @@ def test_send_message_with_xml_characters():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_send_message_with_attributes():
|
def test_send_message_with_attributes():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
body = 'this is a test message'
|
body = 'this is a test message'
|
||||||
message = queue.new_message(body)
|
message = queue.new_message(body)
|
||||||
|
BASE64_BINARY = base64.b64encode(b'binary value').decode('utf-8')
|
||||||
message_attributes = {
|
message_attributes = {
|
||||||
'test.attribute_name': {'data_type': 'String', 'string_value': 'attribute value'},
|
'test.attribute_name': {'data_type': 'String', 'string_value': 'attribute value'},
|
||||||
'test.binary_attribute': {'data_type': 'Binary', 'binary_value': 'binary value'},
|
'test.binary_attribute': {'data_type': 'Binary', 'binary_value': BASE64_BINARY},
|
||||||
'test.number_attribute': {'data_type': 'Number', 'string_value': 'string value'}
|
'test.number_attribute': {'data_type': 'Number', 'string_value': 'string value'}
|
||||||
}
|
}
|
||||||
message.message_attributes = message_attributes
|
message.message_attributes = message_attributes
|
||||||
@ -217,13 +253,13 @@ def test_send_message_with_attributes():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_send_message_with_delay():
|
def test_send_message_with_delay():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
body_one = 'this is a test message'
|
body_one = 'this is a test message'
|
||||||
body_two = 'this is another test message'
|
body_two = 'this is another test message'
|
||||||
|
|
||||||
queue.write(queue.new_message(body_one), delay_seconds=60)
|
queue.write(queue.new_message(body_one), delay_seconds=3)
|
||||||
queue.write(queue.new_message(body_two))
|
queue.write(queue.new_message(body_two))
|
||||||
|
|
||||||
queue.count().should.equal(1)
|
queue.count().should.equal(1)
|
||||||
@ -238,7 +274,7 @@ def test_send_message_with_delay():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_send_large_message_fails():
|
def test_send_large_message_fails():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
body_one = 'test message' * 200000
|
body_one = 'test message' * 200000
|
||||||
@ -271,7 +307,7 @@ def test_message_becomes_inflight_when_received():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_receive_message_with_explicit_visibility_timeout():
|
def test_receive_message_with_explicit_visibility_timeout():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
body_one = 'this is another test message'
|
body_one = 'this is another test message'
|
||||||
@ -360,7 +396,7 @@ def test_read_message_from_queue():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_queue_length():
|
def test_queue_length():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
queue.write(queue.new_message('this is a test message'))
|
queue.write(queue.new_message('this is a test message'))
|
||||||
@ -371,7 +407,7 @@ def test_queue_length():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_delete_message():
|
def test_delete_message():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
queue.write(queue.new_message('this is a test message'))
|
queue.write(queue.new_message('this is a test message'))
|
||||||
@ -414,7 +450,7 @@ def test_send_batch_operation():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_send_batch_operation_with_message_attributes():
|
def test_send_batch_operation_with_message_attributes():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
queue.set_message_class(RawMessage)
|
queue.set_message_class(RawMessage)
|
||||||
|
|
||||||
message_tuple = ("my_first_message", 'test message 1', 0, {
|
message_tuple = ("my_first_message", 'test message 1', 0, {
|
||||||
@ -431,7 +467,7 @@ def test_send_batch_operation_with_message_attributes():
|
|||||||
@mock_sqs_deprecated
|
@mock_sqs_deprecated
|
||||||
def test_delete_batch_operation():
|
def test_delete_batch_operation():
|
||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
queue = conn.create_queue("test-queue", visibility_timeout=60)
|
queue = conn.create_queue("test-queue", visibility_timeout=3)
|
||||||
|
|
||||||
conn.send_message_batch(queue, [
|
conn.send_message_batch(queue, [
|
||||||
("my_first_message", 'test message 1', 0),
|
("my_first_message", 'test message 1', 0),
|
||||||
@ -450,7 +486,7 @@ def test_queue_attributes():
|
|||||||
conn = boto.connect_sqs('the_key', 'the_secret')
|
conn = boto.connect_sqs('the_key', 'the_secret')
|
||||||
|
|
||||||
queue_name = 'test-queue'
|
queue_name = 'test-queue'
|
||||||
visibility_timeout = 60
|
visibility_timeout = 3
|
||||||
|
|
||||||
queue = conn.create_queue(
|
queue = conn.create_queue(
|
||||||
queue_name, visibility_timeout=visibility_timeout)
|
queue_name, visibility_timeout=visibility_timeout)
|
||||||
|
Loading…
Reference in New Issue
Block a user