mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:08:21 +08:00
mdbx-test: add --geometry-jitter=YES|no
option.
This commit is contained in:
parent
e1bcdb8e9a
commit
981b10d10a
@ -447,6 +447,8 @@ void dump(const char *title) {
|
|||||||
global::config::progress_indicator ? "Yes" : "No");
|
global::config::progress_indicator ? "Yes" : "No");
|
||||||
log_verbose("console mode: %s\n",
|
log_verbose("console mode: %s\n",
|
||||||
global::config::console_mode ? "Yes" : "No");
|
global::config::console_mode ? "Yes" : "No");
|
||||||
|
log_verbose("geometry jitter: %s\n",
|
||||||
|
global::config::geometry_jitter ? "Yes" : "No");
|
||||||
}
|
}
|
||||||
|
|
||||||
} /* namespace config */
|
} /* namespace config */
|
||||||
@ -501,6 +503,8 @@ const std::string actor_config::serialize(const char *prefix) const {
|
|||||||
checksum.push(global::config::progress_indicator);
|
checksum.push(global::config::progress_indicator);
|
||||||
result.push_back(global::config::console_mode ? 'Y' : 'N');
|
result.push_back(global::config::console_mode ? 'Y' : 'N');
|
||||||
checksum.push(global::config::console_mode);
|
checksum.push(global::config::console_mode);
|
||||||
|
result.push_back(global::config::geometry_jitter ? 'Y' : 'N');
|
||||||
|
checksum.push(global::config::geometry_jitter);
|
||||||
result.push_back('|');
|
result.push_back('|');
|
||||||
|
|
||||||
result.append(osal_serialize(checksum));
|
result.append(osal_serialize(checksum));
|
||||||
@ -578,11 +582,14 @@ bool actor_config::deserialize(const char *str, actor_config &config) {
|
|||||||
TRACE("<< actor_config::deserialize: slash-5\n");
|
TRACE("<< actor_config::deserialize: slash-5\n");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if ((str[0] == 'Y' || str[0] == 'N') && (str[1] == 'Y' || str[1] == 'N')) {
|
if ((str[0] == 'Y' || str[0] == 'N') && (str[1] == 'Y' || str[1] == 'N') &&
|
||||||
|
(str[2] == 'Y' || str[2] == 'N')) {
|
||||||
global::config::progress_indicator = str[0] == 'Y';
|
global::config::progress_indicator = str[0] == 'Y';
|
||||||
checksum.push(global::config::progress_indicator);
|
checksum.push(global::config::progress_indicator);
|
||||||
global::config::console_mode = str[1] == 'Y';
|
global::config::console_mode = str[1] == 'Y';
|
||||||
checksum.push(global::config::console_mode);
|
checksum.push(global::config::console_mode);
|
||||||
|
global::config::geometry_jitter = str[2] != 'N';
|
||||||
|
checksum.push(global::config::geometry_jitter);
|
||||||
str = slash + 1;
|
str = slash + 1;
|
||||||
|
|
||||||
slash = strchr(str, '|');
|
slash = strchr(str, '|');
|
||||||
|
@ -110,6 +110,7 @@ bool testcase_jitter::run() {
|
|||||||
if (!mode_readonly()) {
|
if (!mode_readonly()) {
|
||||||
fetch_canary();
|
fetch_canary();
|
||||||
update_canary(1);
|
update_canary(1);
|
||||||
|
if (global::config::geometry_jitter) {
|
||||||
err = mdbx_env_set_geometry(
|
err = mdbx_env_set_geometry(
|
||||||
db_guard.get(), -1, -1,
|
db_guard.get(), -1, -1,
|
||||||
coin4size ? upper_limit * 2 / 3 : upper_limit * 3 / 2, -1, -1, -1);
|
coin4size ? upper_limit * 2 / 3 : upper_limit * 3 / 2, -1, -1, -1);
|
||||||
@ -117,14 +118,17 @@ bool testcase_jitter::run() {
|
|||||||
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
||||||
failure_perror("mdbx_env_set_geometry-1", err);
|
failure_perror("mdbx_env_set_geometry-1", err);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
txn_end(flipcoin());
|
txn_end(flipcoin());
|
||||||
|
|
||||||
|
if (global::config::geometry_jitter) {
|
||||||
err = mdbx_env_set_geometry(
|
err = mdbx_env_set_geometry(
|
||||||
db_guard.get(), -1, -1,
|
db_guard.get(), -1, -1,
|
||||||
!coin4size ? upper_limit * 2 / 3 : upper_limit * 3 / 2, -1, -1, -1);
|
!coin4size ? upper_limit * 2 / 3 : upper_limit * 3 / 2, -1, -1, -1);
|
||||||
if (err != MDBX_SUCCESS && err != MDBX_UNABLE_EXTEND_MAPSIZE &&
|
if (err != MDBX_SUCCESS && err != MDBX_UNABLE_EXTEND_MAPSIZE &&
|
||||||
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
||||||
failure_perror("mdbx_env_set_geometry-2", err);
|
failure_perror("mdbx_env_set_geometry-2", err);
|
||||||
|
}
|
||||||
|
|
||||||
if (flipcoin()) {
|
if (flipcoin()) {
|
||||||
jitter_delay();
|
jitter_delay();
|
||||||
@ -133,12 +137,14 @@ bool testcase_jitter::run() {
|
|||||||
txn_end(flipcoin());
|
txn_end(flipcoin());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (global::config::geometry_jitter) {
|
||||||
jitter_delay();
|
jitter_delay();
|
||||||
err =
|
err = mdbx_env_set_geometry(db_guard.get(), -1, -1, upper_limit, -1, -1,
|
||||||
mdbx_env_set_geometry(db_guard.get(), -1, -1, upper_limit, -1, -1, -1);
|
-1);
|
||||||
if (err != MDBX_SUCCESS && err != MDBX_UNABLE_EXTEND_MAPSIZE &&
|
if (err != MDBX_SUCCESS && err != MDBX_UNABLE_EXTEND_MAPSIZE &&
|
||||||
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
err != MDBX_MAP_FULL && err != MDBX_TOO_LARGE)
|
||||||
failure_perror("mdbx_env_set_geometry-3", err);
|
failure_perror("mdbx_env_set_geometry-3", err);
|
||||||
|
}
|
||||||
|
|
||||||
db_close();
|
db_close();
|
||||||
|
|
||||||
|
@ -10,6 +10,7 @@ UPTO=9999999
|
|||||||
MONITOR=
|
MONITOR=
|
||||||
LOOPS=
|
LOOPS=
|
||||||
SKIP_MAKE=no
|
SKIP_MAKE=no
|
||||||
|
GEOMETRY_JITTER=yes
|
||||||
BANNER="$(which banner 2>/dev/null | echo echo)"
|
BANNER="$(which banner 2>/dev/null | echo echo)"
|
||||||
UNAME="$(uname -s 2>/dev/null || echo Unknown)"
|
UNAME="$(uname -s 2>/dev/null || echo Unknown)"
|
||||||
DB_UPTO_MB=17408
|
DB_UPTO_MB=17408
|
||||||
@ -27,6 +28,7 @@ do
|
|||||||
echo "--loops NN Stop after the NN loops"
|
echo "--loops NN Stop after the NN loops"
|
||||||
echo "--dir PATH Specifies directory for test DB and other files (it will be cleared)"
|
echo "--dir PATH Specifies directory for test DB and other files (it will be cleared)"
|
||||||
echo "--db-upto-mb NN Limits upper size of test DB to the NN megabytes"
|
echo "--db-upto-mb NN Limits upper size of test DB to the NN megabytes"
|
||||||
|
echo "--no-geometry-jitter Disable jitter for geometry upper-size"
|
||||||
echo "--help Print this usage help and exit"
|
echo "--help Print this usage help and exit"
|
||||||
exit -2
|
exit -2
|
||||||
;;
|
;;
|
||||||
@ -88,6 +90,9 @@ do
|
|||||||
fi
|
fi
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
|
--no-geometry-jitter)
|
||||||
|
GEOMETRY_JITTER=no
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
echo "Unknown option '$1'"
|
echo "Unknown option '$1'"
|
||||||
exit -2
|
exit -2
|
||||||
@ -296,8 +301,8 @@ function probe {
|
|||||||
rm -f ${TESTDB_DIR}/* || failed
|
rm -f ${TESTDB_DIR}/* || failed
|
||||||
for case in $LIST
|
for case in $LIST
|
||||||
do
|
do
|
||||||
echo "Run ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=11 --pathname=${TESTDB_DIR}/long.db --cleanup-after=no $@ $case"
|
echo "Run ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=11 --pathname=${TESTDB_DIR}/long.db --cleanup-after=no --geometry-jitter=${GEOMETRY_JITTER} $@ $case"
|
||||||
${MONITOR} ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=11 --pathname=${TESTDB_DIR}/long.db --cleanup-after=no "$@" $case | check_deep \
|
${MONITOR} ./mdbx_test ${speculum} --random-writemap=no --ignore-dbfull --repeat=11 --pathname=${TESTDB_DIR}/long.db --cleanup-after=no --geometry-jitter=${GEOMETRY_JITTER} "$@" $case | check_deep \
|
||||||
&& ${MONITOR} ./mdbx_chk ${TESTDB_DIR}/long.db | tee ${TESTDB_DIR}/long-chk.log \
|
&& ${MONITOR} ./mdbx_chk ${TESTDB_DIR}/long.db | tee ${TESTDB_DIR}/long-chk.log \
|
||||||
&& ([ ! -e ${TESTDB_DIR}/long.db-copy ] || ${MONITOR} ./mdbx_chk ${TESTDB_DIR}/long.db-copy | tee ${TESTDB_DIR}/long-chk-copy.log) \
|
&& ([ ! -e ${TESTDB_DIR}/long.db-copy ] || ${MONITOR} ./mdbx_chk ${TESTDB_DIR}/long.db-copy | tee ${TESTDB_DIR}/long-chk-copy.log) \
|
||||||
|| failed
|
|| failed
|
||||||
|
52
test/main.cc
52
test/main.cc
@ -73,6 +73,7 @@ MDBX_NORETURN void usage(void) {
|
|||||||
" --ignore-dbfull[=yes|NO] Ignore MDBX_MAP_FULL error\n"
|
" --ignore-dbfull[=yes|NO] Ignore MDBX_MAP_FULL error\n"
|
||||||
" --speculum[=yes|NO] Use internal `speculum` to check "
|
" --speculum[=yes|NO] Use internal `speculum` to check "
|
||||||
"dataset\n"
|
"dataset\n"
|
||||||
|
" --geometry-jitter[=YES|no] Use jitter for geometry upper-limit\n"
|
||||||
"Keys and Value:\n"
|
"Keys and Value:\n"
|
||||||
" --keylen.min=N Minimal keys length\n"
|
" --keylen.min=N Minimal keys length\n"
|
||||||
" --keylen.max=N Miximal keys length\n"
|
" --keylen.max=N Miximal keys length\n"
|
||||||
@ -181,6 +182,7 @@ void actor_params::set_defaults(const std::string &tmpdir) {
|
|||||||
global::config::failfast = true;
|
global::config::failfast = true;
|
||||||
global::config::progress_indicator = true;
|
global::config::progress_indicator = true;
|
||||||
global::config::console_mode = osal_istty(STDERR_FILENO);
|
global::config::console_mode = osal_istty(STDERR_FILENO);
|
||||||
|
global::config::geometry_jitter = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace global {
|
namespace global {
|
||||||
@ -202,6 +204,7 @@ bool cleanup_after;
|
|||||||
bool failfast;
|
bool failfast;
|
||||||
bool progress_indicator;
|
bool progress_indicator;
|
||||||
bool console_mode;
|
bool console_mode;
|
||||||
|
bool geometry_jitter;
|
||||||
} /* namespace config */
|
} /* namespace config */
|
||||||
|
|
||||||
} /* namespace global */
|
} /* namespace global */
|
||||||
@ -290,8 +293,33 @@ int main(int argc, char *const argv[]) {
|
|||||||
unsigned last_space_id = 0;
|
unsigned last_space_id = 0;
|
||||||
|
|
||||||
for (int narg = 1; narg < argc; ++narg) {
|
for (int narg = 1; narg < argc; ++narg) {
|
||||||
const char *value = nullptr;
|
if (config::parse_option(argc, argv, narg, "dump-config",
|
||||||
|
global::config::dump_config))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "cleanup-before",
|
||||||
|
global::config::cleanup_before))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "cleanup-after",
|
||||||
|
global::config::cleanup_after))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "failfast",
|
||||||
|
global::config::failfast))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "progress",
|
||||||
|
global::config::progress_indicator))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "console",
|
||||||
|
global::config::console_mode))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "geometry-jitter",
|
||||||
|
global::config::geometry_jitter))
|
||||||
|
continue;
|
||||||
|
if (config::parse_option(argc, argv, narg, "timeout",
|
||||||
|
global::config::timeout_duration_seconds,
|
||||||
|
config::duration, 1))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
const char *value = nullptr;
|
||||||
if (config::parse_option(argc, argv, narg, "case", &value)) {
|
if (config::parse_option(argc, argv, narg, "case", &value)) {
|
||||||
fixup4qemu(params);
|
fixup4qemu(params);
|
||||||
testcase_setup(value, params, last_space_id);
|
testcase_setup(value, params, last_space_id);
|
||||||
@ -357,10 +385,6 @@ int main(int argc, char *const argv[]) {
|
|||||||
if (config::parse_option(argc, argv, narg, "threads", params.nthreads,
|
if (config::parse_option(argc, argv, narg, "threads", params.nthreads,
|
||||||
config::no_scale, 1, 64))
|
config::no_scale, 1, 64))
|
||||||
continue;
|
continue;
|
||||||
if (config::parse_option(argc, argv, narg, "timeout",
|
|
||||||
global::config::timeout_duration_seconds,
|
|
||||||
config::duration, 1))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (config::parse_option_intptr(argc, argv, narg, "size-lower",
|
if (config::parse_option_intptr(argc, argv, narg, "size-lower",
|
||||||
params.size_lower,
|
params.size_lower,
|
||||||
@ -491,15 +515,6 @@ int main(int argc, char *const argv[]) {
|
|||||||
continue;
|
continue;
|
||||||
if (config::parse_option(argc, argv, narg, "speculum", params.speculum))
|
if (config::parse_option(argc, argv, narg, "speculum", params.speculum))
|
||||||
continue;
|
continue;
|
||||||
if (config::parse_option(argc, argv, narg, "dump-config",
|
|
||||||
global::config::dump_config))
|
|
||||||
continue;
|
|
||||||
if (config::parse_option(argc, argv, narg, "cleanup-before",
|
|
||||||
global::config::cleanup_before))
|
|
||||||
continue;
|
|
||||||
if (config::parse_option(argc, argv, narg, "cleanup-after",
|
|
||||||
global::config::cleanup_after))
|
|
||||||
continue;
|
|
||||||
if (config::parse_option(argc, argv, narg, "max-readers",
|
if (config::parse_option(argc, argv, narg, "max-readers",
|
||||||
params.max_readers, config::no_scale, 1, 255))
|
params.max_readers, config::no_scale, 1, 255))
|
||||||
continue;
|
continue;
|
||||||
@ -570,15 +585,6 @@ int main(int argc, char *const argv[]) {
|
|||||||
configure_actor(last_space_id, ac_nested, value, params);
|
configure_actor(last_space_id, ac_nested, value, params);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (config::parse_option(argc, argv, narg, "failfast",
|
|
||||||
global::config::failfast))
|
|
||||||
continue;
|
|
||||||
if (config::parse_option(argc, argv, narg, "progress",
|
|
||||||
global::config::progress_indicator))
|
|
||||||
continue;
|
|
||||||
if (config::parse_option(argc, argv, narg, "console",
|
|
||||||
global::config::console_mode))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (*argv[narg] != '-') {
|
if (*argv[narg] != '-') {
|
||||||
fixup4qemu(params);
|
fixup4qemu(params);
|
||||||
|
@ -68,6 +68,7 @@ extern bool cleanup_after;
|
|||||||
extern bool failfast;
|
extern bool failfast;
|
||||||
extern bool progress_indicator;
|
extern bool progress_indicator;
|
||||||
extern bool console_mode;
|
extern bool console_mode;
|
||||||
|
extern bool geometry_jitter;
|
||||||
} /* namespace config */
|
} /* namespace config */
|
||||||
|
|
||||||
} /* namespace global */
|
} /* namespace global */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user