You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The AutoGenerateUUIDExtension was incorrectly overriding existing UUID values for items that already contained non-empty values.
This caused some major issues while I working on a project by using DynamoDbTable.updateItem() method. This method didn't update the existing record instead it saves a new record with auto-generated values. When I debuged the code I found the issue is nit with updateItem() method but with the extension. When I tag partition key attribute with tag @DynamoDbAutoGeneratedUuid. I will never be able to update existing record in the Db using updateItem() method.
Regression Issue
Select this option if this issue appears to be a regression.
Expected Behavior
When provided an an object of DynamoDbBean.
Expected: when you try to update an existing record on the DB. it updates the record as per the attributes provided by the user operation.
Current Behavior
Current: Instead of updating the existing record, the operation saves a new record onto the DB
6. Attempt creating table using the above API and then save a record by providing body
{
"customerName": "XXYYZZ"
}
After record creation you will receive a save records copy as response
{
"customerId": "623bc3df-579f-4b3d-841e-bed00cfeea0f",
"customerName": "XXYYZZ", //modify to send as body again"createdDate": "2024-11-09T08:09:45.479307200Z"
}
using the modified response as body hit the /createRecord again it should updated the existing record. Instead it creates a new record.
6. Attempt to Update an Existing Record
Create a new MyEntity object, save it using updateItem().
Modify the object's attributes (except for the partition key).
Use updateItem() again to update the record in DynamoDB.
Expected Behavior
The updateItem() method should update the existing record with new attribute values.
Actual Behavior
Bug: The @DynamoDbAutoGeneratedUuid annotation overrides the existing partition key.
The updateItem() method creates a new record instead of updating the existing one.
Summary
The issue is caused by the @DynamoDbAutoGeneratedUuid tag which regenerates the UUID during updateItem() calls, leading to unintended new record creation instead of updating existing entries.
Possible Solution
No response
Additional Information/Context
No response
AWS Java SDK version used
2.29.1
JDK version used
21
Operating System and version
windows 11 23H2
The text was updated successfully, but these errors were encountered:
Hi @Boyapati36 thank you for reporting this issue, I can reproduce.
Right now, the bug we are considering is the fact that @DynamoDbAutoGeneratedUuid and UpdateBehavior.WRITE_IF_NOT_EXISTS don't work with partition keys. @DynamoDbAutoGeneratedUuid itself is supposed to get a new value with every write, according to the documentation:
Every time a record with this attribute is written to the database it will update the attribute with a UUID.randomUUID() string
In your PR, the change you are proposing is a breaking change, it would impact customers that may be relying on this behavior. Let us know if you'd be interested in making the change more backwards compatible, we can discuss options. We appreciate your PR.
Describe the bug
The AutoGenerateUUIDExtension was incorrectly overriding existing UUID values for items that already contained non-empty values.
This caused some major issues while I working on a project by using DynamoDbTable.updateItem() method. This method didn't update the existing record instead it saves a new record with auto-generated values. When I debuged the code I found the issue is nit with updateItem() method but with the extension. When I tag partition key attribute with tag @DynamoDbAutoGeneratedUuid. I will never be able to update existing record in the Db using updateItem() method.
Regression Issue
Expected Behavior
When provided an an object of DynamoDbBean.
Expected: when you try to update an existing record on the DB. it updates the record as per the attributes provided by the user operation.
Current Behavior
Current: Instead of updating the existing record, the operation saves a new record onto the DB
Reproduction Steps
DynamoDB Bug Replication Steps: Auto-Generated UUID Overwriting Issue
Prerequisites
Steps to Reproduce the Issue
1. Create a DynamoDB Entity (Model)
Create a DynamoDB bean using Lombok annotations:
2. Configure DynamoDB Enhanced Client Bean
Create a
DynamoDbEnhancedClient
bean in your Spring Boot configuration:3. Create a DynamoDB Table Bean
Create a
DynamoDbTable<MyEntity>
using theDynamoDbEnhancedClient
:4. Create a controller endpoints for table creation and record saving/updating
6. Attempt creating table using the above API and then save a record by providing body
After record creation you will receive a save records copy as response
using the modified response as body hit the /createRecord again it should updated the existing record. Instead it creates a new record.
6. Attempt to Update an Existing Record
MyEntity
object, save it usingupdateItem()
.updateItem()
again to update the record in DynamoDB.Expected Behavior
updateItem()
method should update the existing record with new attribute values.Actual Behavior
@DynamoDbAutoGeneratedUuid
annotation overrides the existing partition key.updateItem()
method creates a new record instead of updating the existing one.Summary
The issue is caused by the
@DynamoDbAutoGeneratedUuid
tag which regenerates the UUID duringupdateItem()
calls, leading to unintended new record creation instead of updating existing entries.Possible Solution
No response
Additional Information/Context
No response
AWS Java SDK version used
2.29.1
JDK version used
21
Operating System and version
windows 11 23H2
The text was updated successfully, but these errors were encountered: