Create
cancel
Showing results for 
Search instead for 
Did you mean: 
Sign up Log in

Next challenges

Recent achievements

  • Global
  • Personal

Recognition

  • Give kudos
  • Received
  • Given

Leaderboard

  • Global

Trophy case

Kudos (beta program)

Kudos logo

You've been invited into the Kudos (beta program) private group. Chat with others in the program, or give feedback to Atlassian.

View group

It's not the same without you

Join the community to find out what other Atlassian users are discussing, debating and creating.

Atlassian Community Hero Image Collage

How to find all the commits made on a branch?

Hi, I have a GIT project with more than 2000 branches and more than 2000 commits.

There are a branch called "1595", I don't know who made it, when was merged, or wich files are affected, so, I am looking for any way to "search" all the commits made on this branch, and then find all the files affected by their commits.

There are any way to do it using Sourcetree or Bitbucket?

5 answers

1 accepted

6 votes
Answer accepted

Git doesn't track information like that. A branch is just a named reference to a commit, and if you commit to a branch, it moves that reference.

What you can do is see all of the commits that are ancestors of that branch, but many of those will have been committed to other branches that either pre-dated your "1595", or were merged into it.

To do that in SourceTree, checkout that branch. In the log view, use the dropdown at the top to view "current branch". If you merge frequently, you may be able to use merge commit descriptions to get a rough idea of what branch sections of older commits belong to.

There may be a better way to do this using a git command line, but this isn't the best forum for those questions.

Thank you for your help, I always imagined a branch like a "group" of commits, now I understand it better, selecting "current branch" on the dropdown was a great way to find what I need.

Like # people like this

I vaguely remember a blog post about a post-commit script that would automatically add a git-note containing the name of the current branch whenever the author made a commit. Something like that might be useful to you in the future.

Like Werner Horbelt likes this

I'm not quite sure if this would be absolutely robust for anybody, I use the following way:

  1. Checkout to the branch that has at least one commit
  2. git rev-list --simplify-by-decoration -2 HEAD
    this gives me just two SHAs: 1) last commit of the branch [C1] 2) and commit parent to the first commit of the branch [C2]
  3. git log --decorate --pretty=oneline --reverse --name-status <C2>..<C1>
    Now I get a list of full history of file changing within the branch

Hello Naeel,

Would you mind explaining your step 2 here? I'm using your answer to write a ruby script that will list all files changed on a branch that has not yet been merged into the development branch, the relevant snippit looks like this:

commit_range = `(git rev-list --simplify-by-decoration -2 HEAD)`
.split(/\n+/)
committed_files = `git log --pretty=format:'' --name-only #{commit_range[1]}..#{commit_range[0]}`
.split(/\n+/)
.uniq

I'm just having trouble understanding what's going on? If I exclude --simplify-by-decoration, I get the same hashes, but I'm not sure if that's necessarily always going to to be the case. It works as expected but I'm asking to see if there are any edge cases I should be aware of?

Not quite sure if the folowing can give you the searched info - it has even to be done on command line ... wink

That's awesome, I don't like use command line, It would be useful if sourceTree show us more options like this.

Like rchylla likes this

git has way to many commands and options to be exposed in a  GUI in a meaningful and clear way.

Those things are mostly for expert level and not for the "normal" user - for whom the most git-GUIS are designed for

Another option is via stash/bitbucket. 

 

1- create a pull request for the branch

2- select source and destination features

3-  at the bottom of the screen you have a nice overview of all the commits/diff. Here you can see the commits and messages, but also al the edited code in the "diff" tab. 

In the bit bucket you have an option called " Commits " there you can just check for the commit you are looking for. But make sure you select the branch you are looking for.

Suggest an answer

Log in or Sign up to answer
TAGS
Community showcase
Posted in Bitbucket

Contest: Share your custom Bitbucket Pipe and win

Announced in this blog, this holiday season we’re celebrating all things CI/CD and between now and the end of 2019 we’ll be showcasing content, use cases, feature announcements and more. One featur...

2,149 views 11 6
Join discussion

Community Events

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

Events near you