Page MenuHomePhabricator

[contrib] skip the first conflict when rebasing the electrum history
ClosedPublic

Authored by PiRK on Aug 17 2023, 16:06.

Details

Summary

The first time this script was launched, it worked properly, but due to the way we integrated electrum into the monorepo (a copy of all files) the initial commit conflicts with itself on subsequent runs. This conflict can be skipped, as we are already confident that the github version of that commit was properly rebased the first time.

Note that git rebase --skip will exit with error code 1 if there is another conflict after the one that is skipped, so we will see the script fail if there is ever another conflict to handle (which should not happen if this remains the only source for new github commits)

Test Plan

contrib/extract-electrum.sh && cd electrumabc-mirror && git status
Check that everything is up to date and that there is not another conflict to be solved.

Diff Detail

Repository
rABC Bitcoin ABC
Branch
electrum_sync
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 24782
Build 49156: Build Diff
Build 49155: arc lint + arc unit

Event Timeline

PiRK requested review of this revision.Aug 17 2023, 16:06

Test plan checks out and rationale makes sense.

So we are looking to do this because maintaining this rebase conflict is worth the trouble as it allows us to preserve the repo's history? imo also probably worthwhile...otherwise would have to deprecate the current repo and create a new mirror one.

A couple of nits:

  1. Is there any way to fix the conflict by changing something in the remote repo (without wiping or deprecating it for a new one)?
  2. Are we sure that the first conflict will always be this exact expected one?

Test plan checks out and rationale makes sense.

So we are looking to do this because maintaining this rebase conflict is worth the trouble as it allows us to preserve the repo's history? imo also probably worthwhile...otherwise would have to deprecate the current repo and create a new mirror one.

A couple of nits:

  1. Is there any way to fix the conflict by changing something in the remote repo (without wiping or deprecating it for a new one)?
  2. Are we sure that the first conflict will always be this exact expected one?

Yes, the idea is that we want to preserve the repo's history so we have a way to use git blame, find old commit message to figure out how some piece of code evolved, keep an archive of the list of authors and their contributions...

I tried changing the remote repo to have it be exactly identical to the monorepo , and that fixed the script for its first run, but unfortunately I could not figure out any way to make that commit then not conflict with itself on subsequent runs. Another thing I tried is to define a merge strategy to keep "our" or "theirs" changes in case of a conflict, but this also only worked once. On subsequent runs the initial monorepo integration commit would revert itself, not matter what strategy I chose. It seems like copying the content of a repo into a monorepo makes it forever un-rebasable on the origin repo, unless the first commit is somehow skipped.

I'm reasonably sure that the first conflict will always be the same, as it is the very first commit in the monorepo's history conflicting with its remote counterpart.

Note that if this fails for some reason, it can only break the archive / mirror (which could then be reset to its original state with a git reset --hard ... command). It will not affect the monorepo. So the damage will be limited.

The only alternatives I can think of are:

  • always reset the remote repo to its initial state (pre-monorepo) before rebasing the monorepo history
  • apply only the recent/new commits as patches instead of rebase

Both of these alternatives are more complex (especially the second one which would require to detect what it the latest monorepo commit that is already applied in the archive).

This revision is now accepted and ready to land.Aug 18 2023, 13:31