2017-03-23 14:47:05 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='Tests multi-threaded lazy_init_name_hash'
|
|
|
|
. ./perf-lib.sh
|
|
|
|
|
|
|
|
test_perf_large_repo
|
|
|
|
test_checkout_worktree
|
|
|
|
|
|
|
|
test_expect_success 'verify both methods build the same hashmaps' '
|
2018-03-24 08:44:33 +01:00
|
|
|
test-tool lazy-init-name-hash --dump --single >out.single &&
|
|
|
|
if test-tool lazy-init-name-hash --dump --multi >out.multi
|
2017-05-13 18:03:50 +02:00
|
|
|
then
|
|
|
|
test_set_prereq REPO_BIG_ENOUGH_FOR_MULTI &&
|
|
|
|
sort <out.single >sorted.single &&
|
|
|
|
sort <out.multi >sorted.multi &&
|
|
|
|
test_cmp sorted.single sorted.multi
|
|
|
|
fi
|
2017-03-23 14:47:05 +01:00
|
|
|
'
|
|
|
|
|
2017-05-13 18:02:32 +02:00
|
|
|
test_expect_success 'calibrate' '
|
|
|
|
entries=$(wc -l <out.single) &&
|
|
|
|
|
|
|
|
case $entries in
|
|
|
|
?) count=1000000 ;;
|
|
|
|
??) count=100000 ;;
|
|
|
|
???) count=10000 ;;
|
|
|
|
????) count=1000 ;;
|
|
|
|
?????) count=100 ;;
|
|
|
|
??????) count=10 ;;
|
|
|
|
*) count=1 ;;
|
|
|
|
esac &&
|
|
|
|
export count &&
|
|
|
|
|
|
|
|
case $entries in
|
|
|
|
1) entries_desc="1 entry" ;;
|
|
|
|
*) entries_desc="$entries entries" ;;
|
|
|
|
esac &&
|
|
|
|
|
|
|
|
case $count in
|
|
|
|
1) count_desc="1 round" ;;
|
|
|
|
*) count_desc="$count rounds" ;;
|
|
|
|
esac &&
|
|
|
|
|
|
|
|
desc="$entries_desc, $count_desc" &&
|
|
|
|
export desc
|
|
|
|
'
|
|
|
|
|
|
|
|
test_perf "single-threaded, $desc" "
|
2018-03-24 08:44:33 +01:00
|
|
|
test-tool lazy-init-name-hash --single --count=$count
|
2017-05-13 18:02:32 +02:00
|
|
|
"
|
|
|
|
|
2017-05-13 18:03:50 +02:00
|
|
|
test_perf REPO_BIG_ENOUGH_FOR_MULTI "multi-threaded, $desc" "
|
2018-03-24 08:44:33 +01:00
|
|
|
test-tool lazy-init-name-hash --multi --count=$count
|
2017-05-13 18:02:32 +02:00
|
|
|
"
|
|
|
|
|
2017-03-23 14:47:05 +01:00
|
|
|
test_done
|