Skip to content

Commit

Permalink
Merge #964: Process for elements upstream tracking / merging
Browse files Browse the repository at this point in the history
2f40d80 Further revisions in response to comments (Glenn Willen)
7207226 Update elements branching proposal based on chat with apoelstra (Glenn Willen)
115f622 Proposals/ideas for elements tracking of upstream bitcoin git branches (Glenn Willen)

Pull request description:

  This goes along with #954 (which is a tool for assisting the review process) and #935 (which was created using approximately this process.)

  It's already had some internal review inside Blockstream, and probably should just get merged now, as a description of the process we're currently trying out; then we can have followup PRs once we know how we feel about it / if we want to revise it.

  @stevenroose ?

Tree-SHA512: 7ec57d5bf9dba191565b6403d64638ff9bb43bc4e3ab0c54c85ffcc384ff9602e01f0af4c6208a22d0987d3c24fc1b1f8a57e9f48686cfa03cde10072923b1e1
  • Loading branch information
stevenroose committed Mar 16, 2021
2 parents b9ee263 + 2f40d80 commit 9d35590
Showing 1 changed file with 45 additions and 0 deletions.
45 changes: 45 additions & 0 deletions doc/elements-upstream-tracking.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
### Old process for elements tracking upstream bitcoin changes:

* At various points (ideally after each major Bitcoin release, optionally after minor releases), someone performs a merge from the Bitcoin release, or some nearby commit, into the Elements `master` branch.
* This usually seems to go through a third, temporary branch, onto which fixes can be applied to make sure that the result builds and passes tests, before merging it back into Elements `master`.
* This requires quite a lot of work from whoever is performing the merge, and it's generally all done at once, in a single big-bang merge commit.
* In theory, this process only gets commits from Bitcoin `master`; sometimes it also seems to have gotten commits from Bitcoin release branches. It's unclear why this happened, but may be related to irregularities in how Core itself has used release branches in the past.
* A modified version of this process is possible, in which the 'merge manager' still does all the merging at once, but brings the Bitcoin side over one pull request at a time, rather than all at once, resolving merge conflicts as they go. This might give an easier time.


### New process for elements tracking upstream bitcoin changes:

* Upstream Bitcoin branches/tags (outside our control):
* `master` (main development)
* `0.XX` -- release branches (one for each major version)
* [tags] `v0.XX.Y` -- one for each release
* Our branches:
* `master` (main elements development)
* `merged-master` (contains a merged combination of all commits from _both_ elements `master` _and_ bitcoin `master`)
* `0.XX` / `0.XX.Y` -- release branches
* Each of these is based on `master`. We do not directly pull in any commits from the upstream release branches; for each cherry-pick into the upstream release branches, we cherry-pick from our `merged-master` branch instead. For administrivia (bumping version numbers, updating changelogs, etc.), we do this ourselves, to reduce merge conflicts.

* Some automated process merges each merged upstream pull request, and each merged Elements merge request, into the `merged-master` branch.
* If the automated process fails, an issue is created, and someone has to do the merge manually, and fix the conflicts. (This is the same work someone would have to do in the current process, but without batching it all up to the very end like we do now.)
* Both the merging and the reviewing, are assisted by scripts checked in under `contrib`.

* When Bitcoin Core branches off for a major release, creating a new `0.XX` release branch, we take the last commit _before_ the upstream release branch -- which has already been merged into our `merged-master` branch -- and merge that into our local `master` elements development branch.
* This means we will always be developing based on the latest major release from Core.
* (If anything is too broken at this point on the upstream `master` branch to even be able to develop, we may have to cherry-pick fixes from the upstream release branch.)
* We _wait_ until Core finalizes the `0.XX.0` release, then we prepare a corresponding `0.XX` Elements release.
* We create our own parallel release branch, and make the same cherry-picks that Core does on their release branch, but we do it from our `merged-master` branch (where any merge conflicts between Core's work and ours have already been resolved.) For any administrative changes, such as version bumps and changelog edits, we do those ourselves on our own release branch.

* When we want to make a minor release, we will repeat the release process, branching from the Elements development `master` branch.
* We will need to cherry-pick any changes from the Core release branch again, since they are not in our dev branch.
* If Core has made any minor releases, it will be a matter of judgement to decide what exactly we cherry-pick for our minor release; most likely we will want to take everything from the Core release branch corresponding to the latest Core minor release.

### Proposed additional changes to the Elements development process

* The biggest issue for this whole process, whether we do it the old way or the new way, seems to be around refactoring on the Bitcoin side. Movement of code is very confusing to `git diff` and `git merge`. (I strongly recommend using advanced options to `git diff` found in the man page. The `patience` or `histogram` modes can help somewhat, and the various options around colorizing code movement are also very useful`.)
* A way of reducing the impact of this dramatically, is to move as much of our code as possible to separate files. E.g. instead of putting Elements wallet RPCs into `rpcwallet.cpp`, put them into `rpcwallet-elements.cpp` or similar.
* In cases where git's textual diffs get confused by code movement, this should prevent spurious conflicts completely.
* In cases where upstream changes things like function signatures, this will turn a merge conflict into a compile error, which is probably easier to fix.
* We already do some of this by separating our code within files, but git's diff algorithm is still somewhat lousy at dealing with changes _near_ other changes, or wholesale moves of files where code also changes.
* We will still need changes in upstream files, but we should try to keep them as small as practical.

* Another annoying issue is the rename from `bitcoin` to `elements`, which conflicts with any refactoring in the build system files, for example. If possible, we may consider trying to automate this process, so that we can avoid having to merge a rename commit, and instead regenerate it by running a script against the new Bitcoin release.

0 comments on commit 9d35590

Please sign in to comment.