You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
As @warsaw discovered the hard way on python/cpython#101024 , if pushing the branch to the selected (or default) remote fails for any reason (e.g. attempting to push to upstream instead of origin, as happened here), the branch is deleted anyway instead instead of issuing a clear error message and existing with it intact. This results in potentially loosing a large amount of hard, tedious work manually resolving backport conflicts (unless the user is a Git expert who knows how to recover it via git reflog), and is a very frustrating and unfriendly user experience.
Full error output from Barry
% cherry_picker --continuegit switch🐍 🍒 ⛏Failed to push to origin ☹remote: error: GH006: Protected branch update failed for refs/heads/backport-49cae39-3.10. remote: error: You're not authorized to push to this branch. Visit https://docs.github.com/articles/about-protected-branches/ for more information. To github.com:python/cpython.git ! [remote rejected] backport-49cae39-3.10 -> backport-49cae39-3.10 (protected branch hook declined)error: failed to push some refs to 'github.com:python/cpython.git'branch backport-49cae39-3.10 has been deleted.Backport PR:[3.10] gh-101021: Document binary parameters as bytes (GH-101024).(cherry picked from commit 49cae39ef020eaf242607bb2d2d193760b9855a6)Co-authored-by: Bob Kline <bkline@users.noreply.github.com>
I'm not sure the best way to fix this within Cherry_Picker's error handling and UX design, but the most obvious solution is to just have it raise e.g. RuntimeError and exit instead. There may be other situations where this happens as well, so it might be worth investigating any other known failure codepaths further.
As a sidenote I also discovered after much trial and error that you need to pass --no-auto-pr and --pr-remote upstream every time you call cherry picker --continue to get it to work, instead of it being stored in .gitconfig. This is very unintiuitve, and could also potentially lead to this error as well.
Also, calling --dry-run --continue in the middle of a cherry pick to see what it would do next completely borks things, and requires wiping the config and starting over to recover.
The text was updated successfully, but these errors were encountered:
For anyone else that hits this, remember that git reflog will give you the commit hash of the deleted branch, allowing you to retrieve it and make a new PR branch without losing any manual conflict resolution work.
To this point, I also recommend doing git config --global rerere.enabled true additionally, which instructs Git to memorize a lot of recent conflict resolutions, re-applying them if they are met again.
As @warsaw discovered the hard way on python/cpython#101024 , if pushing the branch to the selected (or default) remote fails for any reason (e.g. attempting to push to
upstream
instead oforigin
, as happened here), the branch is deleted anyway instead instead of issuing a clear error message and existing with it intact. This results in potentially loosing a large amount of hard, tedious work manually resolving backport conflicts (unless the user is a Git expert who knows how to recover it viagit reflog
), and is a very frustrating and unfriendly user experience.Full error output from Barry
If pushing fails, the PUSHING_TO_REMOTE_FAILED state is set https://github.com/python/cherry-picker/blob/main/cherry_picker/cherry_picker.py#L407, but then push_to_remote just returns and the branch is deleted regardless of the state https://github.com/python/cherry-picker/blob/main/cherry_picker/cherry_picker.py#L521 . As far as I can tell, setting the PUSHING_TO_REMOTE_FAILED state has no effect and cherry-picker just continues and terminates normally regardless.
I'm not sure the best way to fix this within Cherry_Picker's error handling and UX design, but the most obvious solution is to just have it raise e.g.
RuntimeError
and exit instead. There may be other situations where this happens as well, so it might be worth investigating any other known failure codepaths further.As a sidenote I also discovered after much trial and error that you need to pass
--no-auto-pr
and--pr-remote upstream
every time you callcherry picker --continue
to get it to work, instead of it being stored in.gitconfig
. This is very unintiuitve, and could also potentially lead to this error as well.Also, calling
--dry-run --continue
in the middle of a cherry pick to see what it would do next completely borks things, and requires wiping the config and starting over to recover.The text was updated successfully, but these errors were encountered: