mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 23:04:20 +01:00
Addresses #1956 refs[t:1956] Add two more tests for the range_reverse queries
git-svn-id: file:///svn/toku/tokudb@14090 c7de825b-a66e-492c-adef-691d508d4ae1
This commit is contained in:
parent
d2cae8914e
commit
2e9838edcb
3 changed files with 341 additions and 0 deletions
|
@ -104,6 +104,8 @@ BDB_DONTRUN_TESTS = \
|
|||
test_txn_nested3 \
|
||||
test_txn_nested4 \
|
||||
backwards_10_each_le_and_msg \
|
||||
test_dupsort_set_range_reverse \
|
||||
test_dupsort_get_both_range_reverse \
|
||||
#\ ends prev line
|
||||
|
||||
# checkpoint tests depend on this header file,
|
||||
|
|
170
src/tests/test_dupsort_get_both_range_reverse.c
Normal file
170
src/tests/test_dupsort_get_both_range_reverse.c
Normal file
|
@ -0,0 +1,170 @@
|
|||
/* -*- mode: C; c-basic-offset: 4 -*- */
|
||||
#ident "Copyright (c) 2007 Tokutek Inc. All rights reserved."
|
||||
#include "test.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <assert.h>
|
||||
#include <unistd.h>
|
||||
#include <memory.h>
|
||||
#include <sys/stat.h>
|
||||
#include <db.h>
|
||||
|
||||
|
||||
static void
|
||||
db_put (DB *db, int k, int v) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key, val;
|
||||
int r = db->put(db, null_txn, dbt_init(&key, &k, sizeof k), dbt_init(&val, &v, sizeof v), DB_YESOVERWRITE);
|
||||
assert(r == 0);
|
||||
}
|
||||
|
||||
static void
|
||||
db_del (DB *db, int k) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key;
|
||||
int r = db->del(db, null_txn, dbt_init(&key, &k, sizeof k), 0);
|
||||
assert(r == 0);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_db_get (DB *db, int k, int v) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key, val;
|
||||
int r = db->get(db, null_txn, dbt_init(&key, &k, sizeof k), dbt_init_malloc(&val), 0);
|
||||
assert(r == 0);
|
||||
int vv;
|
||||
assert(val.size == sizeof vv);
|
||||
memcpy(&vv, val.data, val.size);
|
||||
assert(vv == v);
|
||||
toku_free(val.data);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_get (DBC *cursor, int k, int v) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init_malloc(&key), dbt_init_malloc(&val), DB_NEXT);
|
||||
assert(r == 0);
|
||||
assert(key.size == sizeof k);
|
||||
int kk;
|
||||
memcpy(&kk, key.data, key.size);
|
||||
assert(val.size == sizeof v);
|
||||
int vv;
|
||||
memcpy(&vv, val.data, val.size);
|
||||
if (kk != k || vv != v) printf("expect key %u got %u - %u %u\n", (uint32_t)ntohl(k), (uint32_t)ntohl(kk), (uint32_t)ntohl(v), (uint32_t)ntohl(vv));
|
||||
assert(kk == k);
|
||||
assert(vv == v);
|
||||
|
||||
toku_free(key.data);
|
||||
toku_free(val.data);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_get_both_range_reverse (DBC *cursor, int k, int v, int expectr) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init(&key, &k, sizeof k), dbt_init(&val, &v, sizeof v), DB_GET_BOTH_RANGE_REVERSE);
|
||||
assert(r == expectr);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_get_current (DBC *cursor, int k, int v) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init_malloc(&key), dbt_init_malloc(&val), DB_CURRENT);
|
||||
assert(r == 0);
|
||||
int kk, vv;
|
||||
assert(key.size == sizeof kk); memcpy(&kk, key.data, key.size); assert(kk == k);
|
||||
assert(val.size == sizeof vv); memcpy(&vv, val.data, val.size); assert(vv == v);
|
||||
toku_free(key.data); toku_free(val.data);
|
||||
}
|
||||
|
||||
|
||||
/* insert, close, delete, insert, search */
|
||||
static void
|
||||
test_icdi_search (int n, int dup_mode) {
|
||||
if (verbose) printf("test_icdi_search:%d %d\n", n, dup_mode);
|
||||
|
||||
DB_ENV * const null_env = 0;
|
||||
DB *db;
|
||||
DB_TXN * const null_txn = 0;
|
||||
const char * const fname = ENVDIR "/" "test_icdi_search.brt";
|
||||
int r;
|
||||
|
||||
r = system("rm -rf " ENVDIR); CKERR(r);
|
||||
r = toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
|
||||
|
||||
/* create the dup database file */
|
||||
r = db_create(&db, null_env, 0); assert(r == 0);
|
||||
r = db->set_flags(db, dup_mode); assert(r == 0);
|
||||
r = db->set_pagesize(db, 4096); assert(r == 0);
|
||||
r = db->open(db, null_txn, fname, "main", DB_BTREE, DB_CREATE, 0666); assert(r == 0);
|
||||
|
||||
/* insert n duplicates */
|
||||
int i;
|
||||
for (i=0; i<n; i++) {
|
||||
int k = htonl(1+n/2);
|
||||
int v = htonl(1+i);
|
||||
db_put(db, k, v);
|
||||
|
||||
expect_db_get(db, k, htonl(1));
|
||||
}
|
||||
|
||||
/* reopen the database to force nonleaf buffering */
|
||||
r = db->close(db, 0); assert(r == 0);
|
||||
r = db_create(&db, null_env, 0); assert(r == 0);
|
||||
r = db->set_flags(db, dup_mode); assert(r == 0);
|
||||
r = db->set_pagesize(db, 4096); assert(r == 0);
|
||||
r = db->open(db, null_txn, fname, "main", DB_BTREE, 0, 0666); assert(r == 0);
|
||||
|
||||
db_del(db, htonl(1+n/2));
|
||||
|
||||
/* insert n duplicates */
|
||||
for (i=0; i<n; i++) {
|
||||
int k = htonl(1+n/2);
|
||||
int v = htonl(1+n+i);
|
||||
db_put(db, k, v);
|
||||
|
||||
DBC *cursor;
|
||||
r = db->cursor(db, null_txn, &cursor, 0); assert(r == 0);
|
||||
expect_cursor_get_both_range_reverse(cursor, k, v, 0);
|
||||
expect_cursor_get_current(cursor, k, v);
|
||||
r = cursor->c_close(cursor); assert(r == 0);
|
||||
}
|
||||
|
||||
DBC *cursor;
|
||||
r = db->cursor(db, null_txn, &cursor, 0); assert(r == 0);
|
||||
expect_cursor_get_both_range_reverse(cursor, 0, 0, DB_NOTFOUND);
|
||||
expect_cursor_get_both_range_reverse(cursor, 0, 0, DB_NOTFOUND);
|
||||
if (n>1)
|
||||
expect_cursor_get_both_range_reverse(cursor, htonl(1+n/2), htonl(1+n+n), 0);
|
||||
expect_cursor_get_both_range_reverse(cursor, htonl(1+n), 0, DB_NOTFOUND);
|
||||
expect_cursor_get_both_range_reverse(cursor, htonl(1), 0, DB_NOTFOUND);
|
||||
r = cursor->c_close(cursor); assert(r == 0);
|
||||
|
||||
r = db->cursor(db, null_txn, &cursor, 0); assert(r == 0);
|
||||
for (i=0; i<n; i++) {
|
||||
expect_cursor_get(cursor, htonl(1+n/2), htonl(1+n+i));
|
||||
}
|
||||
r = cursor->c_close(cursor); assert(r == 0);
|
||||
|
||||
r = db->close(db, 0); assert(r == 0);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
test_main(int argc, char *argv[]) {
|
||||
int i;
|
||||
|
||||
parse_args(argc, argv);
|
||||
|
||||
system("rm -rf " ENVDIR);
|
||||
toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO);
|
||||
|
||||
int limit = 1<<13;
|
||||
if (verbose > 1)
|
||||
limit = 1<<16;
|
||||
|
||||
for (i=1; i <= limit; i *= 2) {
|
||||
test_icdi_search(i, DB_DUP + DB_DUPSORT);
|
||||
}
|
||||
return 0;
|
||||
}
|
169
src/tests/test_dupsort_set_range_reverse.c
Normal file
169
src/tests/test_dupsort_set_range_reverse.c
Normal file
|
@ -0,0 +1,169 @@
|
|||
/* -*- mode: C; c-basic-offset: 4 -*- */
|
||||
#ident "Copyright (c) 2007 Tokutek Inc. All rights reserved."
|
||||
#include "test.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <assert.h>
|
||||
#include <unistd.h>
|
||||
#include <memory.h>
|
||||
#include <sys/stat.h>
|
||||
#include <db.h>
|
||||
|
||||
|
||||
#ifndef DB_DELETE_ANY
|
||||
#define DB_DELETE_ANY 0
|
||||
#endif
|
||||
#ifndef DB_YESOVERWRITE
|
||||
#define DB_YESOVERWRITE 0
|
||||
#endif
|
||||
|
||||
static void
|
||||
db_put (DB *db, int k, int v) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key, val;
|
||||
int r = db->put(db, null_txn, dbt_init(&key, &k, sizeof k), dbt_init(&val, &v, sizeof v), DB_YESOVERWRITE);
|
||||
assert(r == 0);
|
||||
}
|
||||
|
||||
static void
|
||||
db_del (DB *db, int k) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key;
|
||||
int r = db->del(db, null_txn, dbt_init(&key, &k, sizeof k), DB_DELETE_ANY);
|
||||
assert(r == 0);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_db_get (DB *db, int k, int v) {
|
||||
DB_TXN * const null_txn = 0;
|
||||
DBT key, val;
|
||||
int r = db->get(db, null_txn, dbt_init(&key, &k, sizeof k), dbt_init_malloc(&val), 0);
|
||||
assert(r == 0);
|
||||
int vv;
|
||||
assert(val.size == sizeof vv);
|
||||
memcpy(&vv, val.data, val.size);
|
||||
assert(vv == v);
|
||||
toku_free(val.data);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_get (DBC *cursor, int k, int v) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init_malloc(&key), dbt_init_malloc(&val), DB_NEXT);
|
||||
assert(r == 0);
|
||||
assert(key.size == sizeof k);
|
||||
int kk;
|
||||
memcpy(&kk, key.data, key.size);
|
||||
assert(val.size == sizeof v);
|
||||
int vv;
|
||||
memcpy(&vv, val.data, val.size);
|
||||
if (kk != k || vv != v) printf("expect key %u got %u - %u %u\n", (uint32_t)htonl(k), (uint32_t)htonl(kk), (uint32_t)htonl(v), (uint32_t)htonl(vv));
|
||||
assert(kk == k);
|
||||
assert(vv == v);
|
||||
|
||||
toku_free(key.data);
|
||||
toku_free(val.data);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_set_range_reverse (DBC *cursor, int k) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init(&key, &k, sizeof k), dbt_init_malloc(&val), DB_SET_RANGE_REVERSE);
|
||||
assert(r == 0);
|
||||
toku_free(val.data);
|
||||
}
|
||||
|
||||
static void
|
||||
expect_cursor_get_current (DBC *cursor, int k, int v) {
|
||||
DBT key, val;
|
||||
int r = cursor->c_get(cursor, dbt_init_malloc(&key), dbt_init_malloc(&val), DB_CURRENT);
|
||||
assert(r == 0);
|
||||
int kk, vv;
|
||||
assert(key.size == sizeof kk); memcpy(&kk, key.data, key.size); assert(kk == k);
|
||||
assert(val.size == sizeof vv); memcpy(&vv, val.data, val.size); assert(vv == v);
|
||||
toku_free(key.data); toku_free(val.data);
|
||||
}
|
||||
|
||||
|
||||
/* insert, close, delete, insert, search */
|
||||
static void
|
||||
test_icdi_search (int n, int dup_mode) {
|
||||
int r;
|
||||
|
||||
if (verbose) printf("test_icdi_search:%d %d\n", n, dup_mode);
|
||||
|
||||
DB_ENV * const null_env = 0;
|
||||
DB *db;
|
||||
DB_TXN * const null_txn = 0;
|
||||
const char * const fname = ENVDIR "/" "test_icdi_search.brt";
|
||||
|
||||
r = system("rm -rf " ENVDIR); CKERR(r);
|
||||
r = toku_os_mkdir(ENVDIR, S_IRWXU+S_IRWXG+S_IRWXO); CKERR(r);
|
||||
|
||||
/* create the dup database file */
|
||||
r = db_create(&db, null_env, 0); assert(r == 0);
|
||||
r = db->set_flags(db, dup_mode); assert(r == 0);
|
||||
r = db->set_pagesize(db, 4096); assert(r == 0);
|
||||
r = db->open(db, null_txn, fname, "main", DB_BTREE, DB_CREATE, 0666); assert(r == 0);
|
||||
|
||||
/* insert n duplicates */
|
||||
int i;
|
||||
for (i=0; i<n; i++) {
|
||||
int k = htonl(n/2);
|
||||
int v = htonl(i);
|
||||
db_put(db, k, v);
|
||||
|
||||
expect_db_get(db, k, htonl(0));
|
||||
}
|
||||
|
||||
/* reopen the database to force nonleaf buffering */
|
||||
r = db->close(db, 0); assert(r == 0);
|
||||
r = db_create(&db, null_env, 0); assert(r == 0);
|
||||
r = db->set_flags(db, dup_mode); assert(r == 0);
|
||||
r = db->set_pagesize(db, 4096); assert(r == 0);
|
||||
r = db->open(db, null_txn, fname, "main", DB_BTREE, 0, 0666); assert(r == 0);
|
||||
|
||||
db_del(db, htonl(n/2));
|
||||
|
||||
/* insert n duplicates */
|
||||
for (i=0; i < n; i++) {
|
||||
int k = htonl(n/2);
|
||||
int v = htonl(n+i);
|
||||
db_put(db, k, v);
|
||||
|
||||
DBC *cursor;
|
||||
r = db->cursor(db, 0, &cursor, 0); assert(r == 0);
|
||||
expect_cursor_set_range_reverse(cursor, k);
|
||||
expect_cursor_get_current(cursor, k, htonl(n+i));
|
||||
r = cursor->c_close(cursor); assert(r == 0);
|
||||
}
|
||||
|
||||
DBC *cursor;
|
||||
r = db->cursor(db, null_txn, &cursor, 0); assert(r == 0);
|
||||
|
||||
for (i=0; i<n; i++) {
|
||||
expect_cursor_get(cursor, htonl(n/2), htonl(n+i));
|
||||
}
|
||||
|
||||
r = cursor->c_close(cursor); assert(r == 0);
|
||||
|
||||
r = db->close(db, 0); assert(r == 0);
|
||||
}
|
||||
|
||||
|
||||
int
|
||||
test_main(int argc, char *argv[]) {
|
||||
int i;
|
||||
|
||||
parse_args(argc, argv);
|
||||
|
||||
int limit = 1<<13;
|
||||
if (verbose > 1)
|
||||
limit = 1<<16;
|
||||
|
||||
for (i = 1; i <= limit; i *= 2) {
|
||||
test_icdi_search(i, DB_DUP + DB_DUPSORT);
|
||||
}
|
||||
return 0;
|
||||
}
|
Loading…
Add table
Reference in a new issue