mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:18:21 +08:00
test: refine oom-callback.
This commit is contained in:
parent
5519d568f0
commit
89b5b53193
@ -100,8 +100,9 @@ int testcase::oom_callback(MDBX_env *env, int pid, mdbx_tid_t tid, uint64_t txn,
|
|||||||
", txn #%" PRIu64 ", gap %d",
|
", txn #%" PRIu64 ", gap %d",
|
||||||
pid, (size_t)tid, txn, gap);
|
pid, (size_t)tid, txn, gap);
|
||||||
|
|
||||||
if (retry > 0 && self->should_continue()) {
|
if (self->should_continue(true)) {
|
||||||
osal_yield();
|
osal_yield();
|
||||||
|
if (retry > 0)
|
||||||
osal_udelay(retry * 100);
|
osal_udelay(retry * 100);
|
||||||
return 1 /* always retry */;
|
return 1 /* always retry */;
|
||||||
}
|
}
|
||||||
@ -308,7 +309,7 @@ bool testcase::teardown() {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool testcase::should_continue() const {
|
bool testcase::should_continue(bool check_timeout_only) const {
|
||||||
bool result = true;
|
bool result = true;
|
||||||
|
|
||||||
if (config.params.test_duration) {
|
if (config.params.test_duration) {
|
||||||
@ -319,7 +320,8 @@ bool testcase::should_continue() const {
|
|||||||
result = false;
|
result = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config.params.test_nops && nops_completed >= config.params.test_nops)
|
if (!check_timeout_only && config.params.test_nops &&
|
||||||
|
nops_completed >= config.params.test_nops)
|
||||||
result = false;
|
result = false;
|
||||||
|
|
||||||
if (result && global::config::progress_indicator)
|
if (result && global::config::progress_indicator)
|
||||||
|
@ -117,7 +117,7 @@ protected:
|
|||||||
bool wait4start();
|
bool wait4start();
|
||||||
void report(size_t nops_done);
|
void report(size_t nops_done);
|
||||||
void signal();
|
void signal();
|
||||||
bool should_continue() const;
|
bool should_continue(bool check_timeout_only = false) const;
|
||||||
|
|
||||||
void generate_pair(const keygen::serial_t serial, keygen::buffer &key,
|
void generate_pair(const keygen::serial_t serial, keygen::buffer &key,
|
||||||
keygen::buffer &value, keygen::serial_t data_age = 0) {
|
keygen::buffer &value, keygen::serial_t data_age = 0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user