mdbx-test: backport - fix keylen/datalen min/max ranges checking.

Change-Id: Iee5d2f71ad22ec6e86167f5181deff54f0b5b518
This commit is contained in:
Leonid Yuriev 2018-08-11 22:06:26 +03:00
parent e054ad2ebb
commit e18551061e
2 changed files with 24 additions and 11 deletions

View File

@ -122,16 +122,16 @@ void maker::setup(const config::actor_params_pod &actor,
unsigned thread_number) { unsigned thread_number) {
key_essentials.flags = key_essentials.flags =
actor.table_flags & (MDBX_INTEGERKEY | MDBX_REVERSEKEY); actor.table_flags & (MDBX_INTEGERKEY | MDBX_REVERSEKEY);
assert(actor.keylen_min < UINT8_MAX); assert(actor.keylen_min <= UINT8_MAX);
key_essentials.minlen = (uint8_t)actor.keylen_min; key_essentials.minlen = (uint8_t)actor.keylen_min;
assert(actor.keylen_max < UINT16_MAX); assert(actor.keylen_max <= UINT16_MAX);
key_essentials.maxlen = (uint16_t)actor.keylen_max; key_essentials.maxlen = (uint16_t)actor.keylen_max;
value_essentials.flags = value_essentials.flags =
actor.table_flags & (MDBX_INTEGERDUP | MDBX_REVERSEDUP); actor.table_flags & (MDBX_INTEGERDUP | MDBX_REVERSEDUP);
assert(actor.datalen_min < UINT8_MAX); assert(actor.datalen_min <= UINT8_MAX);
value_essentials.minlen = (uint8_t)actor.datalen_min; value_essentials.minlen = (uint8_t)actor.datalen_min;
assert(actor.datalen_max < UINT16_MAX); assert(actor.datalen_max <= UINT16_MAX);
value_essentials.maxlen = (uint16_t)actor.datalen_max; value_essentials.maxlen = (uint16_t)actor.datalen_max;
assert(thread_number < 2); assert(thread_number < 2);

View File

@ -188,20 +188,33 @@ int main(int argc, char *const argv[]) {
config::duration, 1)) config::duration, 1))
continue; continue;
if (config::parse_option(argc, argv, narg, "keylen.min", params.keylen_min, if (config::parse_option(argc, argv, narg, "keylen.min", params.keylen_min,
config::no_scale, 0, params.keylen_max)) config::no_scale, 0, UINT8_MAX)) {
if (params.keylen_max < params.keylen_min)
params.keylen_max = params.keylen_min;
continue; continue;
if (config::parse_option(argc, argv, narg, "keylen.max", params.keylen_max, }
config::no_scale, params.keylen_min, if (config::parse_option(
mdbx_get_maxkeysize(0))) argc, argv, narg, "keylen.max", params.keylen_max, config::no_scale,
0, std::min(mdbx_get_maxkeysize(0), (int)UINT16_MAX))) {
if (params.keylen_min > params.keylen_max)
params.keylen_min = params.keylen_max;
continue; continue;
}
if (config::parse_option(argc, argv, narg, "datalen.min", if (config::parse_option(argc, argv, narg, "datalen.min",
params.datalen_min, config::no_scale, 0, params.datalen_min, config::no_scale, 0,
params.datalen_max)) UINT8_MAX)) {
if (params.datalen_max < params.datalen_min)
params.datalen_max = params.datalen_min;
continue; continue;
}
if (config::parse_option(argc, argv, narg, "datalen.max", if (config::parse_option(argc, argv, narg, "datalen.max",
params.datalen_max, config::no_scale, params.datalen_max, config::no_scale, 0,
params.datalen_min, MDBX_MAXDATASIZE)) std::min((int)UINT16_MAX, MDBX_MAXDATASIZE))) {
if (params.datalen_min > params.datalen_max)
params.datalen_min = params.datalen_max;
continue; continue;
}
if (config::parse_option(argc, argv, narg, "batch.read", params.batch_read, if (config::parse_option(argc, argv, narg, "batch.read", params.batch_read,
config::no_scale, 1)) config::no_scale, 1))
continue; continue;