Skip to content

Commit

Permalink
DynamoDB: KeyConditionExpression can have additional parentheses
Browse files Browse the repository at this point in the history
  • Loading branch information
bblommers committed Dec 28, 2024
1 parent cbc7a51 commit ebb9a4d
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 0 deletions.
4 changes: 4 additions & 0 deletions moto/dynamodb/parsing/key_condition_expression.py
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,10 @@ def parse_expression(
# (hash_key = :id) and (sortkey = :sk)
# ^
if current_stage in [EXPRESSION_STAGES.INITIAL_STAGE]:
if not current_phrase:
# hashkey = :id and (begins_with(sortkey, :sk))
# ^
continue
if current_phrase not in ["begins_with", ""]:
raise MockValidationException(
f"Invalid KeyConditionExpression: Invalid function name; function: {current_phrase}"
Expand Down
25 changes: 25 additions & 0 deletions tests/test_dynamodb/test_dynamodb_query.py
Original file line number Diff line number Diff line change
Expand Up @@ -867,3 +867,28 @@ def test_query_gsi_pagination_with_string_gsi_range_no_sk(table_name=None):
results = page1["Items"] + page2["Items"]
subjects = set([int(r["pk"]) for r in results])
assert subjects == set(range(10))


@pytest.mark.aws_verified
@dynamodb_aws_verified(add_range=True)
def test_key_condition_expression_with_brackets(table_name=None):
dynamodb = boto3.resource("dynamodb", region_name="us-east-1")
table = dynamodb.Table(table_name)

table.put_item(Item={"pk": "TEST", "sk": "aa"})
table.put_item(Item={"pk": "TEST", "sk": "ab"})
table.put_item(Item={"pk": "TEST", "sk": "ac"})

results = table.query(
KeyConditionExpression="(#0 = :0) AND (begins_with(#1, :1))",
ExpressionAttributeNames={"#0": "pk", "#1": "sk"},
ExpressionAttributeValues={":0": "TEST", ":1": "a"},
)
assert results["Count"] == 3

results = table.query(
KeyConditionExpression="(#0 = :0) AND (#1 BETWEEN :1 AND :2)",
ExpressionAttributeNames={"#0": "pk", "#1": "sk"},
ExpressionAttributeValues={":0": "TEST", ":1": "ab", ":2": "ab"},
)
assert results["Items"] == [{"pk": "TEST", "sk": "ab"}]

0 comments on commit ebb9a4d

Please sign in to comment.