core.fsyncmethod: tests for batch mode

Add test cases to exercise batch mode for:
 * 'git add'
 * 'git stash'
 * 'git update-index'
 * 'git unpack-objects'

These tests ensure that the added data winds up in the object database.

In this change we introduce a new test helper lib-unique-files.sh. The
goal of this library is to create a tree of files that have different
oids from any other files that may have been created in the current test
repo. This helps us avoid missing validation of an object being added
due to it already being in the repo.

Signed-off-by: Neeraj Singh <neerajsi@microsoft.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Neeraj Singh 2022-04-04 22:20:16 -07:00 committed by Junio C Hamano
parent fb2d0db502
commit d42bab442d
4 changed files with 109 additions and 14 deletions

34
t/lib-unique-files.sh Normal file
View File

@ -0,0 +1,34 @@
# Helper to create files with unique contents
# Create multiple files with unique contents within this test run. Takes the
# number of directories, the number of files in each directory, and the base
# directory.
#
# test_create_unique_files 2 3 my_dir -- Creates 2 directories with 3 files
# each in my_dir, all with contents
# different from previous invocations
# of this command in this run.
test_create_unique_files () {
test "$#" -ne 3 && BUG "3 param"
local dirs="$1" &&
local files="$2" &&
local basedir="$3" &&
local counter="0" &&
local i &&
local j &&
test_tick &&
local basedata="$basedir$test_tick" &&
rm -rf "$basedir" &&
for i in $(test_seq $dirs)
do
local dir="$basedir/dir$i" &&
mkdir -p "$dir" &&
for j in $(test_seq $files)
do
counter=$((counter + 1)) &&
echo "$basedata.$counter">"$dir/file$j.txt"
done
done
}

View File

