Page MenuHomePhabricator

Allow maintenance scripts to write synthetic events to the push log that act as repository updates
ClosedPublic

Authored by epriestley on Jun 1 2021, 1:50 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Mar 5, 10:02 AM
Unknown Object (File)
Fri, Feb 23, 3:41 PM
Unknown Object (File)
Feb 13 2024, 4:56 AM
Unknown Object (File)
Feb 4 2024, 1:01 AM
Unknown Object (File)
Dec 27 2023, 11:38 AM
Unknown Object (File)
Dec 22 2023, 11:51 PM
Unknown Object (File)
Nov 29 2023, 11:17 PM
Unknown Object (File)
Nov 29 2023, 7:07 PM
Subscribers
None

Details

Summary

Ref T13614. When a script holds the write lock but modifies the repository directly (rather than by pushing), the repository version won't change when the script releases the write lock. Thus, the writes may not propagate to other nodes (it depends which node lucks out and accepts the next write).

To guarantee that writes propagate, allow these scripts to pretend they pushed the repository. These are bare-bones valid events flagged as "Maintenance".

Test Plan
  • Wrote a script to hold the write lock, wait (or pretend to do something), then release the write lock.
  • Applied patches, modified script to use new APIs ("newMaintenanceEvent()").
  • Ran script, saw repository verison bump and relevant push logs:

Screen Shot 2021-06-01 at 6.44.02 AM.png (176×1 px, 48 KB)

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

This revision was not accepted when it landed; it landed in state Needs Review.Jun 1 2021, 3:30 PM
This revision was automatically updated to reflect the committed changes.