Skip to content

Commit

Permalink
Fix bounded trie merge when merging on empty trie
Browse files Browse the repository at this point in the history
  • Loading branch information
rohitsinha54 committed Jan 2, 2025
1 parent d9092a5 commit 6d85b06
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 1 deletion.
2 changes: 1 addition & 1 deletion sdks/python/apache_beam/metrics/cells.py
Original file line number Diff line number Diff line change
Expand Up @@ -740,7 +740,7 @@ def merge(self, other: '_BoundedTrieNode') -> int:
delta = 0
elif not self._children:
self._children = other._children
delta = self._size - other._size
delta = other._size - self._size
else:
delta = 0
other_child: '_BoundedTrieNode'
Expand Down
24 changes: 24 additions & 0 deletions sdks/python/apache_beam/metrics/cells_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -420,6 +420,30 @@ def test_bounded_trie_data_combine_trim(self):
BoundedTrieData(root=right, bound=3)).get_result(),
set([('a', True), ('b', 'd', False), ('c', 'd', False)]))

def test_merge_on_empty_node(self):
root1 = _BoundedTrieNode()
root2 = _BoundedTrieNode()
root2.add_all([
["a", "b", "c"],
["a", "b", "d"],
["a", "e"]
])
self.assertEqual(2, root1.merge(root2))
self.assertEqual(3, root1.size())
self.assertFalse(root1._truncated)

def test_merge_with_empty_node(self):
root1 = _BoundedTrieNode()
root1.add_all([
["a", "b", "c"],
["a", "b", "d"],
["a", "e"]
])
root2 = _BoundedTrieNode()

self.assertEqual(0, root1.merge(root2))
self.assertEqual(3, root1.size())
self.assertFalse(root1._truncated)

if __name__ == '__main__':
unittest.main()

0 comments on commit 6d85b06

Please sign in to comment.