mirror of
https://github.com/git/git.git
synced 2024-11-15 17:03:14 +01:00
853bd0d267
One of the tests in t5401 creates a bunch of branches by calling git-branch(1) for every one of them. This is quite inefficient and takes a comparatively long time even on Unix systems where spawning processes is comparatively fast. Refactor it to instead use git-update-ref(1), which leads to an almost 10-fold speedup: ``` Benchmark 1: ./t5401-update-hooks.sh (rev = HEAD) Time (mean ± σ): 983.2 ms ± 97.6 ms [User: 328.8 ms, System: 679.2 ms] Range (min … max): 882.9 ms … 1078.0 ms 3 runs Benchmark 2: ./t5401-update-hooks.sh (rev = HEAD~) Time (mean ± σ): 9.312 s ± 0.398 s [User: 2.766 s, System: 6.617 s] Range (min … max): 8.885 s … 9.674 s 3 runs Summary ./t5401-update-hooks.sh (rev = HEAD) ran 9.47 ± 1.02 times faster than ./t5401-update-hooks.sh (rev = HEAD~) ``` Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
142 lines
4.0 KiB
Bash
Executable File
142 lines
4.0 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Copyright (c) 2006 Shawn O. Pearce
|
|
#
|
|
|
|
test_description='Test the update hook infrastructure.'
|
|
. ./test-lib.sh
|
|
|
|
test_expect_success setup '
|
|
echo This is a test. >a &&
|
|
git update-index --add a &&
|
|
tree0=$(git write-tree) &&
|
|
commit0=$(echo setup | git commit-tree $tree0) &&
|
|
echo We hope it works. >a &&
|
|
git update-index a &&
|
|
tree1=$(git write-tree) &&
|
|
commit1=$(echo modify | git commit-tree $tree1 -p $commit0) &&
|
|
git update-ref refs/heads/main $commit0 &&
|
|
git update-ref refs/heads/tofail $commit1 &&
|
|
git clone --bare ./. victim.git &&
|
|
GIT_DIR=victim.git git update-ref refs/heads/tofail $commit1 &&
|
|
git update-ref refs/heads/main $commit1 &&
|
|
git update-ref refs/heads/tofail $commit0 &&
|
|
|
|
test_hook --setup -C victim.git pre-receive <<-\EOF &&
|
|
printf %s "$@" >>$GIT_DIR/pre-receive.args
|
|
cat - >$GIT_DIR/pre-receive.stdin
|
|
echo STDOUT pre-receive
|
|
echo STDERR pre-receive >&2
|
|
EOF
|
|
|
|
test_hook --setup -C victim.git update <<-\EOF &&
|
|
echo "$@" >>$GIT_DIR/update.args
|
|
read x; printf %s "$x" >$GIT_DIR/update.stdin
|
|
echo STDOUT update $1
|
|
echo STDERR update $1 >&2
|
|
test "$1" = refs/heads/main || exit
|
|
EOF
|
|
|
|
test_hook --setup -C victim.git post-receive <<-\EOF &&
|
|
printf %s "$@" >>$GIT_DIR/post-receive.args
|
|
cat - >$GIT_DIR/post-receive.stdin
|
|
echo STDOUT post-receive
|
|
echo STDERR post-receive >&2
|
|
EOF
|
|
|
|
test_hook --setup -C victim.git post-update <<-\EOF
|
|
echo "$@" >>$GIT_DIR/post-update.args
|
|
read x; printf %s "$x" >$GIT_DIR/post-update.stdin
|
|
echo STDOUT post-update
|
|
echo STDERR post-update >&2
|
|
EOF
|
|
'
|
|
|
|
test_expect_success push '
|
|
test_must_fail git send-pack --force ./victim.git \
|
|
main tofail >send.out 2>send.err
|
|
'
|
|
|
|
test_expect_success 'updated as expected' '
|
|
test $(GIT_DIR=victim.git git rev-parse main) = $commit1 &&
|
|
test $(GIT_DIR=victim.git git rev-parse tofail) = $commit1
|
|
'
|
|
|
|
test_expect_success 'hooks ran' '
|
|
test -f victim.git/pre-receive.args &&
|
|
test -f victim.git/pre-receive.stdin &&
|
|
test -f victim.git/update.args &&
|
|
test -f victim.git/update.stdin &&
|
|
test -f victim.git/post-receive.args &&
|
|
test -f victim.git/post-receive.stdin &&
|
|
test -f victim.git/post-update.args &&
|
|
test -f victim.git/post-update.stdin
|
|
'
|
|
|
|
test_expect_success 'pre-receive hook input' '
|
|
(echo $commit0 $commit1 refs/heads/main &&
|
|
echo $commit1 $commit0 refs/heads/tofail
|
|
) | test_cmp - victim.git/pre-receive.stdin
|
|
'
|
|
|
|
test_expect_success 'update hook arguments' '
|
|
(echo refs/heads/main $commit0 $commit1 &&
|
|
echo refs/heads/tofail $commit1 $commit0
|
|
) | test_cmp - victim.git/update.args
|
|
'
|
|
|
|
test_expect_success 'post-receive hook input' '
|
|
echo $commit0 $commit1 refs/heads/main |
|
|
test_cmp - victim.git/post-receive.stdin
|
|
'
|
|
|
|
test_expect_success 'post-update hook arguments' '
|
|
echo refs/heads/main |
|
|
test_cmp - victim.git/post-update.args
|
|
'
|
|
|
|
test_expect_success 'all hook stdin is /dev/null' '
|
|
test_must_be_empty victim.git/update.stdin &&
|
|
test_must_be_empty victim.git/post-update.stdin
|
|
'
|
|
|
|
test_expect_success 'all *-receive hook args are empty' '
|
|
test_must_be_empty victim.git/pre-receive.args &&
|
|
test_must_be_empty victim.git/post-receive.args
|
|
'
|
|
|
|
test_expect_success 'send-pack produced no output' '
|
|
test_must_be_empty send.out
|
|
'
|
|
|
|
cat <<EOF >expect
|
|
remote: STDOUT pre-receive
|
|
remote: STDERR pre-receive
|
|
remote: STDOUT update refs/heads/main
|
|
remote: STDERR update refs/heads/main
|
|
remote: STDOUT update refs/heads/tofail
|
|
remote: STDERR update refs/heads/tofail
|
|
remote: error: hook declined to update refs/heads/tofail
|
|
remote: STDOUT post-receive
|
|
remote: STDERR post-receive
|
|
remote: STDOUT post-update
|
|
remote: STDERR post-update
|
|
EOF
|
|
test_expect_success 'send-pack stderr contains hook messages' '
|
|
grep ^remote: send.err | sed "s/ *\$//" >actual &&
|
|
test_cmp expect actual
|
|
'
|
|
|
|
test_expect_success 'pre-receive hook that forgets to read its input' '
|
|
test_hook --clobber -C victim.git pre-receive <<-\EOF &&
|
|
exit 0
|
|
EOF
|
|
rm -f victim.git/hooks/update victim.git/hooks/post-update &&
|
|
|
|
printf "create refs/heads/branch_%d main\n" $(test_seq 100 999) >input &&
|
|
git update-ref --stdin <input &&
|
|
git push ./victim.git "+refs/heads/*:refs/heads/*"
|
|
'
|
|
|
|
test_done
|