| #!/bin/sh |
| |
| test_description="Tests index-pack performance" |
| |
| . ./perf-lib.sh |
| |
| test_perf_large_repo |
| |
| test_expect_success 'repack' ' |
| git repack -ad && |
| PACK=$(ls .git/objects/pack/*.pack | head -n1) && |
| test -f "$PACK" && |
| export PACK |
| ' |
| |
| # Rather than counting up and doubling each time, count down from the endpoint, |
| # halving each time. That ensures that our final test uses as many threads as |
| # CPUs, even if it isn't a power of 2. |
| test_expect_success 'set up thread-counting tests' ' |
| t=$(test-tool online-cpus) && |
| threads= && |
| while test $t -gt 0 |
| do |
| threads="$t $threads" && |
| t=$((t / 2)) || return 1 |
| done |
| ' |
| |
| test_perf 'index-pack 0 threads' --prereq PERF_EXTRA \ |
| --setup 'rm -rf repo.git && git init --bare repo.git' ' |
| GIT_DIR=repo.git git index-pack --threads=1 --stdin < $PACK |
| ' |
| |
| for t in $threads |
| do |
| THREADS=$t |
| export THREADS |
| test_perf "index-pack $t threads" --prereq PERF_EXTRA \ |
| --setup 'rm -rf repo.git && git init --bare repo.git' ' |
| GIT_DIR=repo.git GIT_FORCE_THREADS=1 \ |
| git index-pack --threads=$THREADS --stdin <$PACK |
| ' |
| done |
| |
| test_perf 'index-pack default number of threads' \ |
| --setup 'rm -rf repo.git && git init --bare repo.git' ' |
| GIT_DIR=repo.git git index-pack --stdin < $PACK |
| ' |
| |
| test_done |