Merge pull request #2412 from joolean/issues/2189
Prevent overlapping expr name prefixes from corrupting projection expr
This commit is contained in:
commit
7a01b7ce9e
@ -356,9 +356,18 @@ class DynamoHandler(BaseResponse):
|
||||
|
||||
if projection_expression and expression_attribute_names:
|
||||
expressions = [x.strip() for x in projection_expression.split(',')]
|
||||
projection_expression = None
|
||||
for expression in expressions:
|
||||
if projection_expression is not None:
|
||||
projection_expression = projection_expression + ", "
|
||||
else:
|
||||
projection_expression = ""
|
||||
|
||||
if expression in expression_attribute_names:
|
||||
projection_expression = projection_expression.replace(expression, expression_attribute_names[expression])
|
||||
projection_expression = projection_expression + \
|
||||
expression_attribute_names[expression]
|
||||
else:
|
||||
projection_expression = projection_expression + expression
|
||||
|
||||
filter_kwargs = {}
|
||||
|
||||
|
@ -973,6 +973,53 @@ def test_query_filter():
|
||||
assert response['Count'] == 2
|
||||
|
||||
|
||||
@mock_dynamodb2
|
||||
def test_query_filter_overlapping_expression_prefixes():
|
||||
client = boto3.client('dynamodb', region_name='us-east-1')
|
||||
dynamodb = boto3.resource('dynamodb', region_name='us-east-1')
|
||||
|
||||
# Create the DynamoDB table.
|
||||
client.create_table(
|
||||
TableName='test1',
|
||||
AttributeDefinitions=[{'AttributeName': 'client', 'AttributeType': 'S'}, {'AttributeName': 'app', 'AttributeType': 'S'}],
|
||||
KeySchema=[{'AttributeName': 'client', 'KeyType': 'HASH'}, {'AttributeName': 'app', 'KeyType': 'RANGE'}],
|
||||
ProvisionedThroughput={'ReadCapacityUnits': 123, 'WriteCapacityUnits': 123}
|
||||
)
|
||||
|
||||
client.put_item(
|
||||
TableName='test1',
|
||||
Item={
|
||||
'client': {'S': 'client1'},
|
||||
'app': {'S': 'app1'},
|
||||
'nested': {'M': {
|
||||
'version': {'S': 'version1'},
|
||||
'contents': {'L': [
|
||||
{'S': 'value1'}, {'S': 'value2'},
|
||||
]},
|
||||
}},
|
||||
})
|
||||
|
||||
table = dynamodb.Table('test1')
|
||||
response = table.query(
|
||||
KeyConditionExpression=Key('client').eq('client1') & Key('app').eq('app1'),
|
||||
ProjectionExpression='#1, #10, nested',
|
||||
ExpressionAttributeNames={
|
||||
'#1': 'client',
|
||||
'#10': 'app',
|
||||
}
|
||||
)
|
||||
|
||||
assert response['Count'] == 1
|
||||
assert response['Items'][0] == {
|
||||
'client': 'client1',
|
||||
'app': 'app1',
|
||||
'nested': {
|
||||
'version': 'version1',
|
||||
'contents': ['value1', 'value2']
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@mock_dynamodb2
|
||||
def test_scan_filter():
|
||||
client = boto3.client('dynamodb', region_name='us-east-1')
|
||||
|
Loading…
Reference in New Issue
Block a user