git-bisect man page on OpenBSD

Man page or keyword search:  
man Server   11362 pages
apropos Keyword Search (all sections)
Output format
OpenBSD logo
[printable version]



GIT-BISECT(1)					    GIT-BISECT(1)

NAME
       git-bisect - Find by binary search the change that introduced a bug

SYNOPSIS
       git bisect <subcommand> <options>

DESCRIPTION
       The  command takes various subcommands, and different options depending
       on the subcommand:

       git bisect help
       git bisect start [<bad> [<good>...]] [--] [<paths>...]
       git bisect bad [<rev>]
       git bisect good [<rev>...]
       git bisect skip [(<rev>|<range>)...]
       git bisect reset [<commit>]
       git bisect visualize
       git bisect replay <logfile>
       git bisect log
       git bisect run <cmd>...

       This command uses git rev-list --bisect to help drive the binary search
       process to find which change introduced a bug, given an old "good" com-
       mit object name and a later "bad" commit object name.

   Getting help
       Use "git bisect" to get a short	usage  description,  and  "git	bisect
       help" or "git bisect -h" to get a long usage description.

   Basic bisect commands: start, bad, good
       Using the Linux kernel tree as an example, basic use of the bisect com-
       mand is as follows:

       .ft C
       $ git bisect start
       $ git bisect bad			# Current version is bad
       $ git bisect good v2.6.13-rc2	# v2.6.13-rc2 was the last version
					# tested that was good
       .ft

       When you have specified at least one bad and one good version, the com-
       mand  bisects  the  revision  tree and outputs something similar to the
       following:

								1

GIT-BISECT(1)					    GIT-BISECT(1)

       .ft C
       Bisecting: 675 revisions left to test after this
       .ft

       The state in the middle of the set of revisions is  then	 checked  out.
       You  would  now	compile	 that kernel and boot it. If the booted kernel
       works correctly, you would then issue the following command:

       .ft C
       $ git bisect good		       # this one is good
       .ft

       The output of this command would be something similar to the following:

       .ft C
       Bisecting: 337 revisions left to test after this
       .ft

       You  keep  repeating  this process, compiling the tree, testing it, and
       depending on whether it is good or bad issuing the command "git	bisect
       good" or "git bisect bad" to ask for the next bisection.

       Eventually there will be no more revisions left to bisect, and you will
       have been left with the first bad kernel revision in "refs/bisect/bad".

   Bisect reset
       After  a	 bisect session, to clean up the bisection state and return to
       the original HEAD, issue the following command:

       .ft C
       $ git bisect reset
       .ft

       By default, this will return your tree to the commit that  was  checked

								2

GIT-BISECT(1)					    GIT-BISECT(1)

       out before git bisect start. (A new git bisect start will also do that,
       as it cleans up the old bisection state.)

       With an optional	 argument,  you	 can  return  to  a  different	commit
       instead:

       .ft C
       $ git bisect reset <commit>
       .ft

       For example, git bisect reset HEAD will leave you on the current bisec-
       tion commit and avoid switching commits at all, while git bisect	 reset
       bisect/bad will check out the first bad revision.

   Bisect visualize
       To  see	the  currently remaining suspects in gitk, issue the following
       command during the bisection process:

       .ft C
       $ git bisect visualize
       .ft

       view may also be used as a synonym for visualize.

       If the DISPLAY environment  variable  is	 not  set,  git	 log  is  used
       instead.	 You can also give command line options such as -p and --stat.

       .ft C
       $ git bisect view --stat
       .ft

   Bisect log and bisect replay
       After having marked revisions as good or bad, issue the following  com-
       mand to show what has been done so far:

								3

GIT-BISECT(1)					    GIT-BISECT(1)

       .ft C
       $ git bisect log
       .ft

       If  you	discover that you made a mistake in specifying the status of a
       revision, you can save the output of this command to a file, edit it to
       remove  the incorrect entries, and then issue the following commands to
       return to a corrected state:

       .ft C
       $ git bisect reset
       $ git bisect replay that-file
       .ft

   Avoiding testing a commit
       If, in the middle of a bisect session, you know that the next suggested
       revision	 is  not a good one to test (e.g. the change the commit intro-
       duces is known not to work in your environment and you know it does not
       have anything to do with the bug you are chasing), you may want to find
       a nearby commit and try that instead.

       For example:

       .ft C
       $ git bisect good/bad		       # previous round was good or bad.
       Bisecting: 337 revisions left to test after this
       $ git bisect visualize		       # oops, that is uninteresting.
       $ git reset --hard HEAD~3	       # try 3 revisions before what
					       # was suggested
       .ft

       Then compile and test the chosen	 revision,  and	 afterwards  mark  the
       revision as good or bad in the usual manner.

   Bisect skip
       Instead	of choosing by yourself a nearby commit, you can ask git to do
       it for you by issuing the command:

								4

