From: Thomas Fitzsimmons Date: Wed, 27 Mar 2013 20:14:57 +0000 (-0400) Subject: dbus/dbus-object-tree.c: Add test case for parent removal fix X-Git-Tag: dbus-1.7.6~43^2~4 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d4afe1b80fda8657a8166f0ca6b985afdeb46f33;p=thirdparty%2Fdbus.git dbus/dbus-object-tree.c: Add test case for parent removal fix --- diff --git a/dbus/dbus-object-tree.c b/dbus/dbus-object-tree.c index 14061e8a6..8ae0f2398 100644 --- a/dbus/dbus-object-tree.c +++ b/dbus/dbus-object-tree.c @@ -2127,6 +2127,17 @@ object_tree_test_iteration (void *data) _dbus_assert (!find_subtree_registered_or_unregistered (tree, path1)); _dbus_assert (find_subtree_registered_or_unregistered (tree, path0)); + /* Test freeing a long path */ + if (!do_register (tree, path3, TRUE, 3, tree_test_data)) + goto out; + + _dbus_object_tree_unregister_and_unlock (tree, path3); + _dbus_assert (!find_subtree (tree, path3, NULL)); + _dbus_assert (!find_subtree_registered_or_unregistered (tree, path3)); + _dbus_assert (!find_subtree_registered_or_unregistered (tree, path2)); + _dbus_assert (!find_subtree_registered_or_unregistered (tree, path1)); + _dbus_assert (find_subtree_registered_or_unregistered (tree, path0)); + /* Register it all again, and test dispatch */ if (!do_register (tree, path0, TRUE, 0, tree_test_data))