Page MenuHomePhabricator

Fix race condition inside `git diff-files`
ClosedPublic

Authored by epriestley on Jun 18 2014, 12:11 AM.
Tags
None
Referenced Files
F15412555: D9616.id.diff
Wed, Mar 19, 1:40 PM
F15403237: D9616.id23052.diff
Tue, Mar 18, 2:22 AM
F15400374: D9616.id23052.diff
Mon, Mar 17, 11:18 AM
F15297747: D9616.id23052.diff
Wed, Mar 5, 12:33 PM
Unknown Object (File)
Feb 9 2025, 1:41 PM
Unknown Object (File)
Feb 9 2025, 1:41 PM
Unknown Object (File)
Feb 9 2025, 1:41 PM
Unknown Object (File)
Feb 9 2025, 1:41 PM
Subscribers

Details

Summary

There's some sort of race inside git here, where the git diff-files command exits with different results some of the time when run in parallel with git ls-files or git diff (running either command was sufficient to trigger the race).

Run it separately to avoid the race.

I poked around the git source a little bit but quickly lost interest given that the issue seems fixed and this workaround is essentially reasonable.

Test Plan

Ran test 20x in a row without failures.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

epriestley retitled this revision from to Fix race condition inside `git diff-files`.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: hach-que.
hach-que edited edge metadata.

Ran it 5x in a row, no problemo.

This revision is now accepted and ready to land.Jun 18 2014, 6:45 AM
epriestley updated this revision to Diff 23066.

Closed by commit rARCdd1f93d77b5f (authored by @epriestley).