2017-03-30 18:54:57 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Leonid Yuriev <leo@yuriev.ru>
|
|
|
|
* 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 18:41:11 +03:00
|
|
|
bool testcase_jitter::run() {
|
|
|
|
while (should_continue()) {
|
|
|
|
jitter_delay();
|
|
|
|
db_open();
|
|
|
|
|
|
|
|
if (flipcoin()) {
|
|
|
|
jitter_delay();
|
2017-10-25 19:54:40 -04:00
|
|
|
txn_begin(MDBX_RDONLY);
|
2017-04-23 19:00:28 +03:00
|
|
|
fetch_canary();
|
2017-04-21 18:41:11 +03:00
|
|
|
jitter_delay();
|
2017-04-23 19:00:28 +03:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 18:41:11 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
jitter_delay();
|
|
|
|
txn_begin(mode_readonly());
|
|
|
|
jitter_delay();
|
|
|
|
if (!mode_readonly()) {
|
2017-04-23 19:00:28 +03:00
|
|
|
fetch_canary();
|
|
|
|
update_canary(1);
|
2017-04-21 18:41:11 +03:00
|
|
|
/* TODO:
|
|
|
|
* - db_setsize()
|
|
|
|
* ...
|
|
|
|
*/
|
|
|
|
}
|
2017-04-23 19:00:28 +03:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 18:41:11 +03:00
|
|
|
|
|
|
|
if (flipcoin()) {
|
|
|
|
jitter_delay();
|
2017-10-25 19:54:40 -04:00
|
|
|
txn_begin(MDBX_RDONLY);
|
2017-04-21 18:41:11 +03:00
|
|
|
jitter_delay();
|
2017-04-23 19:00:28 +03:00
|
|
|
txn_end(flipcoin());
|
2017-04-21 18:41:11 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
jitter_delay();
|
|
|
|
db_close();
|
|
|
|
report(1);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2017-03-30 18:54:57 +03:00
|
|
|
|
|
|
|
bool testcase_jitter::teardown() {
|
|
|
|
log_trace(">> teardown");
|
|
|
|
return inherited::teardown();
|
|
|
|
}
|