| 
									
										
										
										
											2014-08-27 11:17:06 -04:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							| 
									
										
										
										
											2014-11-27 08:03:47 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  | from decimal import Decimal | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | import boto | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  | import boto3 | 
					
						
							|  |  |  | from boto3.dynamodb.conditions import Key | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | import sure  # noqa | 
					
						
							|  |  |  | from freezegun import freeze_time | 
					
						
							|  |  |  | from moto import mock_dynamodb2 | 
					
						
							|  |  |  | from boto.exception import JSONResponseError | 
					
						
							| 
									
										
										
										
											2014-11-27 08:03:47 -05:00
										 |  |  | from tests.helpers import requires_boto_gte | 
					
						
							| 
									
										
										
										
											2014-01-07 12:59:36 +02:00
										 |  |  | try: | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |     from boto.dynamodb2.fields import GlobalAllIndex, HashKey, RangeKey, AllIndex | 
					
						
							| 
									
										
										
										
											2015-03-14 15:02:43 -04:00
										 |  |  |     from boto.dynamodb2.table import Item, Table | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |     from boto.dynamodb2.types import STRING, NUMBER | 
					
						
							| 
									
										
										
										
											2014-01-07 12:59:36 +02:00
										 |  |  |     from boto.dynamodb2.exceptions import ValidationException | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  |     from boto.dynamodb2.exceptions import ConditionalCheckFailedException | 
					
						
							| 
									
										
										
										
											2014-01-07 12:59:36 +02:00
										 |  |  | except ImportError: | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | def create_table(): | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('forum_name'), | 
					
						
							|  |  |  |         RangeKey('subject'), | 
					
						
							|  |  |  |     ], throughput={ | 
					
						
							|  |  |  |         'read': 10, | 
					
						
							|  |  |  |         'write': 10, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     return table | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  | def create_table_with_local_indexes(): | 
					
						
							|  |  |  |     table = Table.create( | 
					
						
							|  |  |  |         'messages', | 
					
						
							|  |  |  |         schema=[ | 
					
						
							|  |  |  |             HashKey('forum_name'), | 
					
						
							|  |  |  |             RangeKey('subject'), | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         throughput={ | 
					
						
							|  |  |  |             'read': 10, | 
					
						
							|  |  |  |             'write': 10, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         indexes=[ | 
					
						
							|  |  |  |             AllIndex( | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |                 'threads_index', | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |                 parts=[ | 
					
						
							|  |  |  |                     HashKey('forum_name', data_type=STRING), | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |                     RangeKey('threads', data_type=NUMBER), | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |                 ] | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     return table | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | def iterate_results(res): | 
					
						
							|  |  |  |     for i in res: | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |         pass | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @freeze_time("2012-01-14") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | def test_create_table(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     expected = { | 
					
						
							|  |  |  |         'Table': { | 
					
						
							|  |  |  |             'AttributeDefinitions': [ | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |                 {'AttributeName': 'forum_name', 'AttributeType': 'S'}, | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |                 {'AttributeName': 'subject', 'AttributeType': 'S'} | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |             ], | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'NumberOfDecreasesToday': 0, 'WriteCapacityUnits': 10, 'ReadCapacityUnits': 10 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |             }, | 
					
						
							|  |  |  |             'TableSizeBytes': 0, | 
					
						
							|  |  |  |             'TableName': 'messages', | 
					
						
							|  |  |  |             'TableStatus': 'ACTIVE', | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |             'KeySchema': [ | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |                 {'KeyType': 'HASH', 'AttributeName': 'forum_name'}, | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |                 {'KeyType': 'RANGE', 'AttributeName': 'subject'} | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |             ], | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |             'LocalSecondaryIndexes': [], | 
					
						
							| 
									
										
										
										
											2015-03-14 15:02:43 -04:00
										 |  |  |             'ItemCount': 0, 'CreationDateTime': 1326499200.0, | 
					
						
							|  |  |  |             'GlobalSecondaryIndexes': [], | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     table.describe().should.equal(expected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | @freeze_time("2012-01-14") | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  | def test_create_table_with_local_index(): | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     expected = { | 
					
						
							|  |  |  |         'Table': { | 
					
						
							|  |  |  |             'AttributeDefinitions': [ | 
					
						
							|  |  |  |                 {'AttributeName': 'forum_name', 'AttributeType': 'S'}, | 
					
						
							|  |  |  |                 {'AttributeName': 'subject', 'AttributeType': 'S'}, | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |                 {'AttributeName': 'threads', 'AttributeType': 'N'} | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |             ], | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'NumberOfDecreasesToday': 0, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 10, | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 10, | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'TableSizeBytes': 0, | 
					
						
							|  |  |  |             'TableName': 'messages', | 
					
						
							|  |  |  |             'TableStatus': 'ACTIVE', | 
					
						
							|  |  |  |             'KeySchema': [ | 
					
						
							|  |  |  |                 {'KeyType': 'HASH', 'AttributeName': 'forum_name'}, | 
					
						
							|  |  |  |                 {'KeyType': 'RANGE', 'AttributeName': 'subject'} | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'LocalSecondaryIndexes': [ | 
					
						
							|  |  |  |                 { | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |                     'IndexName': 'threads_index', | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |                     'KeySchema': [ | 
					
						
							|  |  |  |                         {'AttributeName': 'forum_name', 'KeyType': 'HASH'}, | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |                         {'AttributeName': 'threads', 'KeyType': 'RANGE'} | 
					
						
							| 
									
										
										
										
											2016-01-14 11:30:50 -08:00
										 |  |  |                     ], | 
					
						
							|  |  |  |                     'Projection': {'ProjectionType': 'ALL'} | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'ItemCount': 0, | 
					
						
							|  |  |  |             'CreationDateTime': 1326499200.0, | 
					
						
							|  |  |  |             'GlobalSecondaryIndexes': [], | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     table.describe().should.equal(expected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_delete_table(): | 
					
						
							|  |  |  |     conn = boto.dynamodb2.layer1.DynamoDBConnection() | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     conn.list_tables()["TableNames"].should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.delete() | 
					
						
							|  |  |  |     conn.list_tables()["TableNames"].should.have.length_of(0) | 
					
						
							|  |  |  |     conn.delete_table.when.called_with('messages').should.throw(JSONResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_table_throughput(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     table.throughput["read"].should.equal(10) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     table.throughput["write"].should.equal(10) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.update(throughput={ | 
					
						
							|  |  |  |         'read': 5, | 
					
						
							|  |  |  |         'write': 15, | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.throughput["read"].should.equal(5) | 
					
						
							|  |  |  |     table.throughput["write"].should.equal(15) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(throughput={ | 
					
						
							|  |  |  |         'read': 5, | 
					
						
							|  |  |  |         'write': 6, | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.describe() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.throughput["read"].should.equal(5) | 
					
						
							|  |  |  |     table.throughput["write"].should.equal(6) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_item_add_and_describe_and_update(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     ok = table.put_item(data={ | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'subject': 'Check this out!', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     }) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     ok.should.equal(True) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     table.get_item(forum_name="LOLCat Forum", subject='Check this out!').should_not.be.none | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.get_item( | 
					
						
							|  |  |  |         forum_name='LOLCat Forum', | 
					
						
							|  |  |  |         subject='Check this out!' | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'subject': 'Check this out!', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     returned_item['SentBy'] = 'User B' | 
					
						
							|  |  |  |     returned_item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.get_item( | 
					
						
							|  |  |  |         forum_name='LOLCat Forum', | 
					
						
							|  |  |  |         subject='Check this out!' | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'subject': 'Check this out!', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User B', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-31 10:17:08 -08:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_item_partial_save(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     data = { | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'subject': 'The LOLz', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.put_item(data=data) | 
					
						
							|  |  |  |     returned_item = table.get_item(forum_name="LOLCat Forum", subject='The LOLz') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item['SentBy'] = 'User B' | 
					
						
							|  |  |  |     returned_item.partial_save() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.get_item( | 
					
						
							|  |  |  |         forum_name='LOLCat Forum', | 
					
						
							|  |  |  |         subject='The LOLz' | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'subject': 'The LOLz', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User B', | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_item_put_without_table(): | 
					
						
							|  |  |  |     table = Table('undeclared-table') | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item.save.when.called_with().should.throw(JSONResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_get_missing_item(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.get_item.when.called_with( | 
					
						
							|  |  |  |         hash_key='tester', | 
					
						
							|  |  |  |         range_key='other', | 
					
						
							|  |  |  |     ).should.throw(ValidationException) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_get_item_with_undeclared_table(): | 
					
						
							|  |  |  |     table = Table('undeclared-table') | 
					
						
							|  |  |  |     table.get_item.when.called_with(test_hash=3241526475).should.throw(JSONResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_get_item_without_range_key(): | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('test_hash'), | 
					
						
							|  |  |  |         RangeKey('test_range'), | 
					
						
							|  |  |  |     ], throughput={ | 
					
						
							|  |  |  |         'read': 10, | 
					
						
							|  |  |  |         'write': 10, | 
					
						
							|  |  |  |     }) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     hash_key = 3241526475 | 
					
						
							|  |  |  |     range_key = 1234567890987 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     table.put_item(data={'test_hash': hash_key, 'test_range': range_key}) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.get_item.when.called_with(test_hash=hash_key).should.throw(ValidationException) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:53:54 -04:00
										 |  |  | @requires_boto_gte("2.30.0") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_delete_item(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item['subject'] = 'Check this out!' | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item.save() | 
					
						
							|  |  |  |     table.count().should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response = item.delete() | 
					
						
							|  |  |  |     response.should.equal(True) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.count().should.equal(0) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item.delete().should.equal(False) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_delete_item_with_undeclared_table(): | 
					
						
							|  |  |  |     table = Table("undeclared-table") | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item.delete.when.called_with().should.throw(JSONResponseError) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'forum_name': 'LOLCat Forum', | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |         'subject': 'Check this out!' | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item.save(overwrite=True) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item['subject'] = '456' | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item['subject'] = '123' | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item['subject'] = '789' | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.count().should.equal(4) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__gt='1', consistent=True) | 
					
						
							| 
									
										
										
										
											2014-02-23 23:38:04 -08:00
										 |  |  |     expected = ["123", "456", "789"] | 
					
						
							|  |  |  |     for index, item in enumerate(results): | 
					
						
							|  |  |  |         item["subject"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq="the-key", subject__gt='1', reverse=True) | 
					
						
							| 
									
										
										
										
											2014-03-03 13:49:08 -08:00
										 |  |  |     for index, item in enumerate(results): | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |         item["subject"].should.equal(expected[len(expected) - 1 - index]) | 
					
						
							| 
									
										
										
										
											2014-03-03 13:49:08 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__gt='1', consistent=True) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(3) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__gt='234', consistent=True) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(2) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__gt='9999') | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(0) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__beginswith='12') | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__beginswith='7') | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     results = table.query_2(forum_name__eq='the-key', subject__between=['567', '890']) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_with_undeclared_table(): | 
					
						
							|  |  |  |     table = Table('undeclared') | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         forum_name__eq='Amazon DynamoDB', | 
					
						
							|  |  |  |         subject__beginswith='DynamoDB', | 
					
						
							|  |  |  |         limit=1 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     iterate_results.when.called_with(results).should.throw(JSONResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_scan(): | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     table = create_table() | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data = { | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     item_data['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item_data['subject'] = '456' | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item.save() | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     item['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item['subject'] = '123' | 
					
						
							|  |  |  |     item.save() | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data = { | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User B', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:09 PM', | 
					
						
							|  |  |  |         'Ids': set([1, 2, 3]), | 
					
						
							|  |  |  |         'PK': 7, | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item_data['subject'] = '789' | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item.save() | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan() | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(3) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan(SentBy__eq='User B') | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan(Body__beginswith='http') | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(3) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan(Ids__null=False) | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     results = table.scan(Ids__null=True) | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(2) | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     results = table.scan(PK__between=[8, 9]) | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.scan(PK__between=[5, 8]) | 
					
						
							|  |  |  |     sum(1 for _ in results).should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_scan_with_undeclared_table(): | 
					
						
							|  |  |  |     conn = boto.dynamodb2.layer1.DynamoDBConnection() | 
					
						
							|  |  |  |     conn.scan.when.called_with( | 
					
						
							|  |  |  |         table_name='undeclared-table', | 
					
						
							|  |  |  |         scan_filter={ | 
					
						
							|  |  |  |             "SentBy": { | 
					
						
							|  |  |  |                 "AttributeValueList": [{ | 
					
						
							|  |  |  |                     "S": "User B"} | 
					
						
							|  |  |  |                 ], | 
					
						
							|  |  |  |                 "ComparisonOperator": "EQ" | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     ).should.throw(JSONResponseError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_write_batch(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     with table.batch_write() as batch: | 
					
						
							|  |  |  |         batch.put_item(data={ | 
					
						
							|  |  |  |             'forum_name': 'the-key', | 
					
						
							|  |  |  |             'subject': '123', | 
					
						
							|  |  |  |             'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |             'SentBy': 'User A', | 
					
						
							|  |  |  |             'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |         }) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |         batch.put_item(data={ | 
					
						
							|  |  |  |             'forum_name': 'the-key', | 
					
						
							|  |  |  |             'subject': '789', | 
					
						
							|  |  |  |             'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |             'SentBy': 'User B', | 
					
						
							|  |  |  |             'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     table.count().should.equal(2) | 
					
						
							|  |  |  |     with table.batch_write() as batch: | 
					
						
							|  |  |  |         batch.delete_item( | 
					
						
							|  |  |  |             forum_name='the-key', | 
					
						
							|  |  |  |             subject='789' | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.count().should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_batch_read(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User A', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item_data['subject'] = '456' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item.save() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item = Item(table, item_data) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data['forum_name'] = 'the-key' | 
					
						
							|  |  |  |     item_data['subject'] = '123' | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item.save() | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'Body': 'http://url_to_lolcat.gif', | 
					
						
							|  |  |  |         'SentBy': 'User B', | 
					
						
							|  |  |  |         'ReceivedTime': '12/9/2011 11:36:03 PM', | 
					
						
							|  |  |  |         'Ids': set([1, 2, 3]), | 
					
						
							|  |  |  |         'PK': 7, | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item = Item(table, item_data) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  |     item_data['forum_name'] = 'another-key' | 
					
						
							|  |  |  |     item_data['subject'] = '789' | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     item.save() | 
					
						
							|  |  |  |     results = table.batch_get( | 
					
						
							|  |  |  |         keys=[ | 
					
						
							|  |  |  |             {'forum_name': 'the-key', 'subject': '123'}, | 
					
						
							|  |  |  |             {'forum_name': 'another-key', 'subject': '789'}, | 
					
						
							|  |  |  |         ] | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Iterate through so that batch_item gets called | 
					
						
							|  |  |  |     count = len([x for x in results]) | 
					
						
							|  |  |  |     count.should.equal(2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-07 10:56:51 +02:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							| 
									
										
										
										
											2013-12-05 13:16:56 +02:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_get_key_fields(): | 
					
						
							|  |  |  |     table = create_table() | 
					
						
							|  |  |  |     kf = table.get_key_fields() | 
					
						
							| 
									
										
										
										
											2014-07-22 21:47:56 -04:00
										 |  |  |     kf.should.equal(['forum_name', 'subject']) | 
					
						
							| 
									
										
										
										
											2015-03-14 15:02:43 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_create_with_global_indexes(): | 
					
						
							|  |  |  |     conn = boto.dynamodb2.layer1.DynamoDBConnection() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('subject'), | 
					
						
							|  |  |  |         RangeKey('version'), | 
					
						
							|  |  |  |     ], global_indexes=[ | 
					
						
							|  |  |  |         GlobalAllIndex('topic-created_at-index', | 
					
						
							|  |  |  |             parts=[ | 
					
						
							|  |  |  |                 HashKey('topic'), | 
					
						
							|  |  |  |                 RangeKey('created_at', data_type='N') | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             throughput={ | 
					
						
							|  |  |  |                 'read': 6, | 
					
						
							|  |  |  |                 'write': 1 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |     ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table_description = conn.describe_table("messages") | 
					
						
							|  |  |  |     table_description['Table']["GlobalSecondaryIndexes"].should.equal([ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             "IndexName": "topic-created_at-index", | 
					
						
							|  |  |  |             "KeySchema": [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     "AttributeName": "topic", | 
					
						
							|  |  |  |                     "KeyType": "HASH" | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     "AttributeName": "created_at", | 
					
						
							|  |  |  |                     "KeyType": "RANGE" | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             "Projection": { | 
					
						
							|  |  |  |                 "ProjectionType": "ALL" | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             "ProvisionedThroughput": { | 
					
						
							|  |  |  |                 "ReadCapacityUnits": 6, | 
					
						
							|  |  |  |                 "WriteCapacityUnits": 1, | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_with_global_indexes(): | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('subject'), | 
					
						
							|  |  |  |         RangeKey('version'), | 
					
						
							|  |  |  |     ], global_indexes=[ | 
					
						
							|  |  |  |         GlobalAllIndex('topic-created_at-index', | 
					
						
							|  |  |  |             parts=[ | 
					
						
							|  |  |  |                 HashKey('topic'), | 
					
						
							|  |  |  |                 RangeKey('created_at', data_type='N') | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             throughput={ | 
					
						
							|  |  |  |                 'read': 6, | 
					
						
							|  |  |  |                 'write': 1 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |         GlobalAllIndex('status-created_at-index', | 
					
						
							|  |  |  |             parts=[ | 
					
						
							|  |  |  |                 HashKey('status'), | 
					
						
							|  |  |  |                 RangeKey('created_at', data_type='N') | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             throughput={ | 
					
						
							|  |  |  |                 'read': 2, | 
					
						
							|  |  |  |                 'write': 1 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'subject': 'Check this out!', | 
					
						
							|  |  |  |         'version': '1', | 
					
						
							|  |  |  |         'created_at': 0, | 
					
						
							|  |  |  |         'status': 'inactive' | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item['version'] = '2' | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query(status__eq='active') | 
					
						
							|  |  |  |     list(results).should.have.length_of(0) | 
					
						
							| 
									
										
										
										
											2015-05-20 11:20:16 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_with_local_indexes(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = { | 
					
						
							|  |  |  |         'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |         'subject': 'Check this out!', | 
					
						
							|  |  |  |         'version': '1', | 
					
						
							|  |  |  |         'threads': 1, | 
					
						
							|  |  |  |         'status': 'inactive' | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     item = Item(table, item_data) | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item['version'] = '2' | 
					
						
							|  |  |  |     item.save(overwrite=True) | 
					
						
							| 
									
										
										
										
											2016-03-16 21:32:54 -07:00
										 |  |  |     results = table.query(forum_name__eq='Cool Forum', index='threads_index', threads__eq=1) | 
					
						
							| 
									
										
										
										
											2016-01-14 14:25:04 -08:00
										 |  |  |     list(results).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-16 21:32:54 -07:00
										 |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_filter_eq(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Check this out!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 1, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Read this now!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 5, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Please read this... please', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 0, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     for data in item_data: | 
					
						
							|  |  |  |         item = Item(table, data) | 
					
						
							|  |  |  |         item.save(overwrite=True) | 
					
						
							|  |  |  |     results = table.query_2( | 
					
						
							|  |  |  |         forum_name__eq='Cool Forum', index='threads_index', threads__eq=5 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     list(results).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_filter_lt(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Check this out!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 1, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Read this now!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 5, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Please read this... please', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 0, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     for data in item_data: | 
					
						
							|  |  |  |         item = Item(table, data) | 
					
						
							|  |  |  |         item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         forum_name__eq='Cool Forum', index='threads_index', threads__lt=5 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results = list(results) | 
					
						
							|  |  |  |     results.should.have.length_of(2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_filter_gt(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Check this out!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 1, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Read this now!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 5, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Please read this... please', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 0, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     for data in item_data: | 
					
						
							|  |  |  |         item = Item(table, data) | 
					
						
							|  |  |  |         item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         forum_name__eq='Cool Forum', index='threads_index', threads__gt=1 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     list(results).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_filter_lte(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Check this out!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 1, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Read this now!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 5, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Please read this... please', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 0, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     for data in item_data: | 
					
						
							|  |  |  |         item = Item(table, data) | 
					
						
							|  |  |  |         item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         forum_name__eq='Cool Forum', index='threads_index', threads__lte=5 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     list(results).should.have.length_of(3) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @requires_boto_gte("2.9") | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_filter_gte(): | 
					
						
							|  |  |  |     table = create_table_with_local_indexes() | 
					
						
							|  |  |  |     item_data = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Check this out!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 1, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Read this now!', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 5, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             'forum_name': 'Cool Forum', | 
					
						
							|  |  |  |             'subject': 'Please read this... please', | 
					
						
							|  |  |  |             'version': '1', | 
					
						
							|  |  |  |             'threads': 0, | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     for data in item_data: | 
					
						
							|  |  |  |         item = Item(table, data) | 
					
						
							|  |  |  |         item.save(overwrite=True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         forum_name__eq='Cool Forum', index='threads_index', threads__gte=1 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     list(results).should.have.length_of(2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-09 17:58:06 -08:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_reverse_query(): | 
					
						
							|  |  |  |     conn = boto.dynamodb2.layer1.DynamoDBConnection() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('subject'), | 
					
						
							|  |  |  |         RangeKey('created_at', data_type='N') | 
					
						
							|  |  |  |     ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for i in range(10): | 
					
						
							|  |  |  |         table.put_item({ | 
					
						
							|  |  |  |             'subject': "Hi", | 
					
						
							|  |  |  |             'created_at': i | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query_2(subject__eq="Hi", | 
					
						
							|  |  |  |                             created_at__lt=6, | 
					
						
							|  |  |  |                             limit=4, | 
					
						
							|  |  |  |                             reverse=True) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-09 18:29:21 -08:00
										 |  |  |     expected = [Decimal(5), Decimal(4), Decimal(3), Decimal(2)] | 
					
						
							| 
									
										
										
										
											2016-01-09 17:58:06 -08:00
										 |  |  |     [r['created_at'] for r in results].should.equal(expected) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-20 11:20:16 -04:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_lookup(): | 
					
						
							|  |  |  |     from decimal import Decimal | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('test_hash'), | 
					
						
							|  |  |  |         RangeKey('test_range'), | 
					
						
							|  |  |  |     ], throughput={ | 
					
						
							|  |  |  |         'read': 10, | 
					
						
							|  |  |  |         'write': 10, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     hash_key = 3241526475 | 
					
						
							|  |  |  |     range_key = 1234567890987 | 
					
						
							|  |  |  |     data = {'test_hash': hash_key, 'test_range': range_key} | 
					
						
							|  |  |  |     table.put_item(data=data) | 
					
						
							|  |  |  |     message = table.lookup(hash_key, range_key) | 
					
						
							|  |  |  |     message.get('test_hash').should.equal(Decimal(hash_key)) | 
					
						
							|  |  |  |     message.get('test_range').should.equal(Decimal(range_key)) | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_failed_overwrite(): | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('id'), | 
					
						
							|  |  |  |         RangeKey('range'), | 
					
						
							|  |  |  |     ], throughput={ | 
					
						
							|  |  |  |         'read': 7, | 
					
						
							|  |  |  |         'write': 3, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     data1 = {'id': '123', 'range': 'abc', 'data': '678'} | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  |     table.put_item(data=data1) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     data2 = {'id': '123', 'range': 'abc', 'data': '345'} | 
					
						
							|  |  |  |     table.put_item(data=data2, overwrite=True) | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     data3 = {'id': '123', 'range': 'abc', 'data': '812'} | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  |     table.put_item.when.called_with(data=data3).should.throw(ConditionalCheckFailedException) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.lookup('123', 'abc') | 
					
						
							|  |  |  |     dict(returned_item).should.equal(data2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     data4 = {'id': '123', 'range': 'ghi', 'data': 812} | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  |     table.put_item(data=data4) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = table.lookup('123', 'ghi') | 
					
						
							|  |  |  |     dict(returned_item).should.equal(data4) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_conflicting_writes(): | 
					
						
							|  |  |  |     table = Table.create('messages', schema=[ | 
					
						
							|  |  |  |         HashKey('id'), | 
					
						
							|  |  |  |         RangeKey('range'), | 
					
						
							|  |  |  |     ]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     item_data = {'id': '123', 'range': 'abc', 'data': '678'} | 
					
						
							| 
									
										
										
										
											2015-07-08 11:55:12 -04:00
										 |  |  |     item1 = Item(table, item_data) | 
					
						
							|  |  |  |     item2 = Item(table, item_data) | 
					
						
							|  |  |  |     item1.save() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item1['data'] = '579' | 
					
						
							|  |  |  |     item2['data'] = '912' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item1.save() | 
					
						
							|  |  |  |     item2.save.when.called_with().should.throw(ConditionalCheckFailedException) | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | boto3 | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_boto3_conditions(): | 
					
						
							|  |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 5 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123' | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '456' | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '789' | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Test a query returning all items | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").gt('1'), | 
					
						
							|  |  |  |         ScanIndexForward=True, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     expected = ["123", "456", "789"] | 
					
						
							|  |  |  |     for index, item in enumerate(results['Items']): | 
					
						
							|  |  |  |         item["subject"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Return all items again, but in reverse | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").gt('1'), | 
					
						
							|  |  |  |         ScanIndexForward=False, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     for index, item in enumerate(reversed(results['Items'])): | 
					
						
							|  |  |  |         item["subject"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Filter the subjects to only return some of the results | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").gt('234'), | 
					
						
							|  |  |  |         ConsistentRead=True, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Filter to return no results | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").gt('9999') | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").begins_with('12') | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         KeyConditionExpression=Key("subject").begins_with('7') & Key('forum_name').eq('the-key') | 
					
						
							| 
									
										
										
										
											2015-08-01 19:32:33 -04:00
										 |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key') & Key("subject").between('567', '890') | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(1) | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  | def _create_table_with_range_key(): | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         GlobalSecondaryIndexes=[{ | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'KeySchema': [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'username', | 
					
						
							|  |  |  |                     'KeyType': 'HASH', | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'created', | 
					
						
							|  |  |  |                     'KeyType': 'RANGE', | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'Projection': { | 
					
						
							|  |  |  |                 'ProjectionType': 'ALL', | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 5 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 5 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     return dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_item_range_key_set(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							|  |  |  |         'username': 'johndoe', | 
					
						
							|  |  |  |         'created': Decimal('3'), | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_key = {'forum_name': 'the-key', 'subject': '123'} | 
					
						
							|  |  |  |     table.update_item( | 
					
						
							|  |  |  |         Key=item_key, | 
					
						
							|  |  |  |         AttributeUpdates={ | 
					
						
							|  |  |  |             'username': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': 'johndoe2' | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2015-12-21 16:45:08 -07:00
										 |  |  |             'created': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': Decimal('4'), | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'mapfield': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': {'key': 'value'}, | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |         }, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-08 17:46:55 -07:00
										 |  |  |     returned_item = dict((k, str(v) if isinstance(v, Decimal) else v) | 
					
						
							|  |  |  |                          for k, v in table.get_item(Key=item_key)['Item'].items()) | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'username': "johndoe2", | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							| 
									
										
										
										
											2016-01-08 17:46:55 -07:00
										 |  |  |         'created': '4', | 
					
						
							| 
									
										
										
										
											2015-12-21 16:45:08 -07:00
										 |  |  |         'mapfield': {'key': 'value'}, | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:46:05 -07:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_item_does_not_exist_is_created(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     item_key = {'forum_name': 'the-key', 'subject': '123'} | 
					
						
							| 
									
										
										
										
											2016-01-15 10:23:29 -07:00
										 |  |  |     result = table.update_item( | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |         Key=item_key, | 
					
						
							|  |  |  |         AttributeUpdates={ | 
					
						
							|  |  |  |             'username': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': 'johndoe2' | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2015-12-21 16:45:08 -07:00
										 |  |  |             'created': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': Decimal('4'), | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'mapfield': { | 
					
						
							|  |  |  |                 'Action': u'PUT', | 
					
						
							|  |  |  |                 'Value': {'key': 'value'}, | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2016-01-15 10:23:29 -07:00
										 |  |  |         ReturnValues='ALL_OLD', | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 10:23:29 -07:00
										 |  |  |     assert not result.get('Attributes') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-08 17:46:55 -07:00
										 |  |  |     returned_item = dict((k, str(v) if isinstance(v, Decimal) else v) | 
					
						
							|  |  |  |                          for k, v in table.get_item(Key=item_key)['Item'].items()) | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'username': "johndoe2", | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							| 
									
										
										
										
											2016-01-08 17:46:55 -07:00
										 |  |  |         'created': '4', | 
					
						
							| 
									
										
										
										
											2015-12-21 16:45:08 -07:00
										 |  |  |         'mapfield': {'key': 'value'}, | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:44:28 -07:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_item_add_value(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							|  |  |  |         'numeric_field': Decimal('-1'), | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_key = {'forum_name': 'the-key', 'subject': '123'} | 
					
						
							|  |  |  |     table.update_item( | 
					
						
							|  |  |  |         Key=item_key, | 
					
						
							|  |  |  |         AttributeUpdates={ | 
					
						
							|  |  |  |             'numeric_field': { | 
					
						
							|  |  |  |                 'Action': u'ADD', | 
					
						
							|  |  |  |                 'Value': Decimal('2'), | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = dict((k, str(v) if isinstance(v, Decimal) else v) | 
					
						
							|  |  |  |                          for k, v in table.get_item(Key=item_key)['Item'].items()) | 
					
						
							|  |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'numeric_field': '1', | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_item_add_value_does_not_exist_is_created(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     item_key = {'forum_name': 'the-key', 'subject': '123'} | 
					
						
							|  |  |  |     table.update_item( | 
					
						
							|  |  |  |         Key=item_key, | 
					
						
							|  |  |  |         AttributeUpdates={ | 
					
						
							|  |  |  |             'numeric_field': { | 
					
						
							|  |  |  |                 'Action': u'ADD', | 
					
						
							|  |  |  |                 'Value': Decimal('2'), | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     returned_item = dict((k, str(v) if isinstance(v, Decimal) else v) | 
					
						
							|  |  |  |                          for k, v in table.get_item(Key=item_key)['Item'].items()) | 
					
						
							|  |  |  |     dict(returned_item).should.equal({ | 
					
						
							|  |  |  |         'numeric_field': '2', | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-21 16:39:38 -07:00
										 |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_boto3_query_gsi_range_comparison(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '123', | 
					
						
							|  |  |  |         'username': 'johndoe', | 
					
						
							|  |  |  |         'created': 3, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '456', | 
					
						
							|  |  |  |         'username': 'johndoe', | 
					
						
							|  |  |  |         'created': 1, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '789', | 
					
						
							|  |  |  |         'username': 'johndoe', | 
					
						
							|  |  |  |         'created': 2, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '159', | 
					
						
							|  |  |  |         'username': 'janedoe', | 
					
						
							|  |  |  |         'created': 2, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |     table.put_item(Item={ | 
					
						
							|  |  |  |         'forum_name': 'the-key', | 
					
						
							|  |  |  |         'subject': '601', | 
					
						
							|  |  |  |         'username': 'janedoe', | 
					
						
							|  |  |  |         'created': 5, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Test a query returning all johndoe items | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key('username').eq('johndoe') & Key("created").gt(0), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         ScanIndexForward=True, | 
					
						
							|  |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     expected = ["456", "789", "123"] | 
					
						
							|  |  |  |     for index, item in enumerate(results['Items']): | 
					
						
							|  |  |  |         item["subject"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Return all johndoe items again, but in reverse | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key('username').eq('johndoe') & Key("created").gt(0), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         ScanIndexForward=False, | 
					
						
							|  |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     for index, item in enumerate(reversed(results['Items'])): | 
					
						
							|  |  |  |         item["subject"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Filter the creation to only return some of the results | 
					
						
							|  |  |  |     # And reverse order of hash + range key | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key("created").gt(1) & Key('username').eq('johndoe'), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         ConsistentRead=True, | 
					
						
							|  |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Filter to return no results | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key('username').eq('janedoe') & Key("created").gt(9), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key('username').eq('janedoe') & Key("created").eq(5), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     results['Count'].should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Test range key sorting | 
					
						
							|  |  |  |     results = table.query( | 
					
						
							| 
									
										
										
										
											2016-05-05 23:39:10 -04:00
										 |  |  |         KeyConditionExpression=Key('username').eq('johndoe') & Key("created").gt(0), | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |         IndexName='TestGSI', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     expected = [Decimal('1'), Decimal('2'), Decimal('3')] | 
					
						
							|  |  |  |     for index, item in enumerate(results['Items']): | 
					
						
							|  |  |  |         item["created"].should.equal(expected[index]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							| 
									
										
										
										
											2016-05-05 22:14:23 -04:00
										 |  |  | def test_boto3_update_table_throughput(): | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 6 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.provisioned_throughput['ReadCapacityUnits'].should.equal(5) | 
					
						
							|  |  |  |     table.provisioned_throughput['WriteCapacityUnits'].should.equal(6) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(ProvisionedThroughput={ | 
					
						
							|  |  |  |         'ReadCapacityUnits': 10, | 
					
						
							|  |  |  |         'WriteCapacityUnits': 11, | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.provisioned_throughput['ReadCapacityUnits'].should.equal(10) | 
					
						
							|  |  |  |     table.provisioned_throughput['WriteCapacityUnits'].should.equal(11) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							| 
									
										
										
										
											2016-05-05 22:14:23 -04:00
										 |  |  | def test_boto3_update_table_gsi_throughput(): | 
					
						
							| 
									
										
										
										
											2015-12-14 17:07:12 -07:00
										 |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         GlobalSecondaryIndexes=[{ | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'KeySchema': [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'username', | 
					
						
							|  |  |  |                     'KeyType': 'HASH', | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'created', | 
					
						
							|  |  |  |                     'KeyType': 'RANGE', | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'Projection': { | 
					
						
							|  |  |  |                 'ProjectionType': 'ALL', | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 3, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 4 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 6 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gsi_throughput = table.global_secondary_indexes[0]['ProvisionedThroughput'] | 
					
						
							|  |  |  |     gsi_throughput['ReadCapacityUnits'].should.equal(3) | 
					
						
							|  |  |  |     gsi_throughput['WriteCapacityUnits'].should.equal(4) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.provisioned_throughput['ReadCapacityUnits'].should.equal(5) | 
					
						
							|  |  |  |     table.provisioned_throughput['WriteCapacityUnits'].should.equal(6) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(GlobalSecondaryIndexUpdates=[{ | 
					
						
							|  |  |  |         'Update': { | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 10, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 11, | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Primary throughput has not changed | 
					
						
							|  |  |  |     table.provisioned_throughput['ReadCapacityUnits'].should.equal(5) | 
					
						
							|  |  |  |     table.provisioned_throughput['WriteCapacityUnits'].should.equal(6) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gsi_throughput = table.global_secondary_indexes[0]['ProvisionedThroughput'] | 
					
						
							|  |  |  |     gsi_throughput['ReadCapacityUnits'].should.equal(10) | 
					
						
							|  |  |  |     gsi_throughput['WriteCapacityUnits'].should.equal(11) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_table_gsi_create(): | 
					
						
							|  |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 6 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.global_secondary_indexes.should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(GlobalSecondaryIndexUpdates=[{ | 
					
						
							|  |  |  |         'Create': { | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'KeySchema': [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'username', | 
					
						
							|  |  |  |                     'KeyType': 'HASH', | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'created', | 
					
						
							|  |  |  |                     'KeyType': 'RANGE', | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'Projection': { | 
					
						
							|  |  |  |                 'ProjectionType': 'ALL', | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 3, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 4 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  |     table.global_secondary_indexes.should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gsi_throughput = table.global_secondary_indexes[0]['ProvisionedThroughput'] | 
					
						
							|  |  |  |     assert gsi_throughput['ReadCapacityUnits'].should.equal(3) | 
					
						
							|  |  |  |     assert gsi_throughput['WriteCapacityUnits'].should.equal(4) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Check update works | 
					
						
							|  |  |  |     table.update(GlobalSecondaryIndexUpdates=[{ | 
					
						
							|  |  |  |         'Update': { | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 10, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 11, | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }]) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gsi_throughput = table.global_secondary_indexes[0]['ProvisionedThroughput'] | 
					
						
							|  |  |  |     assert gsi_throughput['ReadCapacityUnits'].should.equal(10) | 
					
						
							|  |  |  |     assert gsi_throughput['WriteCapacityUnits'].should.equal(11) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(GlobalSecondaryIndexUpdates=[{ | 
					
						
							|  |  |  |         'Delete': { | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  |     table.global_secondary_indexes.should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_update_table_gsi_throughput(): | 
					
						
							|  |  |  |     dynamodb = boto3.resource('dynamodb', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Create the DynamoDB table. | 
					
						
							|  |  |  |     table = dynamodb.create_table( | 
					
						
							|  |  |  |         TableName='users', | 
					
						
							|  |  |  |         KeySchema=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'KeyType': 'HASH' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'KeyType': 'RANGE' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         GlobalSecondaryIndexes=[{ | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |             'KeySchema': [ | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'username', | 
					
						
							|  |  |  |                     'KeyType': 'HASH', | 
					
						
							|  |  |  |                 }, | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     'AttributeName': 'created', | 
					
						
							|  |  |  |                     'KeyType': 'RANGE', | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ], | 
					
						
							|  |  |  |             'Projection': { | 
					
						
							|  |  |  |                 'ProjectionType': 'ALL', | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             'ProvisionedThroughput': { | 
					
						
							|  |  |  |                 'ReadCapacityUnits': 3, | 
					
						
							|  |  |  |                 'WriteCapacityUnits': 4 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }], | 
					
						
							|  |  |  |         AttributeDefinitions=[ | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'forum_name', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 'AttributeName': 'subject', | 
					
						
							|  |  |  |                 'AttributeType': 'S' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |         ], | 
					
						
							|  |  |  |         ProvisionedThroughput={ | 
					
						
							|  |  |  |             'ReadCapacityUnits': 5, | 
					
						
							|  |  |  |             'WriteCapacityUnits': 6 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  |     table.global_secondary_indexes.should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table.update(GlobalSecondaryIndexUpdates=[{ | 
					
						
							|  |  |  |         'Delete': { | 
					
						
							|  |  |  |             'IndexName': 'TestGSI', | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |     }]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     table = dynamodb.Table('users') | 
					
						
							|  |  |  |     table.global_secondary_indexes.should.have.length_of(0) | 
					
						
							| 
									
										
										
										
											2016-03-01 11:30:35 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_dynamodb2 | 
					
						
							|  |  |  | def test_query_pagination(): | 
					
						
							|  |  |  |     table = _create_table_with_range_key() | 
					
						
							|  |  |  |     for i in range(10): | 
					
						
							|  |  |  |         table.put_item(Item={ | 
					
						
							|  |  |  |             'forum_name': 'the-key', | 
					
						
							|  |  |  |             'subject': '{0}'.format(i), | 
					
						
							|  |  |  |             'username': 'johndoe', | 
					
						
							|  |  |  |             'created': Decimal('3'), | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     page1 = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key'), | 
					
						
							|  |  |  |         Limit=6 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     page1['Count'].should.equal(6) | 
					
						
							|  |  |  |     page1['Items'].should.have.length_of(6) | 
					
						
							|  |  |  |     page1.should.have.key('LastEvaluatedKey') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     page2 = table.query( | 
					
						
							|  |  |  |         KeyConditionExpression=Key('forum_name').eq('the-key'), | 
					
						
							|  |  |  |         Limit=6, | 
					
						
							|  |  |  |         ExclusiveStartKey=page1['LastEvaluatedKey'] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     page2['Count'].should.equal(4) | 
					
						
							|  |  |  |     page2['Items'].should.have.length_of(4) | 
					
						
							|  |  |  |     page2.should_not.have.key('LastEvaluatedKey') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     results = page1['Items'] + page2['Items'] | 
					
						
							|  |  |  |     subjects = set([int(r['subject']) for r in results]) | 
					
						
							|  |  |  |     subjects.should.equal(set(range(10))) |