Merge pull request #1060 from kawasakitoshiya/send_json_message_from_sns_to_sqs

escape json string when sending message from sns mock to sqs mock
This commit is contained in:
Jack Danger 2017-08-17 18:29:41 -07:00 committed by GitHub
commit a579280b7a
2 changed files with 33 additions and 1 deletions

View File

@ -81,7 +81,8 @@ class Subscription(BaseModel):
if self.protocol == 'sqs':
queue_name = self.endpoint.split(":")[-1]
region = self.endpoint.split(":")[3]
sqs_backends[region].send_message(queue_name, message)
escaped_message = message.replace('"', '\\"')
sqs_backends[region].send_message(queue_name, escaped_message)
elif self.protocol in ['http', 'https']:
post_data = self.get_post_data(message, message_id)
requests.post(self.endpoint, json=post_data)

View File

@ -34,6 +34,37 @@ def test_publish_to_sqs():
messages[0].body.should.equal('my message')
@mock_sqs
@mock_sns
def test_publish_to_sqs_dump_json():
conn = boto3.client('sns', region_name='us-east-1')
conn.create_topic(Name="some-topic")
response = conn.list_topics()
topic_arn = response["Topics"][0]['TopicArn']
sqs_conn = boto3.resource('sqs', region_name='us-east-1')
sqs_conn.create_queue(QueueName="test-queue")
conn.subscribe(TopicArn=topic_arn,
Protocol="sqs",
Endpoint="arn:aws:sqs:us-east-1:123456789012:test-queue")
message = json.dumps({
"Records": [{
"eventVersion": "2.0",
"eventSource": "aws:s3",
"s3": {
"s3SchemaVersion": "1.0"
}
}]
}, sort_keys=True)
conn.publish(TopicArn=topic_arn, Message=message)
queue = sqs_conn.get_queue_by_name(QueueName="test-queue")
messages = queue.receive_messages(MaxNumberOfMessages=1)
expected = u'{\\"Records\\": [{\\"eventSource\\": \\"aws:s3\\", \\"eventVersion\\": \\"2.0\\", \\"s3\\": {\\"s3SchemaVersion\\": \\"1.0\\"}}]}'
messages[0].body.should.equal(expected)
@mock_sqs
@mock_sns
def test_publish_to_sqs_in_different_region():