-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
TODO: Attempt to rebase human commits instead of failing immediately #10
Comments
We used to have some form of rebasing before this commit 91d1f66 - which removed it as iirc it was very broken, but old implementation probably still worth referencing |
What were the main reasons why old implementation was broken, does anybody remember?) |
It didn't handle conflicts at all, resulting in broken state. |
Ok, thanks. I'm trying to understand the current behavior of
So, if the stated above is correct,
|
Btw what is the logic for aborting update in case of human commits in the update branch? What errors will happen if we remove this check? |
Yes
It resets the update branch to master every time, regardless of changes in master. I.e. it disregards the remote update branch state. It's basically
|
No errors will happen, but human commits may potentially be orphaned, and we presume that human commits are imporant and worth keeping, even at the cost of failing to update. I guess it might kinda make sense to simply remove this check and let update-daemon force-push over human commits, and then let humans do the rebasing manually, but it would be annoying. |
Problem: Currently when there are human commits in update branch, update bot reports an error. Solution: Rebase current changes in remote update branch on top of remote default branch if possible. Otherwise report an error.
Problem: bot doesn't checkout to a sensible branch after a rebase fail. Solution: checkout to default branch. Note: currently an error "rebase patch already applied" occurs. Needs to be fixed.
Problem: if the default branch is updated while an update branch exists, the update branch won't be automatically rebased. Solution: in lieu of a proper rebase, which is hard, reset the update branch to the default, as we'll have to force-push anyway, and there's not much to rebase if there are no human commits to begin with.
Problem: currently, when there are human commits in the update branch, we just bail. There has to be a more robust strategy. Solution: complicated. The first decision point is whether the update branch is behind the default branch. - If it isn't, the bot pushes new commits on top of the branch, or amends the last commit if it wasn't made by a human and it's not also on the default branch. - If it is, the update branch is hard-reset to the default one, and any human commits are cherry-picked on top. - If it doesn't exist, it's initialized to the default branch. This feels like a reasonable balance between force-pushing all the time and trying to preserve history to an extent. However it is all rather convoluted.
…commits [#10] Reset to default branch if update branch is behind
update-daemon should ideally try to rebase "human" commits on top of the automatic update commit. It should work in most cases (when humans didn't change the
flake.lock
file), and would make the workflow much smoother.The text was updated successfully, but these errors were encountered: