Merge branch 'ab/gc-reflog'
Fix various glitches in "git gc" around reflog handling. * ab/gc-reflog: gc: handle & check gc.reflogExpire config reflog tests: assert lack of early exit with expiry="never" reflog tests: test for the "points nowhere" warning reflog tests: make use of "test_config" idiom gc: refactor a "call me once" pattern gc: convert to using the_hash_algo gc: remove redundant check for gc_auto_threshold
This commit is contained in:
@ -232,25 +232,34 @@ test_expect_success '--expire=never' '
|
||||
'
|
||||
|
||||
test_expect_success 'gc.reflogexpire=never' '
|
||||
test_config gc.reflogexpire never &&
|
||||
test_config gc.reflogexpireunreachable never &&
|
||||
|
||||
git reflog expire --verbose --all >output &&
|
||||
test_line_count = 9 output &&
|
||||
|
||||
git config gc.reflogexpire never &&
|
||||
git config gc.reflogexpireunreachable never &&
|
||||
git reflog expire --verbose --all &&
|
||||
git reflog refs/heads/master >output &&
|
||||
test_line_count = 4 output
|
||||
'
|
||||
|
||||
test_expect_success 'gc.reflogexpire=false' '
|
||||
test_config gc.reflogexpire false &&
|
||||
test_config gc.reflogexpireunreachable false &&
|
||||
|
||||
git config gc.reflogexpire false &&
|
||||
git config gc.reflogexpireunreachable false &&
|
||||
git reflog expire --verbose --all &&
|
||||
git reflog refs/heads/master >output &&
|
||||
test_line_count = 4 output &&
|
||||
test_line_count = 4 output
|
||||
|
||||
git config --unset gc.reflogexpire &&
|
||||
git config --unset gc.reflogexpireunreachable
|
||||
'
|
||||
|
||||
test_expect_success 'git reflog expire unknown reference' '
|
||||
test_config gc.reflogexpire never &&
|
||||
test_config gc.reflogexpireunreachable never &&
|
||||
|
||||
test_must_fail git reflog expire master@{123} 2>stderr &&
|
||||
test_i18ngrep "points nowhere" stderr &&
|
||||
test_must_fail git reflog expire does-not-exist 2>stderr &&
|
||||
test_i18ngrep "points nowhere" stderr
|
||||
'
|
||||
|
||||
test_expect_success 'checkout should not delete log for packed ref' '
|
||||
|
@ -120,6 +120,25 @@ test_expect_success 'gc --quiet' '
|
||||
test_must_be_empty stderr
|
||||
'
|
||||
|
||||
test_expect_success 'gc.reflogExpire{Unreachable,}=never skips "expire" via "gc"' '
|
||||
test_config gc.reflogExpire never &&
|
||||
test_config gc.reflogExpireUnreachable never &&
|
||||
|
||||
GIT_TRACE=$(pwd)/trace.out git gc &&
|
||||
|
||||
# Check that git-pack-refs is run as a sanity check (done via
|
||||
# gc_before_repack()) but that git-expire is not.
|
||||
grep -E "^trace: (built-in|exec|run_command): git pack-refs --" trace.out &&
|
||||
! grep -E "^trace: (built-in|exec|run_command): git reflog expire --" trace.out
|
||||
'
|
||||
|
||||
test_expect_success 'one of gc.reflogExpire{Unreachable,}=never does not skip "expire" via "gc"' '
|
||||
>trace.out &&
|
||||
test_config gc.reflogExpire never &&
|
||||
GIT_TRACE=$(pwd)/trace.out git gc &&
|
||||
grep -E "^trace: (built-in|exec|run_command): git reflog expire --" trace.out
|
||||
'
|
||||
|
||||
run_and_wait_for_auto_gc () {
|
||||
# We read stdout from gc for the side effect of waiting until the
|
||||
# background gc process exits, closing its fd 9. Furthermore, the
|
||||
|
Reference in New Issue
Block a user