Commit cd0089c
committed
Fix "Specified HEAD didn't match actual HEAD^{tree}" error on branch apply
Telemetry showed users hitting this error when applying a branch. It's
caused by a race condition: `apply()` reads `prev_head_id` from the
workspace graph and passes it to `safe_checkout`, but between those two
calls the file watcher can run `update_workspace_commit`, which moves
the `gitbutler/workspace` ref to a new commit with a different tree.
Inside `merge_worktree_changes_into_destination_or_keep_snapshot`, the
caller's stale `source_tree_id` was compared against
`repo.head_tree_id_or_empty()` and the mismatch triggered a `bail!()`.
The fix removes that assertion and always reads the tree from
`repo.head_tree_id_or_empty()`. This is correct because worktree diffs
(via the git index) are always relative to the actual HEAD tree, not
whatever the caller cached — so the snapshot base must match.
Includes regression test:
`checkout_succeeds_when_source_tree_diverges_from_head`
Remove unused source_tree_id parameter
Remove the now-unused source_tree_id parameter from
merge_worktree_changes_into_destination_or_keep_snapshot and its
callers. The parameter was unused in the function body and
documentation, so eliminating it cleans up the function signature,
related docs, and the call site in function.rs to avoid passing an
unnecessary value. This simplifies the API and reduces confusion about
the expected inputs.1 parent 577e759 commit cd0089c
3 files changed
Lines changed: 88 additions & 10 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
77 | | - | |
78 | 77 | | |
79 | 78 | | |
80 | 79 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
36 | 36 | | |
37 | 37 | | |
38 | 38 | | |
39 | | - | |
40 | | - | |
41 | | - | |
42 | 39 | | |
43 | 40 | | |
44 | 41 | | |
| |||
64 | 61 | | |
65 | 62 | | |
66 | 63 | | |
67 | | - | |
68 | 64 | | |
69 | 65 | | |
70 | 66 | | |
| |||
76 | 72 | | |
77 | 73 | | |
78 | 74 | | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
84 | 80 | | |
85 | 81 | | |
86 | 82 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1086 | 1086 | | |
1087 | 1087 | | |
1088 | 1088 | | |
| 1089 | + | |
| 1090 | + | |
| 1091 | + | |
| 1092 | + | |
| 1093 | + | |
| 1094 | + | |
| 1095 | + | |
| 1096 | + | |
| 1097 | + | |
| 1098 | + | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
| 1102 | + | |
| 1103 | + | |
| 1104 | + | |
| 1105 | + | |
| 1106 | + | |
| 1107 | + | |
| 1108 | + | |
| 1109 | + | |
| 1110 | + | |
| 1111 | + | |
| 1112 | + | |
| 1113 | + | |
| 1114 | + | |
| 1115 | + | |
| 1116 | + | |
| 1117 | + | |
| 1118 | + | |
| 1119 | + | |
| 1120 | + | |
| 1121 | + | |
| 1122 | + | |
| 1123 | + | |
| 1124 | + | |
| 1125 | + | |
| 1126 | + | |
| 1127 | + | |
| 1128 | + | |
| 1129 | + | |
| 1130 | + | |
| 1131 | + | |
| 1132 | + | |
| 1133 | + | |
| 1134 | + | |
| 1135 | + | |
| 1136 | + | |
| 1137 | + | |
| 1138 | + | |
| 1139 | + | |
| 1140 | + | |
| 1141 | + | |
| 1142 | + | |
| 1143 | + | |
| 1144 | + | |
| 1145 | + | |
| 1146 | + | |
| 1147 | + | |
| 1148 | + | |
| 1149 | + | |
| 1150 | + | |
| 1151 | + | |
| 1152 | + | |
| 1153 | + | |
| 1154 | + | |
| 1155 | + | |
| 1156 | + | |
| 1157 | + | |
| 1158 | + | |
| 1159 | + | |
| 1160 | + | |
| 1161 | + | |
| 1162 | + | |
| 1163 | + | |
| 1164 | + | |
| 1165 | + | |
| 1166 | + | |
| 1167 | + | |
| 1168 | + | |
| 1169 | + | |
| 1170 | + | |
| 1171 | + | |
1089 | 1172 | | |
1090 | 1173 | | |
1091 | 1174 | | |
| |||
0 commit comments