mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-23 01:48:21 +08:00
mdbx-test: implement 'speculum' checking for ttl testcase.
Change-Id: Ic825711893f782a71e75447575ac76644ac3f482
This commit is contained in:
parent
d1d65f8090
commit
3990f1cc07
@ -178,7 +178,6 @@ bool testcase_nested::trim_tail(unsigned window_width) {
|
|||||||
fifo.size());
|
fifo.size());
|
||||||
db_table_clear(dbi, txn_guard.get());
|
db_table_clear(dbi, txn_guard.get());
|
||||||
fifo.clear();
|
fifo.clear();
|
||||||
speculum.clear();
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
12
test/test.cc
12
test/test.cc
@ -172,6 +172,7 @@ void testcase::txn_begin(bool readonly, unsigned flags) {
|
|||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_txn_begin()", rc);
|
failure_perror("mdbx_txn_begin()", rc);
|
||||||
txn_guard.reset(txn);
|
txn_guard.reset(txn);
|
||||||
|
need_speculum_assign = config.params.speculum && !readonly;
|
||||||
|
|
||||||
log_trace("<< txn_begin(%s, 0x%04X)", readonly ? "read-only" : "read-write",
|
log_trace("<< txn_begin(%s, 0x%04X)", readonly ? "read-only" : "read-write",
|
||||||
flags);
|
flags);
|
||||||
@ -192,9 +193,12 @@ int testcase::breakable_commit() {
|
|||||||
if (unlikely(err != MDBX_SUCCESS && err != MDBX_THREAD_MISMATCH &&
|
if (unlikely(err != MDBX_SUCCESS && err != MDBX_THREAD_MISMATCH &&
|
||||||
err != MDBX_BAD_TXN))
|
err != MDBX_BAD_TXN))
|
||||||
failure_perror("mdbx_txn_abort()", err);
|
failure_perror("mdbx_txn_abort()", err);
|
||||||
|
if (need_speculum_assign)
|
||||||
|
speculum = speculum_commited;
|
||||||
} else
|
} else
|
||||||
failure_perror("mdbx_txn_commit()", err);
|
failure_perror("mdbx_txn_commit()", err);
|
||||||
}
|
} else if (need_speculum_assign)
|
||||||
|
speculum_commited = speculum;
|
||||||
|
|
||||||
log_trace("<< txn_commit: %s", rc ? "failed" : "Ok");
|
log_trace("<< txn_commit: %s", rc ? "failed" : "Ok");
|
||||||
return rc;
|
return rc;
|
||||||
@ -224,11 +228,15 @@ void testcase::txn_end(bool abort) {
|
|||||||
if (unlikely(err != MDBX_SUCCESS && err != MDBX_THREAD_MISMATCH &&
|
if (unlikely(err != MDBX_SUCCESS && err != MDBX_THREAD_MISMATCH &&
|
||||||
err != MDBX_BAD_TXN))
|
err != MDBX_BAD_TXN))
|
||||||
failure_perror("mdbx_txn_abort()", err);
|
failure_perror("mdbx_txn_abort()", err);
|
||||||
|
if (need_speculum_assign)
|
||||||
|
speculum = speculum_commited;
|
||||||
} else {
|
} else {
|
||||||
txn_inject_writefault(txn);
|
txn_inject_writefault(txn);
|
||||||
int err = mdbx_txn_commit(txn);
|
int err = mdbx_txn_commit(txn);
|
||||||
if (unlikely(err != MDBX_SUCCESS))
|
if (unlikely(err != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_txn_commit()", err);
|
failure_perror("mdbx_txn_commit()", err);
|
||||||
|
if (need_speculum_assign)
|
||||||
|
speculum_commited = speculum;
|
||||||
}
|
}
|
||||||
|
|
||||||
log_trace("<< txn_end(%s)", abort ? "abort" : "commit");
|
log_trace("<< txn_end(%s)", abort ? "abort" : "commit");
|
||||||
@ -491,6 +499,7 @@ void testcase::db_table_drop(MDBX_dbi handle) {
|
|||||||
int rc = mdbx_drop(txn_guard.get(), handle, true);
|
int rc = mdbx_drop(txn_guard.get(), handle, true);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_drop(delete=true)", rc);
|
failure_perror("mdbx_drop(delete=true)", rc);
|
||||||
|
speculum.clear();
|
||||||
log_trace("<< testcase::db_table_drop");
|
log_trace("<< testcase::db_table_drop");
|
||||||
} else {
|
} else {
|
||||||
log_trace("<< testcase::db_table_drop: not needed");
|
log_trace("<< testcase::db_table_drop: not needed");
|
||||||
@ -502,6 +511,7 @@ void testcase::db_table_clear(MDBX_dbi handle, MDBX_txn *txn) {
|
|||||||
int rc = mdbx_drop(txn ? txn : txn_guard.get(), handle, false);
|
int rc = mdbx_drop(txn ? txn : txn_guard.get(), handle, false);
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
failure_perror("mdbx_drop(delete=false)", rc);
|
failure_perror("mdbx_drop(delete=false)", rc);
|
||||||
|
speculum.clear();
|
||||||
log_trace("<< testcase::db_table_clear");
|
log_trace("<< testcase::db_table_clear");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,6 +133,9 @@ protected:
|
|||||||
return cmp < 0;
|
return cmp < 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// for simplify the set<pair<key,value>>
|
||||||
|
// is used instead of multimap<key,value>
|
||||||
using SET = std::set<Item, ItemCompare>;
|
using SET = std::set<Item, ItemCompare>;
|
||||||
|
|
||||||
const actor_config &config;
|
const actor_config &config;
|
||||||
@ -143,6 +146,7 @@ protected:
|
|||||||
scoped_txn_guard txn_guard;
|
scoped_txn_guard txn_guard;
|
||||||
scoped_cursor_guard cursor_guard;
|
scoped_cursor_guard cursor_guard;
|
||||||
bool signalled{false};
|
bool signalled{false};
|
||||||
|
bool need_speculum_assign{false};
|
||||||
|
|
||||||
size_t nops_completed{0};
|
size_t nops_completed{0};
|
||||||
chrono::time start_timestamp;
|
chrono::time start_timestamp;
|
||||||
@ -154,7 +158,7 @@ protected:
|
|||||||
mdbx_canary canary;
|
mdbx_canary canary;
|
||||||
} last;
|
} last;
|
||||||
|
|
||||||
SET speculum{ItemCompare(this)};
|
SET speculum{ItemCompare(this)}, speculum_commited{ItemCompare(this)};
|
||||||
bool speculum_verify();
|
bool speculum_verify();
|
||||||
int insert(const keygen::buffer &akey, const keygen::buffer &adata,
|
int insert(const keygen::buffer &akey, const keygen::buffer &adata,
|
||||||
unsigned flags);
|
unsigned flags);
|
||||||
@ -233,11 +237,10 @@ public:
|
|||||||
|
|
||||||
class testcase_hill : public testcase {
|
class testcase_hill : public testcase {
|
||||||
using inherited = testcase;
|
using inherited = testcase;
|
||||||
SET speculum_commited;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
testcase_hill(const actor_config &config, const mdbx_pid_t pid)
|
testcase_hill(const actor_config &config, const mdbx_pid_t pid)
|
||||||
: testcase(config, pid), speculum_commited(ItemCompare(this)) {}
|
: testcase(config, pid) {}
|
||||||
bool run() override;
|
bool run() override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
14
test/ttl.cc
14
test/ttl.cc
@ -97,7 +97,7 @@ bool testcase_ttl::run() {
|
|||||||
for (unsigned n = 0; n < tail_count; ++n) {
|
for (unsigned n = 0; n < tail_count; ++n) {
|
||||||
log_trace("ttl: remove-tail %" PRIu64, tail_serial);
|
log_trace("ttl: remove-tail %" PRIu64, tail_serial);
|
||||||
generate_pair(tail_serial);
|
generate_pair(tail_serial);
|
||||||
err = mdbx_del(txn_guard.get(), dbi, &key->value, &data->value);
|
err = remove(key, data);
|
||||||
if (unlikely(err != MDBX_SUCCESS)) {
|
if (unlikely(err != MDBX_SUCCESS)) {
|
||||||
if (err == MDBX_MAP_FULL && config.params.ignore_dbfull) {
|
if (err == MDBX_MAP_FULL && config.params.ignore_dbfull) {
|
||||||
log_notice("ttl: tail-bailout due '%s'", mdbx_strerror(err));
|
log_notice("ttl: tail-bailout due '%s'", mdbx_strerror(err));
|
||||||
@ -120,13 +120,17 @@ bool testcase_ttl::run() {
|
|||||||
log_notice("ttl: bailout at commit due '%s'", mdbx_strerror(err));
|
log_notice("ttl: bailout at commit due '%s'", mdbx_strerror(err));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (!speculum_verify()) {
|
||||||
|
log_notice("ttl: bailout after tail-trim");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
fifo.push_front(std::make_pair(serial, head_count));
|
fifo.push_front(std::make_pair(serial, head_count));
|
||||||
retry:
|
retry:
|
||||||
for (unsigned n = 0; n < head_count; ++n) {
|
for (unsigned n = 0; n < head_count; ++n) {
|
||||||
log_trace("ttl: insert-head %" PRIu64, serial);
|
log_trace("ttl: insert-head %" PRIu64, serial);
|
||||||
generate_pair(serial);
|
generate_pair(serial);
|
||||||
err = mdbx_put(txn_guard.get(), dbi, &key->value, &data->value,
|
err = insert(key, data, insert_flags);
|
||||||
insert_flags);
|
|
||||||
if (unlikely(err != MDBX_SUCCESS)) {
|
if (unlikely(err != MDBX_SUCCESS)) {
|
||||||
if (err == MDBX_MAP_FULL && config.params.ignore_dbfull) {
|
if (err == MDBX_MAP_FULL && config.params.ignore_dbfull) {
|
||||||
log_notice("ttl: head-insert skip due '%s'", mdbx_strerror(err));
|
log_notice("ttl: head-insert skip due '%s'", mdbx_strerror(err));
|
||||||
@ -149,6 +153,10 @@ bool testcase_ttl::run() {
|
|||||||
serial = fifo.front().first;
|
serial = fifo.front().first;
|
||||||
fifo.pop_front();
|
fifo.pop_front();
|
||||||
}
|
}
|
||||||
|
if (!speculum_verify()) {
|
||||||
|
log_notice("ttl: bailout after head-grow");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
report(1);
|
report(1);
|
||||||
rc = true;
|
rc = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user