[PropertyDDS] Relax error handling for removal of non-existent keys (PR-008) #26157
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This PR modifies the error handling behavior in IndexedCollectionBaseProperty to prevent client crashes when attempting to remove a key that does not exist. Instead of throwing a critical PR-008 error, the system will now log a warning and continue execution.
Problem
Solution
The
_removeByKeymethod inIndexedCollectionBasePropertyhas been updated to:Warn instead of Throw: When a non-existent key removal is attempted, it now logs
console.warn(MSG.REMOVED_NON_EXISTING_ENTRY + in_key)instead of throwing an error.Breaking Changes
This PR introduces a breaking change to the behavior of
remove()methods in PropertyDDS collection types (MapProperty,ReferenceMapProperty,SetProperty).Previous Behavior
Error: PR-008: Trying to remove a non-existing entry: <key>New Behavior
PR-008: Trying to remove a non-existing entry: <key>undefined(instead of throwing)Migration Impact
Code that relies on errors being thrown will need to be updated: