Re: Article about "git bisect run" on LWN

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 5 Feb 2009, Ingo Molnar wrote:

* Christian Couder <chriscool@xxxxxxxxxxxxx> wrote:

Hi,

For information, an article from me, 'Fully automated bisecting with "git
bisect run"' has been published in today's edition of LWN on the
development page:

http://lwn.net/Articles/317154/

Nice article!

In terms of possible future enhancements of git bisect, here's a couple of
random ideas that would help my auto-bisection efforts:

- Feature: support "Bisection Redundancy"

  This feature helps developers realize if a bug is sporadic. This happens
  quite often in the kernel space: a bug looks deterministic, but down the
  line it becomes sporadic. Sometimes a boot crash only occurs with a 75%
  probability - and if one is unlucky it can cause a _lot_ of wasted
  bisection time. The wrong commit gets blamed and the wrong set of
  developers start scratching their heads. It's a reoccuring theme on lkml.

  What git could do here is to allow testers to inject a bit of extra
  "redundancy" automatically, and use the redundant test-points to detect
  conflicts in good/bad constraints.

  It would work like this:

     git bisect start --redundancy=33%

  It would mean that for every third bisection points, Git would
  _not_ chose the ideal (estimated) 'middle point' from the set of "unknown
  quality" changes that are still outstanding - but would intentionally
  "weer outside" and select one commit from the _known_ set of commits.

  If such a redundant re-test of the known-good or known-bad set yields a
  nonsensical result then Git aborts the bisection with a "logic
  inconsistency detected" kind of message - and people could at this point
  realize the non-determinism of the test.

  ( Git can do this when a "redundant" test point is marked as 'bad' -
    despite an earlier bisection already categorizing that test point as
    'good' - or if it's the other way around. Git will only continue with
    the bisection if the test point has the expected quality. )

  This essentially means an automated re-test - but it's much better than
  just a repeated bisection - i've often met non-deterministic bugs that
  yield the _exact same_ nonsensical commit even on repeat bisections. That
  happens when a timing bug depends on the exact kernel layout, or a
  miscompilation or linker bug depends on the exact kernel layout, etc.

  It's also faster than a re-done bisection: 33% more testpoints is better
  than twice as many test-points. Also, auto-bisection can deal with
  redundancy just fine - it does not really matter whether i have to wait
  20 or 30 minutes for a test result since there's no manual intervention
  needed - but it _very_ much matters whether i can trust the validity of
  the bisection result.

when you gave this the title of redundnancy and described the problem I assumed that you would then propose running the test multiple times (so "git bisect run X --redundancy 5" would run each test 5 times, it would pass IFF it passed the test all 5 times. that would seem to be a better match for the name, as well as being a better test

David Lang
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux