Skip to content

Latest commit

 

History

History
114 lines (81 loc) · 2.85 KB

README.md

File metadata and controls

114 lines (81 loc) · 2.85 KB

Git bisect demo

Setup

We have two scripts in this repo.

  • app.sh (this is our app, if it works it outputs something otherwise it outputs nothing)
  • bisect-script.sh (this is the script we'll use to find the bug!)

Instructions

At the current commit, our app is in a broken state, we've made lots of changes since the last time it was working and we don't want to look through all those commits manually to find out what broke it.

We'll use git bisect to help us.

We then need to give git bisect two informations, a good commit and a bad commit.

If we look at our git history (using git log)

commit 469f767f3b9bb5b6834a2318048bdb15f8ac3e8a (HEAD -> master)
Author: Antonio <redacted@gmail.com>
Date:   Mon Dec 9 18:32:03 2019 +0100

    Adds bisect script

commit ed3c23ba90be7f53790d6527bf64e7492817652d
Author: Antonio <redacted@gmail.com>
Date:   Mon Dec 9 18:28:05 2019 +0100

    Adds an useless commit

commit 86dc2360424dda19e3b60ac5af7e7dc2bdb9dcac
Author: Antonio <redacted@gmail.com>
Date:   Mon Dec 9 18:27:47 2019 +0100

    Adds a readme

commit bf11e29d8dccf14d19bcdba399c9cff844f009b4
Author: Antonio <redacted@gmail.com>
Date:   Mon Dec 9 18:27:17 2019 +0100

    Break the app

commit 9b0ca8a81736f7b5f6ea1fde53728820de72cfaf
Author: Antonio <redacted@gmail.com>
Date:   Mon Dec 9 18:26:51 2019 +0100

    First commit

we can find the hash of a working commit (first commmit: 9b0ca8a8173) and the hash of a broken commit, let's say "Adds bisect instructiosn: f2b836f"

Let's run a few simple commands to start playing with git bisect

git bisect bad 469f767f3b9bb
git bisect good f2b836f

Let's create a script to automate git bisect, we'll call it bisect.sh

This script needs to do two things:

  • Exit 0 if the commit is "good"
  • Exit 2 if the commit is "bad"
#!/usr/bin/env bash

OUTPUT=$(./app.sh)

if [ -z "$OUTPUT" ]; then
  # The app is broken since the output is empty
  echo "This commit is broken"
  exit 2
else
  # The app works just fine
  echo "Everything works!"
  exit 0
fi;

We can now run

git bisect run ./bisect.sh

This should give us the following output

antonio@Antonios-MacBook-Pro:~/dev/sandbox/git-bisect-demo|86dc236⚡
⇒  git bisect run ./bisect.sh
running ./bisect.sh
This commit is broken
Bisecting: 0 revisions left to test after this (roughly 0 steps)
[bf11e29d8dccf14d19bcdba399c9cff844f009b4] Break the app
running ./bisect.sh
This commit is broken
bf11e29d8dccf14d19bcdba399c9cff844f009b4 is the first bad commit
commit bf11e29d8dccf14d19bcdba399c9cff844f009b4
Author: Antonio <antonio.root@gmail.com>
Date:   Mon Dec 9 18:27:17 2019 +0100

    Break the app

 app.sh | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
bisect run success

And there it is! We found the commit that introduced a bug in our code!

Don't forget to run git bisect reset afterward to clean up the mess left behind!