2018-08-12 21:08:07 +03:00
|
|
|
#!/bin/bash
|
|
|
|
set -euo pipefail
|
2018-09-05 02:20:56 +03:00
|
|
|
make check
|
|
|
|
TESTDB_PREFIX=${1:-/dev/shm/mdbx-gc-test}.
|
2018-08-12 21:08:07 +03:00
|
|
|
|
|
|
|
function rep9 { printf "%*s" $1 '' | tr ' ' '9'; }
|
|
|
|
function join { local IFS="$1"; shift; echo "$*"; }
|
|
|
|
function bit2option { local -n arr=$1; (( ($2&(1<<$3)) != 0 )) && echo -n '+' || echo -n '-'; echo "${arr[$3]}"; }
|
|
|
|
|
|
|
|
options=(writemap coalesce lifo)
|
|
|
|
|
|
|
|
function bits2list {
|
|
|
|
local -n arr=$1
|
|
|
|
local i
|
|
|
|
local list=()
|
|
|
|
for ((i=0; i<${#arr[@]}; ++i)) do
|
|
|
|
list[$i]=$(bit2option $1 $2 $i)
|
|
|
|
done
|
|
|
|
join , "${list[@]}"
|
|
|
|
}
|
|
|
|
|
2018-09-05 02:20:56 +03:00
|
|
|
function probe {
|
|
|
|
echo "=============================================== $(date)"
|
|
|
|
echo "${caption}: $*"
|
|
|
|
rm -f ${TESTDB_PREFIX}* \
|
2018-09-21 01:04:35 +03:00
|
|
|
&& ./mdbx_test --pathname=${TESTDB_PREFIX}db "$@" | lz4 > ${TESTDB_PREFIX}log.lz4 \
|
2018-09-05 02:20:56 +03:00
|
|
|
&& ./mdbx_chk -nvvv ${TESTDB_PREFIX}db | tee ${TESTDB_PREFIX}chk \
|
2018-11-04 18:57:38 +03:00
|
|
|
&& ./mdbx_chk -nvvv ${TESTDB_PREFIX}db-copy | tee ${TESTDB_PREFIX}chk-copy \
|
2018-09-05 02:20:56 +03:00
|
|
|
|| (echo "FAILED"; exit 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
count=0
|
|
|
|
for nops in {2..7}; do
|
|
|
|
for ((wbatch=nops-1; wbatch > 0; --wbatch)); do
|
2018-09-20 23:29:23 +03:00
|
|
|
loops=$(((3333 >> nops) / nops + 1))
|
2018-09-05 02:20:56 +03:00
|
|
|
for ((rep=0; rep++ < loops; )); do
|
|
|
|
for ((bits=2**${#options[@]}; --bits >= 0; )); do
|
|
|
|
seed=$(date +%N)
|
2018-09-17 00:32:02 +03:00
|
|
|
caption="Probe #$((++count)) int-key,w/o-dups, repeat ${rep} of ${loops}" probe \
|
|
|
|
--pagesize=min --size=6G --table=+key.integer,-data.dups --keylen.min=min --keylen.max=max --datalen.min=min --datalen.max=1111 \
|
|
|
|
--nops=$( rep9 $nops ) --batch.write=$( rep9 $wbatch ) --mode=$(bits2list options $bits) \
|
|
|
|
--keygen.seed=${seed} basic
|
|
|
|
caption="Probe #$((++count)) int-key,with-dups, repeat ${rep} of ${loops}" probe \
|
|
|
|
--pagesize=min --size=6G --table=+key.integer,+data.dups --keylen.min=min --keylen.max=max --datalen.min=min --datalen.max=max \
|
|
|
|
--nops=$( rep9 $nops ) --batch.write=$( rep9 $wbatch ) --mode=$(bits2list options $bits) \
|
|
|
|
--keygen.seed=${seed} basic
|
|
|
|
caption="Probe #$((++count)) int-key,int-data, repeat ${rep} of ${loops}" probe \
|
|
|
|
--pagesize=min --size=6G --table=+key.integer,+data.integer --keylen.min=min --keylen.max=max --datalen.min=min --datalen.max=max \
|
|
|
|
--nops=$( rep9 $nops ) --batch.write=$( rep9 $wbatch ) --mode=$(bits2list options $bits) \
|
|
|
|
--keygen.seed=${seed} basic
|
2018-09-05 02:20:56 +03:00
|
|
|
caption="Probe #$((++count)) w/o-dups, repeat ${rep} of ${loops}" probe \
|
|
|
|
--pagesize=min --size=6G --table=-data.dups --keylen.min=min --keylen.max=max --datalen.min=min --datalen.max=1111 \
|
|
|
|
--nops=$( rep9 $nops ) --batch.write=$( rep9 $wbatch ) --mode=$(bits2list options $bits) \
|
2018-09-16 21:03:04 +03:00
|
|
|
--keygen.seed=${seed} basic
|
2018-09-05 02:20:56 +03:00
|
|
|
caption="Probe #$((++count)) with-dups, repeat ${rep} of ${loops}" probe \
|
|
|
|
--pagesize=min --size=6G --table=+data.dups --keylen.min=min --keylen.max=max --datalen.min=min --datalen.max=max \
|
|
|
|
--nops=$( rep9 $nops ) --batch.write=$( rep9 $wbatch ) --mode=$(bits2list options $bits) \
|
2018-09-16 21:03:04 +03:00
|
|
|
--keygen.seed=${seed} basic
|
2018-09-05 02:20:56 +03:00
|
|
|
done
|
2018-08-12 21:08:07 +03:00
|
|
|
done
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "=== ALL DONE ====================== $(date)"
|