Page MenuHomePhabricator

Allow diff change detection to complete for Mercurial changes which remove a binary file
ClosedPublic

Authored by epriestley on Jan 29 2019, 5:15 PM.
Tags
None
Referenced Files
F18804431: D20056.id47891.diff
Sat, Oct 18, 8:16 AM
F18710927: D20056.diff
Mon, Sep 29, 3:21 AM
F18674864: D20056.id.diff
Thu, Sep 25, 4:36 PM
F18669354: D20056.diff
Wed, Sep 24, 8:10 PM
F18566946: D20056.id.diff
Sep 9 2025, 3:02 PM
F18459026: D20056.id.diff
Sep 1 2025, 4:04 PM
F18234766: D20056.id47924.diff
Aug 20 2025, 6:34 PM
F18234625: D20056.diff
Aug 20 2025, 6:21 PM
Subscribers
None

Details

Summary

See PHI1044. When you push a commit, we try to detect if the diff is the same as the last diff in Differential. This is a soft/heuristic check and only used to provide a hint in email ("CHANGED SINCE LAST DIFF").

For some changes, we can end up on this pathway with a binary changeset for a deleted file in the commit, and try to fetch the file data. This will fail since the file has been deleted. I'm not entirely sure why this hasn't cropped up before and didn't try to truly build an end-to-end test case, but it's a valid state that we shouldn't fatal in.

When we get here in this state, just detect a change. This is safe, even if it isn't always correct.

(This will be revisited in the future so I'm favoring fixing the broken behavior for now.)

Test Plan

This required some rigging, but I modified bin/differential extract to run the isDiffChangedBeforeCommit() code, then rigged a commit/diff to hit this case and reproduced the reported error. After the change, the comparison worked cleanly.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable