From: Michael Witten <mfwitten@gmail.com>
To: Christofer Jennings <boz.lists@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: Sanity Check: scrum teams, shared 'story branches', rebasing shared branches
Date: Sun, 10 Jun 2012 04:35:40 -0000 [thread overview]
Message-ID: <f02de4149bf84cd78e41c22088413b31-mfwitten@gmail.com> (raw)
In-Reply-To: <3EA7D039-9D6E-4945-A982-43DB53AAE43A@gmail.com>
On Sat, 9 Jun 2012 16:51:28 -0700, Christofer Jennings wrote:
> I've been using Git and GitHub for ~6 months. Working on a SCM plan
> for a Scrum project with 50+ developers in ~8 dev. teams. Each team
> will be working on one or two stories simultaneously, so expect ~16
> 'story branches' (and master) at any given time. We've got GitHub
> Enterprise and are working out how to manage story development on
> shared branches that get merged to master only after going through
> acceptance & peer review. We hope stories will only be 3 - 5 days to
> complete, but may take 2 weeks. We're promoting frequent pushes to
> story branches.
>
> After a number of experiments and doing online research, we're
> thinking to use rebase to keep the story branches up-to-date with
> master while the story branches are in development. This seems to be
> the best approach because it will allow us to use bisect to isolate
> issues, and it will give us the most linear history graph.
You can use bisect to isolate issues regardless of merges. Also, linear
histories are not always better histories; for one, merge commits can
usefully encode the way that something was actually developed.
> So, here's my question: Can we use "rebase -s recursive -Xtheirs" as
> shown below?
>
> In this experiment, we're on 'story' branch 's1'. It's behind master
> because another story has been merged to master. We need to rebase
> to master and then rebase to origin/s1 to be up-to-date. So we...
>
> git fetch -v
> git rebase origin/master
> ... resolve stuff ...
> git rebase -s recursive -Xtheirs origin/s1
Let's expand that a bit for the sake of discussion:
git fetch -v
git branch -f s1_0 # Additional line
git rebase origin/master
... resolve stuff ...
git branch -f s1_1 # Additional line
git rebase -s recursive -Xtheirs origin/s1
So:
* The first rebase applies all the commits in `origin/master..s1_0'
on top of the commit to which `origin/master' points; the branch
heads `s1' and `s1_1' are then set to point to the youngest of
the resulting commits.
* The second rebase applies all the commits in `origin/s1..s1_1'
on top of the commit to which `origin/s1' points; the branch
heads `s1' and `s1_2' are then set to point to the youngest of
the resulting commits.
In that second rebase, the range:
origin/s1..s1_1
is equivalent to:
^origin/s1 s1_1
which is equivalent to:
^origin/s1 origin/master s1_1
because `origin/master' is reachable from `s1_1'. This in turn is
equivalent to:
origin/s1..origin/master origin/s1..s1_1
In other words, the second rebase applies all the commits in
`origin/s1..origin/master' (namely, possibly the commits from
the other story) ON TOP of the commit pointed to by `origin/s1',
which is probably not what you want; the code might be correct,
but the history is probably not.
To see for yourself, try this small example:
$ git init origin; cd origin
$ echo 0 > a; git add a; git commit -m Initial
$ git branch s1
$ echo 1 > a; git commit -am 'Other Story'
$ cd ..; git clone origin local
$ cd origin; git checkout s1
$ echo 0 > b; git add b; git commit -m 'Shared s1 update'
$ cd ../local
$ git checkout -b s1 origin/s1
$ echo 0 > c; git add c; git commit -m 'Local s1 work'
$ git fetch
$ git rebase origin/master
$ git rebase origin/s1
First, rewinding head to replay your work on top of it...
Applying: Other Story
Applying: Local s1 work
$ git log --format=%s --graph
* Local s1 work
* Other Story
* Shared s1 update
* Initial
> The "-s recursive -Xtheirs" part seems to result in all the right code
> at the end. We only had to "git add && git rebase --continue" for
> deleted files.
Two points:
* I think it's dangerous to ignore any conflicts, let alone when mixing
code from multiple upstreams.
* Be certain that you don't want -Xours. IIRC, during a rebase, the commits
that have already been placed in the new history (which includes the
upstream) are considered `ours' during a rebase.
Basically, you need to define more strictly what "upstream" means in your
project, and you need to be less afraid of merging, a fundamental process
around which git was designed.
Sincerely,
Michael Witten
next prev parent reply other threads:[~2012-06-10 4:44 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-06-09 23:51 Sanity Check: scrum teams, shared 'story branches', rebasing shared branches Christofer Jennings
2012-06-10 4:35 ` Michael Witten [this message]
2012-06-10 15:48 ` Heiko Voigt
2012-06-14 14:32 ` Christofer Jennings
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=f02de4149bf84cd78e41c22088413b31-mfwitten@gmail.com \
--to=mfwitten@gmail.com \
--cc=boz.lists@gmail.com \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).