Best practices for multiple git repositories

前端 未结 2 1703
温柔的废话
温柔的废话 2021-02-15 13:38

I have around 20 different repositories. Many are independent and compile as libraries but some others have dependencies among them. Dependency resolution and branching is compl

2条回答
  •  清歌不尽
    2021-02-15 14:31

    For working with multiple branches in parallel, use paralleled clones if possible. cd is an awful lot easier than checkout and clean and check-for-stale-detritus and recreate-caches every time you want to switch.


    So far as recording your test environments goes, what you're describing is exactly what submodules do, in every detail. For something this simple, I'm going to recommend setting yourself up without using the submodule command at all, and telling it about your setup once you're comfortable and the top item on your submodule-issues list is keystroke count.

    Starting from the setup in your question, here's how you set yourself up to record clean builds in the subprojects:

    cd $superproject
    git init .
    git add a b c etc
    git commit -m "recording test state for $thistest"
    

    That's it. You've committed a list of commit id's, i.e. the id's of the currently-checked-out commits in each of those repos. The actual content is in those repos, not this one, but that's the entire difference between files and submodules so far as git's concerned. The .gitmodules file has random notes to help cloners, mainly a suggested repo that's supposed to contain the necessary commits, and random notes for command defaults, but what it's doing is easy and obvious.

    Want to check out the right commit at path foo?

    (commit=`git rev-parse :foo`; cd foo; git checkout $commit)
    

    The rev-parse fetches the content id for foo from the index, the cd and checkout do that.

    Here's how you find all your submodules and what should be checked out there to recreate the staged aka indexed environment:

    git ls-files -s | grep ^16
    

    Check what your current index lists for a submodule and what's actually checked out there:

    echo $(git rev-parse :$submodule; (cd $submodule; git rev-parse HEAD))
    

    and there you go. Check out the right commits in all your submodules?

    git ls-files -s | grep ^16 | while read mode commit stage path; do
            (cd "$path"; git checkout $commit)
    done
    

    Sometimes you're carrying local patches you want applied to every checkout:

    git ls-files -s | grep ^16 | while read mode commit stage path; do
            (cd $path; git rebase $commit)
    done
    

    and so forth. There's git submodule commands for these, but they're not doing anything you don't see above. Same for all the rest, you can translate everything they do into near-oneliners like the ones above.

    There's nothing mysterious about submodules.


    Continuous integration is generally done with any of a whole lot of tools, I'll leave that for someone else to address.

提交回复
热议问题