mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:24:12 +08:00
mdbx-test: add seek-test for MDBX_GET_BOTH
.
Related to https://github.com/erthink/libmdbx/issues/243
This commit is contained in:
parent
76399bd643
commit
66c354baff
38
test/test.cc
38
test/test.cc
@ -641,7 +641,8 @@ enum speculum_cursors : int {
|
|||||||
prev = 1,
|
prev = 1,
|
||||||
prev_prev = 2,
|
prev_prev = 2,
|
||||||
next = 3,
|
next = 3,
|
||||||
next_next = 4
|
next_next = 4,
|
||||||
|
seek_check = 5
|
||||||
};
|
};
|
||||||
|
|
||||||
bool testcase::is_same(const Item &a, const Item &b) const {
|
bool testcase::is_same(const Item &a, const Item &b) const {
|
||||||
@ -852,11 +853,26 @@ int testcase::insert(const keygen::buffer &akey, const keygen::buffer &adata,
|
|||||||
int err;
|
int err;
|
||||||
bool rc = true;
|
bool rc = true;
|
||||||
Item item;
|
Item item;
|
||||||
|
#if SPECULUM_CURSORS
|
||||||
|
MDBX_cursor *check_seek_cursor = nullptr;
|
||||||
|
MDBX_val seek_check_key, seek_check_data;
|
||||||
|
int seek_check_err = 42;
|
||||||
|
#endif /* SPECULUM_CURSORS */
|
||||||
if (config.params.speculum) {
|
if (config.params.speculum) {
|
||||||
item.first = iov2dataview(akey);
|
item.first = iov2dataview(akey);
|
||||||
item.second = iov2dataview(adata);
|
item.second = iov2dataview(adata);
|
||||||
#if SPECULUM_CURSORS
|
#if SPECULUM_CURSORS
|
||||||
speculum_prepare_cursors(item);
|
speculum_prepare_cursors(item);
|
||||||
|
check_seek_cursor = speculum_cursors[seek_check].get();
|
||||||
|
seek_check_key = akey->value;
|
||||||
|
seek_check_data = adata->value;
|
||||||
|
seek_check_err = mdbx_cursor_get(
|
||||||
|
check_seek_cursor, &seek_check_key, &seek_check_data,
|
||||||
|
(config.params.table_flags & MDBX_DUPSORT) ? MDBX_GET_BOTH
|
||||||
|
: MDBX_SET_KEY);
|
||||||
|
if (seek_check_err != MDBX_SUCCESS && seek_check_err != MDBX_NOTFOUND)
|
||||||
|
failure("speculum-%s: %s pre-insert %d %s", "insert", "seek",
|
||||||
|
seek_check_err, mdbx_strerror(seek_check_err));
|
||||||
#endif /* SPECULUM_CURSORS */
|
#endif /* SPECULUM_CURSORS */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -881,6 +897,26 @@ int testcase::insert(const keygen::buffer &akey, const keygen::buffer &adata,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if SPECULUM_CURSORS
|
#if SPECULUM_CURSORS
|
||||||
|
if (insertion_result.second) {
|
||||||
|
if (seek_check_err != MDBX_NOTFOUND) {
|
||||||
|
log_error(
|
||||||
|
"speculum.pre-insert-seek: unexpected %d {%s, %s}", seek_check_err,
|
||||||
|
mdbx_dump_val(&seek_check_key, dump_key, sizeof(dump_key)),
|
||||||
|
mdbx_dump_val(&seek_check_data, dump_value, sizeof(dump_value)));
|
||||||
|
rc = false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (seek_check_err != MDBX_SUCCESS) {
|
||||||
|
log_error(
|
||||||
|
"speculum.pre-insert-seek: unexpected %d {%s, %s}", seek_check_err,
|
||||||
|
mdbx_dump_val(&seek_check_key, dump_key, sizeof(dump_key)),
|
||||||
|
mdbx_dump_val(&seek_check_data, dump_value, sizeof(dump_value)));
|
||||||
|
speculum_check_iterator("insert", "pre-seek", insertion_result.first,
|
||||||
|
seek_check_key, seek_check_data);
|
||||||
|
rc = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (insertion_result.first != speculum.begin()) {
|
if (insertion_result.first != speculum.begin()) {
|
||||||
const auto cursor_prev = speculum_cursors[prev].get();
|
const auto cursor_prev = speculum_cursors[prev].get();
|
||||||
auto it_prev = insertion_result.first;
|
auto it_prev = insertion_result.first;
|
||||||
|
@ -202,7 +202,7 @@ protected:
|
|||||||
#define SPECULUM_CURSORS 1
|
#define SPECULUM_CURSORS 1
|
||||||
#endif /* SPECULUM_CURSORS */
|
#endif /* SPECULUM_CURSORS */
|
||||||
#if SPECULUM_CURSORS
|
#if SPECULUM_CURSORS
|
||||||
scoped_cursor_guard speculum_cursors[5];
|
scoped_cursor_guard speculum_cursors[5 + 1];
|
||||||
void speculum_prepare_cursors(const Item &item);
|
void speculum_prepare_cursors(const Item &item);
|
||||||
void speculum_check_cursor(const char *where, const char *stage,
|
void speculum_check_cursor(const char *where, const char *stage,
|
||||||
const testcase::SET::const_iterator &it,
|
const testcase::SET::const_iterator &it,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user