Merge branch 'ab/perf-grep-threads'
More perf tests for threaded grep * ab/perf-grep-threads: perf: amend the grep tests to test grep.threadsmaint
commit
59b43c014d
|
|
@ -12,6 +12,9 @@ e.g. GIT_PERF_7820_GREP_OPTS=' -i'. Some options to try:
|
||||||
-vi
|
-vi
|
||||||
-vw
|
-vw
|
||||||
-viw
|
-viw
|
||||||
|
|
||||||
|
If GIT_PERF_GREP_THREADS is set to a list of threads (e.g. '1 4 8'
|
||||||
|
etc.) we will test the patterns under those numbers of threads.
|
||||||
"
|
"
|
||||||
|
|
||||||
. ./perf-lib.sh
|
. ./perf-lib.sh
|
||||||
|
|
@ -19,6 +22,11 @@ e.g. GIT_PERF_7820_GREP_OPTS=' -i'. Some options to try:
|
||||||
test_perf_large_repo
|
test_perf_large_repo
|
||||||
test_checkout_worktree
|
test_checkout_worktree
|
||||||
|
|
||||||
|
if test -n "$GIT_PERF_GREP_THREADS"
|
||||||
|
then
|
||||||
|
test_set_prereq PERF_GREP_ENGINES_THREADS
|
||||||
|
fi
|
||||||
|
|
||||||
for pattern in \
|
for pattern in \
|
||||||
'how.to' \
|
'how.to' \
|
||||||
'^how to' \
|
'^how to' \
|
||||||
|
|
@ -39,18 +47,42 @@ do
|
||||||
else
|
else
|
||||||
prereq=""
|
prereq=""
|
||||||
fi
|
fi
|
||||||
test_perf $prereq "$engine grep$GIT_PERF_7820_GREP_OPTS '$pattern'" "
|
if ! test_have_prereq PERF_GREP_ENGINES_THREADS
|
||||||
git -c grep.patternType=$engine grep$GIT_PERF_7820_GREP_OPTS -- '$pattern' >'out.$engine' || :
|
then
|
||||||
"
|
test_perf $prereq "$engine grep$GIT_PERF_7820_GREP_OPTS '$pattern'" "
|
||||||
|
git -c grep.patternType=$engine grep$GIT_PERF_7820_GREP_OPTS -- '$pattern' >'out.$engine' || :
|
||||||
|
"
|
||||||
|
else
|
||||||
|
for threads in $GIT_PERF_GREP_THREADS
|
||||||
|
do
|
||||||
|
test_perf PTHREADS,$prereq "$engine grep$GIT_PERF_7820_GREP_OPTS '$pattern' with $threads threads" "
|
||||||
|
git -c grep.patternType=$engine -c grep.threads=$threads grep$GIT_PERF_7820_GREP_OPTS -- '$pattern' >'out.$engine.$threads' || :
|
||||||
|
"
|
||||||
|
done
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
test_expect_success "assert that all engines found the same for$GIT_PERF_7820_GREP_OPTS '$pattern'" '
|
if ! test_have_prereq PERF_GREP_ENGINES_THREADS
|
||||||
test_cmp out.basic out.extended &&
|
then
|
||||||
if test_have_prereq PCRE
|
test_expect_success "assert that all engines found the same for$GIT_PERF_7820_GREP_OPTS '$pattern'" '
|
||||||
then
|
test_cmp out.basic out.extended &&
|
||||||
test_cmp out.basic out.perl
|
if test_have_prereq PCRE
|
||||||
fi
|
then
|
||||||
'
|
test_cmp out.basic out.perl
|
||||||
|
fi
|
||||||
|
'
|
||||||
|
else
|
||||||
|
for threads in $GIT_PERF_GREP_THREADS
|
||||||
|
do
|
||||||
|
test_expect_success PTHREADS "assert that all engines found the same for$GIT_PERF_7820_GREP_OPTS '$pattern' under threading" "
|
||||||
|
test_cmp out.basic.$threads out.extended.$threads &&
|
||||||
|
if test_have_prereq PCRE
|
||||||
|
then
|
||||||
|
test_cmp out.basic.$threads out.perl.$threads
|
||||||
|
fi
|
||||||
|
"
|
||||||
|
done
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,9 @@ Set GIT_PERF_7821_GREP_OPTS in the environment to pass options to
|
||||||
git-grep. Make sure to include a leading space,
|
git-grep. Make sure to include a leading space,
|
||||||
e.g. GIT_PERF_7821_GREP_OPTS=' -w'. See p7820-grep-engines.sh for more
|
e.g. GIT_PERF_7821_GREP_OPTS=' -w'. See p7820-grep-engines.sh for more
|
||||||
options to try.
|
options to try.
|
||||||
|
|
||||||
|
If GIT_PERF_7821_THREADS is set to a list of threads (e.g. '1 4 8'
|
||||||
|
etc.) we will test the patterns under those numbers of threads.
|
||||||
"
|
"
|
||||||
|
|
||||||
. ./perf-lib.sh
|
. ./perf-lib.sh
|
||||||
|
|
@ -13,6 +16,11 @@ options to try.
|
||||||
test_perf_large_repo
|
test_perf_large_repo
|
||||||
test_checkout_worktree
|
test_checkout_worktree
|
||||||
|
|
||||||
|
if test -n "$GIT_PERF_GREP_THREADS"
|
||||||
|
then
|
||||||
|
test_set_prereq PERF_GREP_ENGINES_THREADS
|
||||||
|
fi
|
||||||
|
|
||||||
for pattern in 'int' 'uncommon' 'æ'
|
for pattern in 'int' 'uncommon' 'æ'
|
||||||
do
|
do
|
||||||
for engine in fixed basic extended perl
|
for engine in fixed basic extended perl
|
||||||
|
|
@ -23,19 +31,44 @@ do
|
||||||
else
|
else
|
||||||
prereq=""
|
prereq=""
|
||||||
fi
|
fi
|
||||||
test_perf $prereq "$engine grep$GIT_PERF_7821_GREP_OPTS $pattern" "
|
if ! test_have_prereq PERF_GREP_ENGINES_THREADS
|
||||||
git -c grep.patternType=$engine grep$GIT_PERF_7821_GREP_OPTS $pattern >'out.$engine' || :
|
then
|
||||||
"
|
test_perf $prereq "$engine grep$GIT_PERF_7821_GREP_OPTS $pattern" "
|
||||||
|
git -c grep.patternType=$engine grep$GIT_PERF_7821_GREP_OPTS $pattern >'out.$engine' || :
|
||||||
|
"
|
||||||
|
else
|
||||||
|
for threads in $GIT_PERF_GREP_THREADS
|
||||||
|
do
|
||||||
|
test_perf PTHREADS,$prereq "$engine grep$GIT_PERF_7821_GREP_OPTS $pattern with $threads threads" "
|
||||||
|
git -c grep.patternType=$engine -c grep.threads=$threads grep$GIT_PERF_7821_GREP_OPTS $pattern >'out.$engine.$threads' || :
|
||||||
|
"
|
||||||
|
done
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
test_expect_success "assert that all engines found the same for$GIT_PERF_7821_GREP_OPTS $pattern" '
|
if ! test_have_prereq PERF_GREP_ENGINES_THREADS
|
||||||
test_cmp out.fixed out.basic &&
|
then
|
||||||
test_cmp out.fixed out.extended &&
|
test_expect_success "assert that all engines found the same for$GIT_PERF_7821_GREP_OPTS $pattern" '
|
||||||
if test_have_prereq PCRE
|
test_cmp out.fixed out.basic &&
|
||||||
then
|
test_cmp out.fixed out.extended &&
|
||||||
test_cmp out.fixed out.perl
|
if test_have_prereq PCRE
|
||||||
fi
|
then
|
||||||
'
|
test_cmp out.fixed out.perl
|
||||||
|
fi
|
||||||
|
'
|
||||||
|
else
|
||||||
|
for threads in $GIT_PERF_GREP_THREADS
|
||||||
|
do
|
||||||
|
test_expect_success PTHREADS "assert that all engines found the same for$GIT_PERF_7821_GREP_OPTS $pattern under threading" "
|
||||||
|
test_cmp out.fixed.$threads out.basic.$threads &&
|
||||||
|
test_cmp out.fixed.$threads out.extended.$threads &&
|
||||||
|
if test_have_prereq PCRE
|
||||||
|
then
|
||||||
|
test_cmp out.fixed.$threads out.perl.$threads
|
||||||
|
fi
|
||||||
|
"
|
||||||
|
done
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue