mdbx-test: фиксация транзакции при ошибках теста для последующего анализа БД.

This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2024-02-28 02:24:53 +03:00
parent d53dc4572c
commit d7f259110c
2 changed files with 13 additions and 0 deletions

View File

@ -753,6 +753,18 @@ void testcase::speculum_check_iterator(const char *where, const char *stage,
mdbx_dump_val(&v, dump_value, sizeof(dump_value))); mdbx_dump_val(&v, dump_value, sizeof(dump_value)));
} }
void testcase::failure(const char *fmt, ...) const {
va_list ap;
va_start(ap, fmt);
fflush(nullptr);
logging::output_nocheckloglevel_ap(logging::failure, fmt, ap);
va_end(ap);
fflush(nullptr);
if (txn_guard)
mdbx_txn_commit(const_cast<testcase *>(this)->txn_guard.release());
exit(EXIT_FAILURE);
}
#if SPECULUM_CURSORS #if SPECULUM_CURSORS
void testcase::speculum_check_cursor(const char *where, const char *stage, void testcase::speculum_check_cursor(const char *where, const char *stage,
const testcase::SET::const_iterator &it, const testcase::SET::const_iterator &it,

View File

@ -281,6 +281,7 @@ protected:
void signal(); void signal();
bool should_continue(bool check_timeout_only = false) const; bool should_continue(bool check_timeout_only = false) const;
void failure(const char *fmt, ...) const;
void generate_pair(const keygen::serial_t serial, keygen::buffer &out_key, void generate_pair(const keygen::serial_t serial, keygen::buffer &out_key,
keygen::buffer &out_value, keygen::serial_t data_age) { keygen::buffer &out_value, keygen::serial_t data_age) {
keyvalue_maker.pair(serial, out_key, out_value, data_age, false); keyvalue_maker.pair(serial, out_key, out_value, data_age, false);