@ -8,6 +8,8 @@ test_description='Test of git add, including the -- option.'
TEST_PASSES_SANITIZE_LEAK=true TEST_PASSES_SANITIZE_LEAK=true
. ./test-lib.sh . ./test-lib.sh
. $TEST_DIRECTORY/lib-unique-files.sh
# Test the file mode "$1" of the file "$2" in the index. # Test the file mode "$1" of the file "$2" in the index.
test_mode_in_index () { test_mode_in_index () {
case "$(git ls-files -s "$2")" in case "$(git ls-files -s "$2")" in
@ -34,6 +36,32 @@ test_expect_success \
'Test that "git add -- -q" works' \ 'Test that "git add -- -q" works' \
'touch -- -q && git add -- -q' 'touch -- -q && git add -- -q'
BATCH_CONFIGURATION='-c core.fsync=loose-object -c core.fsyncmethod=batch'
test_expect_success 'git add: core.fsyncmethod=batch' "
test_create_unique_files 2 4 files_base_dir1 &&
GIT_TEST_FSYNC=1 git $BATCH_CONFIGURATION add -- ./files_base_dir1/ &&
git ls-files --stage files_base_dir1/ |
test_parse_ls_files_stage_oids >added_files_oids &&
# We created 2 subdirs with 4 files each (8 files total) above
test_line_count = 8 added_files_oids &&
git cat-file --batch-check='%(objectname)' <added_files_oids >added_files_actual &&
test_cmp added_files_oids added_files_actual
"
test_expect_success 'git update-index: core.fsyncmethod=batch' "
test_create_unique_files 2 4 files_base_dir2 &&
find files_base_dir2 ! -type d -print | xargs git $BATCH_CONFIGURATION update-index --add -- &&
git ls-files --stage files_base_dir2 |
test_parse_ls_files_stage_oids >added_files2_oids &&
# We created 2 subdirs with 4 files each (8 files total) above
test_line_count = 8 added_files2_oids &&
git cat-file --batch-check='%(objectname)' <added_files2_oids >added_files2_actual &&
test_cmp added_files2_oids added_files2_actual
"
test_expect_success \ test_expect_success \
'git add: Test that executable bit is not used if core.filemode=0' \ 'git add: Test that executable bit is not used if core.filemode=0' \
'git config core.filemode 0 && 'git config core.filemode 0 &&

View File

@ -9,6 +9,7 @@ GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
. ./test-lib.sh . ./test-lib.sh
. $TEST_DIRECTORY/lib-unique-files.sh
test_expect_success 'usage on cmd and subcommand invalid option' ' test_expect_success 'usage on cmd and subcommand invalid option' '
test_expect_code 129 git stash --invalid-option 2>usage && test_expect_code 129 git stash --invalid-option 2>usage &&
@ -1336,6 +1337,25 @@ test_expect_success 'stash handles skip-worktree entries nicely' '
git rev-parse --verify refs/stash:A.t git rev-parse --verify refs/stash:A.t
' '
BATCH_CONFIGURATION='-c core.fsync=loose-object -c core.fsyncmethod=batch'
test_expect_success 'stash with core.fsyncmethod=batch' "
test_create_unique_files 2 4 files_base_dir &&
GIT_TEST_FSYNC=1 git $BATCH_CONFIGURATION stash push -u -- ./files_base_dir/ &&
# The files were untracked, so use the third parent,
# which contains the untracked files
git ls-tree -r stash^3 -- ./files_base_dir/ |
test_parse_ls_tree_oids >stashed_files_oids &&
# We created 2 dirs with 4 files each (8 files total) above
test_line_count = 8 stashed_files_oids &&
git cat-file --batch-check='%(objectname)' <stashed_files_oids >stashed_files_actual &&
test_cmp stashed_files_oids stashed_files_actual
"
test_expect_success 'git stash succeeds despite directory/file change' ' test_expect_success 'git stash succeeds despite directory/file change' '
test_create_repo directory_file_switch_v1 && test_create_repo directory_file_switch_v1 &&
( (

View File

@ -161,22 +161,27 @@ test_expect_success 'pack-objects with bogus arguments' '
' '
check_unpack () { check_unpack () {
local packname="$1" &&
local object_list="$2" &&
local git_config="$3" &&
test_when_finished "rm -rf git2" && test_when_finished "rm -rf git2" &&
git init --bare git2 && git $git_config init --bare git2 &&
git -C git2 unpack-objects -n <"$1".pack && (
git -C git2 unpack-objects <"$1".pack && git $git_config -C git2 unpack-objects -n <"$packname".pack &&
(cd .git && find objects -type f -print) | git $git_config -C git2 unpack-objects <"$packname".pack &&
while read path git $git_config -C git2 cat-file --batch-check="%(objectname)"
do ) <"$object_list" >current &&
cmp git2/$path .git/$path || { cmp "$object_list" current
echo $path differs.
return 1
}
done
} }
test_expect_success 'unpack without delta' ' test_expect_success 'unpack without delta' '
check_unpack test-1-${packname_1} check_unpack test-1-${packname_1} obj-list
'
BATCH_CONFIGURATION='-c core.fsync=loose-object -c core.fsyncmethod=batch'
test_expect_success 'unpack without delta (core.fsyncmethod=batch)' '
check_unpack test-1-${packname_1} obj-list "$BATCH_CONFIGURATION"
' '
test_expect_success 'pack with REF_DELTA' ' test_expect_success 'pack with REF_DELTA' '
@ -185,7 +190,11 @@ test_expect_success 'pack with REF_DELTA' '
' '
test_expect_success 'unpack with REF_DELTA' ' test_expect_success 'unpack with REF_DELTA' '
check_unpack test-2-${packname_2} check_unpack test-2-${packname_2} obj-list
'
test_expect_success 'unpack with REF_DELTA (core.fsyncmethod=batch)' '
check_unpack test-2-${packname_2} obj-list "$BATCH_CONFIGURATION"
' '
test_expect_success 'pack with OFS_DELTA' ' test_expect_success 'pack with OFS_DELTA' '
@ -195,7 +204,11 @@ test_expect_success 'pack with OFS_DELTA' '
' '
test_expect_success 'unpack with OFS_DELTA' ' test_expect_success 'unpack with OFS_DELTA' '
check_unpack test-3-${packname_3} check_unpack test-3-${packname_3} obj-list
'
test_expect_success 'unpack with OFS_DELTA (core.fsyncmethod=batch)' '
check_unpack test-3-${packname_3} obj-list "$BATCH_CONFIGURATION"
' '
test_expect_success 'compare delta flavors' ' test_expect_success 'compare delta flavors' '