Page MenuHomePhabricator

Conpherence - change message rendering logic to eradicate possibility of duplicates
ClosedPublic

Authored by btrahan on May 12 2015, 11:20 PM.
Tags
None
Referenced Files
F14813083: D12819.id30825.diff
Mon, Jan 27, 9:57 AM
Unknown Object (File)
Fri, Jan 24, 7:02 PM
Unknown Object (File)
Fri, Jan 24, 2:32 PM
Unknown Object (File)
Fri, Jan 24, 4:26 AM
Unknown Object (File)
Fri, Jan 24, 4:26 AM
Unknown Object (File)
Sat, Jan 18, 12:44 AM
Unknown Object (File)
Thu, Jan 16, 9:20 PM
Unknown Object (File)
Mon, Jan 6, 3:31 AM
Subscribers

Details

Summary

Fixes T6713. Before this diff, we would update the DOM when various requests came back, but the logic to erase race conditions proved too tricky for me to get right. Instead, change the algorithm up and keep a set of transaction ids around per thread. When its time to update the transactions, sort the list of ids and just render the whole darn set again.

To make this work, this ends up adding transacton ids to fake transactons like "show older" and date markers. This is able to work by using a float sort and giving these transactions ids that are .5 from being an integer and in the right place numerically.

Test Plan

for durable column, clicked show older and it worked. sent a message and it worked. for main view, clicked show older and it worked. sent a message and it worked.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

btrahan retitled this revision from to Conpherence - change message rendering logic to eradicate possibility of duplicates.
btrahan updated this object.
btrahan edited the test plan for this revision. (Show Details)
btrahan added a reviewer: epriestley.
epriestley edited edge metadata.
epriestley added inline comments.
webroot/rsrc/js/application/conpherence/ConpherenceThreadManager.js
119

omg

This revision is now accepted and ready to land.May 12 2015, 11:48 PM
btrahan edited edge metadata.
  • refactor sort function to reduce likelihood of future developers taking the lord's name in vain reviewing the code
  • and rebase
  • and celerity map
This revision was automatically updated to reflect the committed changes.