GIT-BISECT(1)					    GIT-BISECT(1)

       .ft C
       $ git bisect skip		 # Current version cannot be tested
       .ft

       But git may eventually be unable to tell the first bad commit  among  a
       bad commit and one or more skipped commits.

       You can even skip a range of commits, instead of just one commit, using
       the "<commit1>..<commit2>" notation. For example:

       .ft C
       $ git bisect skip v2.5..v2.6
       .ft

       This tells the bisect process that no commit  after  v2.5,  up  to  and
       including v2.6, should be tested.

       Note  that  if  you also want to skip the first commit of the range you
       would issue the command:

       .ft C
       $ git bisect skip v2.5 v2.5..v2.6
       .ft

       This tells the bisect process that the commits  between	v2.5  included
       and v2.6 included should be skipped.

   Cutting down bisection by giving more parameters to bisect start
       You can further cut down the number of trials, if you know what part of
       the tree is involved in the problem you are tracking down, by  specify-
       ing path parameters when issuing the bisect start command:

       .ft C
       $ git bisect start -- arch/i386 include/asm-i386
       .ft

								5

GIT-BISECT(1)					    GIT-BISECT(1)

       If  you	know  beforehand more than one good commit, you can narrow the
       bisect space down by specifying all of  the  good  commits  immediately
       after the bad commit when issuing the bisect start command:

       .ft C
       $ git bisect start v2.6.20-rc6 v2.6.20-rc4 v2.6.20-rc1 --
			  # v2.6.20-rc6 is bad
			  # v2.6.20-rc4 and v2.6.20-rc1 are good
       .ft

   Bisect run
       If  you	have a script that can tell if the current source code is good
       or bad, you can bisect by issuing the command:

       .ft C
       $ git bisect run my_script arguments
       .ft

       Note that the script (my_script in the above example) should exit  with
       code 0 if the current source code is good, and exit with a code between
       1 and 127 (inclusive), except 125, if the current source code is bad.

       Any other exit code will abort the bisect process. It should  be	 noted
       that a program that terminates via "exit(-1)" leaves $? = 255, (see the
       exit(3) manual page), as the value is chopped with "& 0377".

       The special exit code 125 should be used when the current  source  code
       cannot be tested. If the script exits with this code, the current revi-
       sion will be skipped (see git bisect skip above).

       You may often find that during a bisect session you want to have tempo-
       rary modifications (e.g. s/#define DEBUG 0/#define DEBUG 1/ in a header
       file, or "revision that does not have  this  commit  needs  this	 patch
       applied to work around another problem this bisection is not interested
       in") applied to the revision being tested.

       To cope with such a situation, after the inner  git  bisect  finds  the
       next revision to test, the script can apply the patch before compiling,
       run the real test, and afterwards decide if the revision (possibly with
       the  needed  patch)  passed  the	 test  and then rewind the tree to the

								6

GIT-BISECT(1)					    GIT-BISECT(1)

       pristine state. Finally the script should exit with the status  of  the
       real  test to let the "git bisect run" command loop determine the even-
       tual outcome of the bisect session.

EXAMPLES
       o  Automatically bisect a broken build between v1.2 and HEAD:

	  .ft C
	  $ git bisect start HEAD v1.2 --      # HEAD is bad, v1.2 is good
	  $ git bisect run make		       # "make" builds the app
	  .ft

       o  Automatically bisect a test failure between origin and HEAD:

	  .ft C
	  $ git bisect start HEAD origin --    # HEAD is bad, origin is good
	  $ git bisect run make test	       # "make test" builds and tests
	  .ft

       o  Automatically bisect a broken test suite:

	  .ft C
	  $ cat ~/test.sh
	  #!/bin/sh
	  make || exit 125		     # this skips broken builds
	  make test			     # "make test" runs the test suite
	  $ git bisect start v1.3 v1.1 --    # v1.3 is bad, v1.1 is good
	  $ git bisect run ~/test.sh
	  .ft

	  Here we use a "test.sh" custom script. In  this  script,  if	"make"
	  fails, we skip the current commit.

	  It is safer to use a custom script outside the repository to prevent
	  interactions between the bisect, make and  test  processes  and  the
	  script.

	  "make	 test" should "exit 0", if the test suite passes, and "exit 1"
	  otherwise.

       o  Automatically bisect a broken test case:

								7

GIT-BISECT(1)					    GIT-BISECT(1)

	  .ft C
	  $ cat ~/test.sh
	  #!/bin/sh
	  make || exit 125		       # this skips broken builds
	  ~/check_test_case.sh		       # does the test case passes ?
	  $ git bisect start HEAD HEAD~10 --   # culprit is among the last 10
	  $ git bisect run ~/test.sh
	  .ft

	  Here "check_test_case.sh" should "exit 0" if the test	 case  passes,
	  and "exit 1" otherwise.

	  It  is  safer if both "test.sh" and "check_test_case.sh" scripts are
	  outside the repository to prevent interactions between  the  bisect,
	  make and test processes and the scripts.

       o  Automatically bisect a broken test suite:

	  .ft C
	  $ git bisect start HEAD HEAD~10 --   # culprit is among the last 10
	  $ git bisect run sh -c "make || exit 125; ~/check_test_case.sh"
	  .ft

	  Does the same as the previous example, but on a single line.

AUTHOR
       Written by Linus Torvalds <torvalds@osdl.org: mailto:torvalds@osdl.org>

DOCUMENTATION
       Documentation by Junio C Hamano and the git-list	 <git@vger.kernel.org:
       mailto:git@vger.kernel.org>.

SEE ALSO
       Fighting	  regressions	with   git   bisect:   git-bisect-lk2009.html,
       git-blame(1).

GIT
       Part of the git(1) suite

								8

[top]

List of man pages available for OpenBSD

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net