Skip to content
This repository has been archived by the owner on Oct 26, 2024. It is now read-only.

Latest commit

 

History

History
68 lines (46 loc) · 3.28 KB

git_subrepo.md

File metadata and controls

68 lines (46 loc) · 3.28 KB

Version control stuff

Originally written 7/9/22 based on git subtree, completely revamped 12/19/22 based on git subrepo. Much cleaner!

Dealing with our open source library is non-trivial.

We're a small team and it'd be nice to just use a single repo for everything. But, we can't because we want to open source imprint. Unfortunately, there are no good tools for splitting repos apart but still treating them as a single repo. The options are:

  1. git submodule
  2. git subtree
  3. git subrepo

I like the discussion here by the git subrepo author on why subrepo is the best option.

As far as I can tell, the design of git subrepo is pretty close to the optimal design for our situation. The only downside to the tool is that it's not perfectly maintained. I think that's going to be okay for us.

For the most part, while developing confirm we can act like the open source imprint repo does not exist. This is nice.

Automated pushes from confirm to imprint

The flow from confirm to imprint looks like:

  1. (manual) Merge PR to main in confirm
  2. (automatic) The confirmasaurus repo CI run will reach the push_to_imprint job only if the tests pass.
  3. (automatic) push_to_imprint will push the imprint/ subrepo to the imprint repo. See the actions workflow here

Contributing changes to imprint

The flow from imprint to confirm looks like:

  1. (automatic) The imprint CI will run this actions workflow to send the updated subrepo back to confirmasaurus.
  2. (automatic) That will trigger the actions workflow here which pulls the new changes into confirmasaurus main.

Manually contributing changes to imprint

This should not normally be necessary due to the automated push/pull workflow above.

git subrepo push imprint --branch sync --squash --debug --verbose --message "Subrepo push to imprint"

Manually pulling changes from imprint

This should not normally be necessary due to the automated push/pull workflow above.

git subrepo pull imprint --debug --verbose --message "Pull from imprint to confirm"

(historical) What I did to set up subrepo

git subrepo has rough edges and some bugs. This is acceptable because the git subtree and git submodule alternatives are so shitty. One of the greatest gifts an engineer could give the world would be to fix this basic infrastructure!

  1. git subrepo init imprint
  2. Manually open the imprint/.gitrepo file and set:
    • remote = git@github.com:Confirm-Solutions/imprint.git
    • branch = main
    • commit = go-get-the-commit-id-from-imprint-repo
    • parent = go-get-the-commit-id-from-confirm-repo
  3. Manually implement this fix (only necessary for getting set up): https://github.com/ingydotnet/git-subrepo/pull/498/files

Useful references