2017-03-30 23:54:57 +08:00
|
|
|
/*
|
2018-02-04 18:09:18 +08:00
|
|
|
* Copyright 2017-2018 Leonid Yuriev <leo@yuriev.ru>
|
2017-03-30 23:54:57 +08:00
|
|
|
* and other libmdbx authors: please see AUTHORS file.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
|
|
* Public License.
|
|
|
|
*
|
|
|
|
* A copy of this license is available in the file LICENSE in the
|
|
|
|
* top-level directory of the distribution or, alternatively, at
|
|
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "test.h"
|
|
|
|
|
|
|
|
bool testcase_jitter::setup() {
|
|
|
|
log_trace(">> setup");
|
|
|
|
if (!inherited::setup())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
log_trace("<< setup");
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-04-21 23:41:11 +08:00
|
|
|
bool testcase_jitter::run() {
|
|
|
|
while (should_continue()) {
|
|
|
|
jitter_delay();
|
|
|
|
db_open();
|
|
|
|
|
|
|
|
if (flipcoin()) {
|
|
|
|
jitter_delay();
|
2017-10-27 02:14:29 +08:00
|
|
|
txn_begin(true);
|
2017-04-24 00:00:28 +08:00
|
|
|
fetch_canary();
|
2017-04-21 23:41:11 +08:00
|
|
|
jitter_delay();
|
2017-04-24 00:00:28 +08:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 23:41:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
jitter_delay();
|
|
|
|
txn_begin(mode_readonly());
|
|
|
|
jitter_delay();
|
|
|
|
if (!mode_readonly()) {
|
2017-04-24 00:00:28 +08:00
|
|
|
fetch_canary();
|
|
|
|
update_canary(1);
|
2017-04-21 23:41:11 +08:00
|
|
|
/* TODO:
|
|
|
|
* - db_setsize()
|
|
|
|
* ...
|
|
|
|
*/
|
|
|
|
}
|
2017-04-24 00:00:28 +08:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 23:41:11 +08:00
|
|
|
|
|
|
|
if (flipcoin()) {
|
|
|
|
jitter_delay();
|
2017-10-27 02:14:29 +08:00
|
|
|
txn_begin(true);
|
2017-04-21 23:41:11 +08:00
|
|
|
jitter_delay();
|
2017-04-24 00:00:28 +08:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 23:41:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
jitter_delay();
|
|
|
|
db_close();
|
2018-09-17 03:01:56 +08:00
|
|
|
|
|
|
|
/* just 'align' nops with other tests with batching */
|
|
|
|
const auto batching =
|
|
|
|
std::max(config.params.batch_read, config.params.batch_write);
|
|
|
|
report(std::max(1u, batching / 2));
|
2017-04-21 23:41:11 +08:00
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2017-03-30 23:54:57 +08:00
|
|
|
|
|
|
|
bool testcase_jitter::teardown() {
|
|
|
|
log_trace(">> teardown");
|
|
|
|
return inherited::teardown();
|
|
|
|
}
|