| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import boto | 
					
						
							|  |  |  | import sure  # noqa | 
					
						
							|  |  |  | from freezegun import freeze_time | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from moto import mock_dynamodb_deprecated | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from boto.dynamodb import condition | 
					
						
							|  |  |  | from boto.dynamodb.exceptions import DynamoDBKeyNotFoundError, DynamoDBValidationError | 
					
						
							|  |  |  | from boto.exception import DynamoDBResponseError | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def create_table(conn): | 
					
						
							|  |  |  |     message_table_schema = conn.create_schema( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key_name="forum_name", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |         hash_key_proto_value=str, | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         range_key_name="subject", | 
					
						
							|  |  |  |         range_key_proto_value=str, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = conn.create_table( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         name="messages", schema=message_table_schema, read_units=10, write_units=10 | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  |     return table | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @freeze_time("2012-01-14") | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_create_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     expected = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Table": { | 
					
						
							|  |  |  |             "CreationDateTime": 1326499200.0, | 
					
						
							|  |  |  |             "ItemCount": 0, | 
					
						
							|  |  |  |             "KeySchema": { | 
					
						
							|  |  |  |                 "HashKeyElement": {"AttributeName": "forum_name", "AttributeType": "S"}, | 
					
						
							|  |  |  |                 "RangeKeyElement": {"AttributeName": "subject", "AttributeType": "S"}, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |             "ProvisionedThroughput": { | 
					
						
							|  |  |  |                 "ReadCapacityUnits": 10, | 
					
						
							|  |  |  |                 "WriteCapacityUnits": 10, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |             "TableName": "messages", | 
					
						
							|  |  |  |             "TableSizeBytes": 0, | 
					
						
							|  |  |  |             "TableStatus": "ACTIVE", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     conn.describe_table("messages").should.equal(expected) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_delete_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     create_table(conn) | 
					
						
							|  |  |  |     conn.list_tables().should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     conn.layer1.delete_table("messages") | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     conn.list_tables().should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     conn.layer1.delete_table.when.called_with("messages").should.throw( | 
					
						
							|  |  |  |         DynamoDBResponseError | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_update_table_throughput(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  |     table.read_units.should.equal(10) | 
					
						
							|  |  |  |     table.write_units.should.equal(10) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update_throughput(5, 6) | 
					
						
							|  |  |  |     table.refresh() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.read_units.should.equal(5) | 
					
						
							|  |  |  |     table.write_units.should.equal(6) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_item_add_and_describe_and_update(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     item = table.new_item( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key="LOLCat Forum", range_key="Check this out!", attrs=item_data | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.has_item("LOLCat Forum", "Check this out!").should.equal(True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.get_item( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key="LOLCat Forum", | 
					
						
							|  |  |  |         range_key="Check this out!", | 
					
						
							|  |  |  |         attributes_to_get=["Body", "SentBy"], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     dict(returned_item).should.equal( | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             "forum_name": "LOLCat Forum", | 
					
						
							|  |  |  |             "subject": "Check this out!", | 
					
						
							|  |  |  |             "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |             "SentBy": "User A", | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     item["SentBy"] = "User B" | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.get_item( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key="LOLCat Forum", | 
					
						
							|  |  |  |         range_key="Check this out!", | 
					
						
							|  |  |  |         attributes_to_get=["Body", "SentBy"], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     dict(returned_item).should.equal( | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             "forum_name": "LOLCat Forum", | 
					
						
							|  |  |  |             "subject": "Check this out!", | 
					
						
							|  |  |  |             "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |             "SentBy": "User B", | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_item_put_without_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.layer1.put_item.when.called_with( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         table_name="undeclared-table", | 
					
						
							|  |  |  |         item=dict(hash_key="LOLCat Forum", range_key="Check this out!"), | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ).should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_get_missing_item(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     table.get_item.when.called_with(hash_key="tester", range_key="other").should.throw( | 
					
						
							|  |  |  |         DynamoDBKeyNotFoundError | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     table.has_item("foobar", "more").should.equal(False) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_get_item_with_undeclared_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.layer1.get_item.when.called_with( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         table_name="undeclared-table", | 
					
						
							|  |  |  |         key={"HashKeyElement": {"S": "tester"}, "RangeKeyElement": {"S": "test-range"}}, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ).should.throw(DynamoDBKeyNotFoundError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_get_item_without_range_key(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     message_table_schema = conn.create_schema( | 
					
						
							|  |  |  |         hash_key_name="test_hash", | 
					
						
							|  |  |  |         hash_key_proto_value=int, | 
					
						
							|  |  |  |         range_key_name="test_range", | 
					
						
							|  |  |  |         range_key_proto_value=int, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = conn.create_table( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         name="messages", schema=message_table_schema, read_units=10, write_units=10 | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     hash_key = 3241526475 | 
					
						
							|  |  |  |     range_key = 1234567890987 | 
					
						
							|  |  |  |     new_item = table.new_item(hash_key=hash_key, range_key=range_key) | 
					
						
							|  |  |  |     new_item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     table.get_item.when.called_with(hash_key=hash_key).should.throw( | 
					
						
							|  |  |  |         DynamoDBValidationError | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_delete_item(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     item = table.new_item( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key="LOLCat Forum", range_key="Check this out!", attrs=item_data | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response = item.delete() | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     response.should.equal({"Attributes": [], "ConsumedCapacityUnits": 0.5}) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item.delete.when.called_with().should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_delete_item_with_attribute_response(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     item = table.new_item( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         hash_key="LOLCat Forum", range_key="Check this out!", attrs=item_data | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     response = item.delete(return_values="ALL_OLD") | 
					
						
							|  |  |  |     response.should.equal( | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             "Attributes": { | 
					
						
							|  |  |  |                 "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |                 "forum_name": "LOLCat Forum", | 
					
						
							|  |  |  |                 "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							|  |  |  |                 "SentBy": "User A", | 
					
						
							|  |  |  |                 "subject": "Check this out!", | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             "ConsumedCapacityUnits": 0.5, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item.delete.when.called_with().should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_delete_item_with_undeclared_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.layer1.delete_item.when.called_with( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         table_name="undeclared-table", | 
					
						
							|  |  |  |         key={"HashKeyElement": {"S": "tester"}, "RangeKeyElement": {"S": "test-range"}}, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     ).should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_query(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="456", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="123", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="789", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query(hash_key="the-key", range_key_condition=condition.GT("1")) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(3) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query(hash_key="the-key", range_key_condition=condition.GT("234")) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(2) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query(hash_key="the-key", range_key_condition=condition.GT("9999")) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(0) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query( | 
					
						
							|  |  |  |         hash_key="the-key", range_key_condition=condition.CONTAINS("12") | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query( | 
					
						
							|  |  |  |         hash_key="the-key", range_key_condition=condition.BEGINS_WITH("7") | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.query( | 
					
						
							|  |  |  |         hash_key="the-key", range_key_condition=condition.BETWEEN("567", "890") | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_query_with_undeclared_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.layer1.query.when.called_with( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         table_name="undeclared-table", | 
					
						
							|  |  |  |         hash_key_value={"S": "the-key"}, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |         range_key_conditions={ | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |             "AttributeValueList": [{"S": "User B"}], | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |             "ComparisonOperator": "EQ", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     ).should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_scan(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="456", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="123", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User B", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							|  |  |  |         "Ids": set([1, 2, 3]), | 
					
						
							|  |  |  |         "PK": 7, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="789", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan() | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results.response["Items"].should.have.length_of(3) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"SentBy": condition.EQ("User B")}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"Body": condition.BEGINS_WITH("http")}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(3) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"Ids": condition.CONTAINS(2)}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"Ids": condition.NOT_NULL()}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"Ids": condition.NULL()}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(2) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"PK": condition.BETWEEN(8, 9)}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(0) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     results = table.scan(scan_filter={"PK": condition.BETWEEN(5, 8)}) | 
					
						
							|  |  |  |     results.response["Items"].should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_scan_with_undeclared_table(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.layer1.scan.when.called_with( | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         table_name="undeclared-table", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |         scan_filter={ | 
					
						
							|  |  |  |             "SentBy": { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |                 "AttributeValueList": [{"S": "User B"}], | 
					
						
							|  |  |  |                 "ComparisonOperator": "EQ", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     ).should.throw(DynamoDBResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_scan_after_has_item(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  |     list(table.scan()).should.equal([]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     table.has_item(hash_key="the-key", range_key="123") | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     list(table.scan()).should.equal([]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_write_batch(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     batch_list = conn.new_batch_write_list() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     items = [] | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     items.append( | 
					
						
							|  |  |  |         table.new_item( | 
					
						
							|  |  |  |             hash_key="the-key", | 
					
						
							|  |  |  |             range_key="123", | 
					
						
							|  |  |  |             attrs={ | 
					
						
							|  |  |  |                 "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |                 "SentBy": "User A", | 
					
						
							|  |  |  |                 "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     items.append( | 
					
						
							|  |  |  |         table.new_item( | 
					
						
							|  |  |  |             hash_key="the-key", | 
					
						
							|  |  |  |             range_key="789", | 
					
						
							|  |  |  |             attrs={ | 
					
						
							|  |  |  |                 "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |                 "SentBy": "User B", | 
					
						
							|  |  |  |                 "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							|  |  |  |                 "Ids": set([1, 2, 3]), | 
					
						
							|  |  |  |                 "PK": 7, | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     batch_list.add_batch(table, puts=items) | 
					
						
							|  |  |  |     conn.batch_write_item(batch_list) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     batch_list = conn.new_batch_write_list() | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     batch_list.add_batch(table, deletes=[("the-key", "789")]) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     conn.batch_write_item(batch_list) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.refresh() | 
					
						
							|  |  |  |     table.item_count.should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb_deprecated | 
					
						
							|  |  |  | def test_batch_read(): | 
					
						
							|  |  |  |     conn = boto.connect_dynamodb() | 
					
						
							|  |  |  |     table = create_table(conn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User A", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="456", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="the-key", range_key="123", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |         "Body": "http://url_to_lolcat.gif", | 
					
						
							|  |  |  |         "SentBy": "User B", | 
					
						
							|  |  |  |         "ReceivedTime": "12/9/2011 11:36:03 PM", | 
					
						
							|  |  |  |         "Ids": set([1, 2, 3]), | 
					
						
							|  |  |  |         "PK": 7, | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     item = table.new_item(hash_key="another-key", range_key="789", attrs=item_data) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     item.put() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-23 08:38:53 +01:00
										 |  |  |     items = table.batch_get_item([("the-key", "123"), ("another-key", "789")]) | 
					
						
							| 
									
										
										
										
											2018-12-21 12:28:56 +01:00
										 |  |  |     # Iterate through so that batch_item gets called | 
					
						
							|  |  |  |     count = len([x for x in items]) | 
					
						
							|  |  |  |     count.should.equal(2) |