Page MenuHomePhabricator

Move the "container updated" message for Buildables that build Diffs outside of the transaction
ClosedPublic

Authored by epriestley on Nov 15 2018, 12:10 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Dec 15, 6:17 PM
Unknown Object (File)
Sat, Nov 30, 5:26 PM
Unknown Object (File)
Nov 19 2024, 11:49 AM
Unknown Object (File)
Nov 14 2024, 11:09 PM
Unknown Object (File)
Nov 14 2024, 1:18 AM
Unknown Object (File)
Nov 10 2024, 4:15 PM
Unknown Object (File)
Nov 7 2024, 11:01 AM
Unknown Object (File)
Oct 26 2024, 10:16 PM
Subscribers
None

Details

Summary

Ref T13216. See PHI970. Ref T13054. See some discussion in T13216.

When a Harbormaster Buildable object is first created for a Diff, it has no containerPHID since the revision has not yet been created.

We later (after creating a revision) send the Buildable a message telling it that we've added a container and it should re-link the container object.

Currently, we send this message in applyExternalEffects(), which runs inside the Differential transaction. If Harbormaster races quickly enough, it can read the Diff object before the transaction commits, and not see the container update.

Add a didCommitTransaction() callback after the transactions commit, then move the message code there instead.

Test Plan
  • See T13216 for substantial evidence that this change is on the right track.
  • Before change: added sleep(15), reproduced the issue reliably.
  • After change: unable to reproduce issue even with sleep(15) (the containerPHID always populates correctly).

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Harbormaster returned this revision to the author for changes because remote builds failed.Nov 15 2018, 12:11 AM
Harbormaster failed remote builds in B21150: Diff 47301!

Stacked on qsprintf() changes.

(This also has a couple of unrelated qsprintf() changes: they reproduce by visiting the Daemon console and the changes cleared the warnings.)

This revision is now accepted and ready to land.Nov 16 2018, 7:20 PM