Merge pull request #504 from pcraciunoiu/feature/update-item-types-and-test
Support for other UPDATE DynamoTypes and query Select=COUNT
This commit is contained in:
commit
bb103d1688
@ -124,11 +124,20 @@ class Item(object):
|
|||||||
def update_with_attribute_updates(self, attribute_updates):
|
def update_with_attribute_updates(self, attribute_updates):
|
||||||
for attribute_name, update_action in attribute_updates.items():
|
for attribute_name, update_action in attribute_updates.items():
|
||||||
action = update_action['Action']
|
action = update_action['Action']
|
||||||
|
if action == 'DELETE' and not 'Value' in update_action:
|
||||||
|
del self.attrs[attribute_name]
|
||||||
|
continue
|
||||||
new_value = list(update_action['Value'].values())[0]
|
new_value = list(update_action['Value'].values())[0]
|
||||||
if action == 'PUT':
|
if action == 'PUT':
|
||||||
# TODO deal with other types
|
# TODO deal with other types
|
||||||
if isinstance(new_value, list) or isinstance(new_value, set):
|
if isinstance(new_value, list) or isinstance(new_value, set):
|
||||||
self.attrs[attribute_name] = DynamoType({"SS": new_value})
|
self.attrs[attribute_name] = DynamoType({"SS": new_value})
|
||||||
|
elif isinstance(new_value, dict):
|
||||||
|
self.attrs[attribute_name] = DynamoType({"M": new_value})
|
||||||
|
elif update_action['Value'].keys() == ['N']:
|
||||||
|
self.attrs[attribute_name] = DynamoType({"N": new_value})
|
||||||
|
elif update_action['Value'].keys() == ['NULL']:
|
||||||
|
del self.attrs[attribute_name]
|
||||||
else:
|
else:
|
||||||
self.attrs[attribute_name] = DynamoType({"S": new_value})
|
self.attrs[attribute_name] = DynamoType({"S": new_value})
|
||||||
|
|
||||||
|
@ -330,9 +330,10 @@ class DynamoHandler(BaseResponse):
|
|||||||
|
|
||||||
result = {
|
result = {
|
||||||
"Count": len(items),
|
"Count": len(items),
|
||||||
"Items": [item.attrs for item in items],
|
|
||||||
"ConsumedCapacityUnits": 1,
|
"ConsumedCapacityUnits": 1,
|
||||||
}
|
}
|
||||||
|
if self.body.get('Select', '').upper() != 'COUNT':
|
||||||
|
result["Items"] = [item.attrs for item in items]
|
||||||
|
|
||||||
# Implement this when we do pagination
|
# Implement this when we do pagination
|
||||||
# if not last_page:
|
# if not last_page:
|
||||||
|
@ -735,9 +735,7 @@ def test_boto3_conditions():
|
|||||||
results['Count'].should.equal(1)
|
results['Count'].should.equal(1)
|
||||||
|
|
||||||
|
|
||||||
|
def _create_table_with_range_key():
|
||||||
@mock_dynamodb2
|
|
||||||
def test_boto3_query_gsi_range_comparison():
|
|
||||||
dynamodb = boto3.resource('dynamodb', region_name='us-east-1')
|
dynamodb = boto3.resource('dynamodb', region_name='us-east-1')
|
||||||
|
|
||||||
# Create the DynamoDB table.
|
# Create the DynamoDB table.
|
||||||
@ -788,7 +786,52 @@ def test_boto3_query_gsi_range_comparison():
|
|||||||
'WriteCapacityUnits': 5
|
'WriteCapacityUnits': 5
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
table = dynamodb.Table('users')
|
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'
|
||||||
|
},
|
||||||
|
'created': {
|
||||||
|
'Action': u'PUT',
|
||||||
|
'Value': Decimal('4'),
|
||||||
|
},
|
||||||
|
'mapfield': {
|
||||||
|
'Action': u'PUT',
|
||||||
|
'Value': {'key': 'value'},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
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({
|
||||||
|
'username': "johndoe2",
|
||||||
|
'forum_name': 'the-key',
|
||||||
|
'subject': '123',
|
||||||
|
'created': '4',
|
||||||
|
'mapfield': {'key': 'value'},
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
@mock_dynamodb2
|
||||||
|
def test_boto3_query_gsi_range_comparison():
|
||||||
|
table = _create_table_with_range_key()
|
||||||
|
|
||||||
table.put_item(Item={
|
table.put_item(Item={
|
||||||
'forum_name': 'the-key',
|
'forum_name': 'the-key',
|
||||||
|
Loading…
Reference in New Issue
Block a user