Merge lp://staging/~cmiller/desktopcouch/cpu-usage-replication into lp://staging/desktopcouch

Proposed by Chad Miller
Status: Merged
Approved by: dobey
Approved revision: 282
Merged at revision: 279
Proposed branch: lp://staging/~cmiller/desktopcouch/cpu-usage-replication
Merge into: lp://staging/desktopcouch
Diff against target: 85 lines (+21/-1)
4 files modified
desktopcouch/application/plugins/tests/test_ubuntuone_pairing.py (+3/-0)
desktopcouch/application/plugins/ubuntuone_pairing.py (+13/-1)
desktopcouch/application/service.py (+1/-0)
desktopcouch/application/tests/test_service.py (+4/-0)
To merge this branch: bzr merge lp://staging/~cmiller/desktopcouch/cpu-usage-replication
Reviewer Review Type Date Requested Status
dobey (community) Approve
Roman Yepishev (community) fieldtest Approve
Eric Casteleijn (community) Approve
Review via email: mp+68462@code.staging.launchpad.net

Commit message

Slow down the idle-run function that checks for whether all the blocking semaphores are completed. gobject may call this every chance it gets, which pegs the CPU.

Catch the signal from the service that indicates no response is ever coming, CredentialsNotFound. Don't wait for timeout. Also, in cases where there is no response from the ubuntu-sso client, continue with execution. A dbus method call is waiting on us to complete, probably. desktopcouch can operate without ubuntuone support, so we shouldn't deny it from running altogether.

To post a comment you must log in.
Revision history for this message
Eric Casteleijn (thisfred) wrote :

Looks good.

review: Approve
Revision history for this message
Roman Yepishev (rye) wrote :

During my tests it takes 20 seconds to start replying to the dbus getPort() even when all the databases are already in disk cache. Could you please check whether this is happening on your installation too?

review: Needs Information (fieldtest)
Revision history for this message
Roman Yepishev (rye) wrote :

Looks awesome!

review: Approve (fieldtest)
Revision history for this message
dobey (dobey) wrote :

56 +
57 + gobject.timeout_add(TIMEOUT_SEC*1000, blocking_semaphores.discard,
58 + PLUGIN_NAME)

You should drop the *1000 here and use timeout_add_seconds() instead. Using add_seconds instead, results in timeouts getting aligned, so that number of wakeups is reduced.

review: Needs Fixing
Revision history for this message
dobey (dobey) :
review: Approve
Revision history for this message
Ubuntu One Auto Pilot (otto-pilot) wrote :

There are additional revisions which have not been approved in review. Please seek review and approval of these new revisions.

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
The diff is not available at this time. You can reload the page or download it.

Subscribers

People subscribed via source and target branches