]> git.ipfire.org Git - thirdparty/git.git/commitdiff
read-tree tests: check "diff-files" exit code on failure
authorÆvar Arnfjörð Bjarmason <avarab@gmail.com>
Mon, 7 Mar 2022 12:48:54 +0000 (13:48 +0100)
committerJunio C Hamano <gitster@pobox.com>
Mon, 7 Mar 2022 21:27:39 +0000 (13:27 -0800)
Fix an issue with the exit code of "diff-files" being ignored, which
has been ignored ever since these tests were originally added in
c859600954d ([PATCH] read-tree: save more user hassles during
fast-forward., 2005-06-07).

Since the exit code was ignored we'd hide errors here under
SANITIZE=leak, which resulted in me mistakenly marking these tests as
passing under SANITIZE=leak in e5a917fcf42 (unpack-trees: don't leak
memory in verify_clean_subdirectory(), 2021-10-07) and
4ea08416b8e (leak tests: mark a read-tree test as passing
SANITIZE=leak, 2021-10-31).

As it would be non-trivial to fix these tests (the leak is in
revision.c) let's un-mark them as passing under SANITIZE=leak in
addition to fixing the issue of ignoring the exit code.

Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/t1001-read-tree-m-2way.sh
t/t1002-read-tree-m-u-2way.sh

index d1115528cb9461495f3ad1e934beb1cd3682f97c..0710b1fb1e945b4d15d989f65f83050076e592cf 100755 (executable)
@@ -21,7 +21,6 @@ In the test, these paths are used:
        yomin   - not in H or M
 '
 
-TEST_PASSES_SANITIZE_LEAK=true
 . ./test-lib.sh
 . "$TEST_DIRECTORY"/lib-read-tree.sh
 
@@ -38,11 +37,12 @@ compare_change () {
 }
 
 check_cache_at () {
-       clean_if_empty=$(git diff-files -- "$1")
+       git diff-files -- "$1" >out &&
+       clean_if_empty=$(cat out) &&
        case "$clean_if_empty" in
        '')  echo "$1: clean" ;;
        ?*)  echo "$1: dirty" ;;
-       esac
+       esac &&
        case "$2,$clean_if_empty" in
        clean,)         :     ;;
        clean,?*)       false ;;
index ca5c5510c737cce1f7c224a7cd8ad0ab95d3010d..46cbd5514a68e135222b5dbec77a21e170ccaa2b 100755 (executable)
@@ -9,7 +9,6 @@ This is identical to t1001, but uses -u to update the work tree as well.
 
 '
 
-TEST_PASSES_SANITIZE_LEAK=true
 . ./test-lib.sh
 . "$TEST_DIRECTORY"/lib-read-tree.sh
 
@@ -23,11 +22,12 @@ compare_change () {
 }
 
 check_cache_at () {
-       clean_if_empty=$(git diff-files -- "$1")
+       git diff-files -- "$1" >out &&
+       clean_if_empty=$(cat out) &&
        case "$clean_if_empty" in
        '')  echo "$1: clean" ;;
        ?*)  echo "$1: dirty" ;;
-       esac
+       esac &&
        case "$2,$clean_if_empty" in
        clean,)         :     ;;
        clean,?*)       false ;;