A developer completed a new feature last month and I've completed the review, test, etc and merge that feature branch into release branch this month. Now I need to collect my current month's release branch changes and I'm using the below git command to see the changes applied to the release branch. Unfortunately the above mentioned feature changes are not listing since the commit date for above changes doesn't fall under the date I've selected. For me, the change has been delivered to release branch now and I need to count those change towards this month release churn metrics.
git log --after='2017-07-01 00:00:00'
Any quick and easy thoughts on this?
As a workaround, currently I'm achieving the above functionality by collecting the full release branch log every month and do a diff between previously saved last month git log o/p file. The resulting diff will have all changes since last month's saved log.
Here's one idea:
- Rebase before you merge. The rebase will leave all the "authorDate" meta-data alone on the rebased commits, but it will update the "commitDate" meta-data, which is what "git log --after" actually uses internally, even though it uses "authorDate" in its output (a git ux mistake IMO, quite confusing for users!). And so if you rebase today, all commits that get rebased will be captured by a "git log --after yesterday" even though the dates they show look older.
More info here about what data "git log --after" is actually using (stackoverflow.com): How to get git to show commits in a specified date range for author date?
Here's another idea:
- The merge commit itself should show up (its "commitDate" will be in July), just not the commits brought over by the merge. Can you use the merge commit to calculate your metrics?
- Try "git log --first-parent -m -p" to get merge diffs into your git log output. Normally "git log -p" does not include merges in the diff output. You need to add "-m" to get their diffs to print.
p.s. If you're on Bitbucket Server, my paid add-on, Bit-Booster Rebase/Squash, is very useful if you're want to try a rebase workflow. It also includes a hook you can enable to require rebases for merges into the release branch.
Hi @Bijoy_Thomas, I'm contributing during my free time to this open source project: https://github.com/flacle/truegitcodechurn which seems like it would automate some aspect of your workflow. However at the time of writing it only checks the current branch and does not include merge commits (yet). Hope this helps.
Beginning on April 4th, we will be implementing push limits. This means that your push cannot be completed if it is over 3.5 GB. If you do attempt to complete a push that is over 3.5 GB, it will fail...
Connect with like-minded Atlassian users at free events near you!Find an event
Connect with like-minded Atlassian users at free events near you!
Unfortunately there are no Community Events near you at the moment.Host an event
You're one step closer to meeting fellow Atlassian users at your local event. Learn more about Community Events