Bug 29728

Summary: ContactManager::addGroup and removeGroup are confusing/broken
Product: Telepathy Reporter: Olli Salli <ollisal>
Component: tp-qtAssignee: Telepathy bugs list <telepathy-bugs>
Status: RESOLVED FIXED QA Contact: Telepathy bugs list <telepathy-bugs>
Severity: minor    
Priority: medium    
Version: git master   
Hardware: All   
OS: All   
Whiteboard:
i915 platform: i915 features:

Description Olli Salli 2010-08-21 09:27:11 UTC
ContactManager::addGroup is described as "Attempt to add an user-defined contact list group". Therefore, (and judging from the naming), one would expect that after the returned PendingOperation has finished successfully, the group would have actually been added (I know, right?), and would be usable for eg. adding contacts to it.

In reality however, the PendingOperation finishes as soon as the underlying EnsureChannel D-Bus call to the CM has returned. While this is, indeed, when the group is actually added at the CM level, at this point the ContactManager internals still haven't picked up the new group, and, for example, trying to add a contact to the seemingly newly-added group fails! A work-around is to wait for the groupAdded signal for the group in question - but this is really error-prone, as the signal may well have been emitted already (and will be, if we fix this bug properly)!

The fix would be to make a private PendingOperation subclass, which would first make the EnsureChannel call, and if that's successful, and the new group hasn't been picked up yet, wait for the new group to be picked up (by the groupAdded() signal) before finishing. Then, the operation being finished() would truly mean that the group is now usable by the usual methods manipulating it.

Similarly, the removeGroup PendingOperation returns as soon as the Channel's Close method has returned (and the group has been removed from the server). However, contacts can still seemingly be added to the group etc. until the channel being invalidated is picked up by the ContactManager internals, and groupRemoved() is emitted (probably in the next few mainloop iterations)! This is less of a problem though, as you generally shouldn't need to worry about a removed group anymore - it's still confusing however, as the PendingOperation to eg. add a contact to a group in this state will probably fail with "The method AddMembers on bahbah interface doesn't exist" (because the Channel doesn't exist anymore) instead of the intended "The group doesn't exist".

The fix for this, then, is obviously waiting for groupRemoved in the removeGroup PendingOperation if the group still exists in the ContactManager internals after the Channel has been closed.
Comment 1 Olli Salli 2010-08-21 09:39:43 UTC
Waiting for groupAdded() is especially error-prone when adding multiple groups at a time. If the PendingOperations would actually finish at an useful time, the application could add whatever it wanted to the groups when the finished signal for the desired group would be emitted. However, now that it has to (probably) wait for groupAdded(), it has to take care to ignore groupAdded for the other added groups when waiting to be able to add to a desired group, but also cater for other callbacks to be able to pick up the other groups.
Comment 2 Olli Salli 2010-12-30 06:46:11 UTC
Andre's new code using the Connection.Interface.RosterGroups API fixes this. Will be in 0.5.2.

Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.