X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=libraries%2Fliblmdb%2Fmtest.c;h=6fc5840c3f870db893adc5e342136a27343860cd;hb=385193cd520c3b238fe9048d47e8abf8383386bc;hp=8c8dd57835b01a9bb51587639ada7f6b83110cd2;hpb=98fe3390891c7577e5f2664a091088786da78ffb;p=openldap diff --git a/libraries/liblmdb/mtest.c b/libraries/liblmdb/mtest.c index 8c8dd57835..6fc5840c3f 100644 --- a/libraries/liblmdb/mtest.c +++ b/libraries/liblmdb/mtest.c @@ -1,6 +1,6 @@ /* mtest.c - memory-mapped database tester/toy */ /* - * Copyright 2011 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -11,12 +11,16 @@ * top-level directory of the distribution or, alternatively, at * . */ -#define _XOPEN_SOURCE 500 /* srandom(), random() */ #include #include #include #include "lmdb.h" +#define E(expr) CHECK((rc = (expr)) == MDB_SUCCESS, #expr) +#define RES(err, expr) ((rc = expr) == (err) || (CHECK(!rc, #expr), 0)) +#define CHECK(test, msg) ((test) ? (void)0 : ((void)fprintf(stderr, \ + "%s:%d: %s: %s\n", __FILE__, __LINE__, msg, mdb_strerror(rc)), abort())) + int main(int argc,char * argv[]) { int i = 0, j = 0, rc; @@ -25,130 +29,148 @@ int main(int argc,char * argv[]) MDB_val key, data; MDB_txn *txn; MDB_stat mst; - MDB_cursor *cursor; + MDB_cursor *cursor, *cur2; + MDB_cursor_op op; int count; int *values; - char sval[32]; + char sval[32] = ""; - srandom(time(NULL)); + srand(time(NULL)); - count = (random()%384) + 64; + count = (rand()%384) + 64; values = (int *)malloc(count*sizeof(int)); for(i = 0;i in each iteration, since MDB_NOOVERWRITE may modify it */ + data.mv_size = sizeof(sval); + data.mv_data = sval; + if (RES(MDB_KEYEXIST, mdb_put(txn, dbi, &key, &data, MDB_NOOVERWRITE))) { + j++; + data.mv_size = sizeof(sval); + data.mv_data = sval; + } } if (j) printf("%d duplicates skipped\n", j); - rc = mdb_txn_commit(txn); - rc = mdb_env_stat(env, &mst); + E(mdb_txn_commit(txn)); + E(mdb_env_stat(env, &mst)); - rc = mdb_txn_begin(env, NULL, 1, &txn); - rc = mdb_cursor_open(txn, dbi, &cursor); + E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn)); + E(mdb_cursor_open(txn, dbi, &cursor)); while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) { printf("key: %p %.*s, data: %p %.*s\n", key.mv_data, (int) key.mv_size, (char *) key.mv_data, data.mv_data, (int) data.mv_size, (char *) data.mv_data); } + CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get"); mdb_cursor_close(cursor); mdb_txn_abort(txn); j=0; key.mv_data = sval; - for (i= count - 1; i > -1; i-= (random()%5)) { + for (i= count - 1; i > -1; i-= (rand()%5)) { j++; txn=NULL; - rc = mdb_txn_begin(env, NULL, 0, &txn); + E(mdb_txn_begin(env, NULL, 0, &txn)); sprintf(sval, "%03x ", values[i]); - rc = mdb_del(txn, dbi, &key, NULL); - if (rc) { + if (RES(MDB_NOTFOUND, mdb_del(txn, dbi, &key, NULL))) { j--; mdb_txn_abort(txn); } else { - rc = mdb_txn_commit(txn); + E(mdb_txn_commit(txn)); } } free(values); printf("Deleted %d values\n", j); - rc = mdb_env_stat(env, &mst); - rc = mdb_txn_begin(env, NULL, 1, &txn); - rc = mdb_cursor_open(txn, dbi, &cursor); + E(mdb_env_stat(env, &mst)); + E(mdb_txn_begin(env, NULL, MDB_RDONLY, &txn)); + E(mdb_cursor_open(txn, dbi, &cursor)); printf("Cursor next\n"); while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT)) == 0) { printf("key: %.*s, data: %.*s\n", (int) key.mv_size, (char *) key.mv_data, (int) data.mv_size, (char *) data.mv_data); } + CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get"); + printf("Cursor last\n"); + E(mdb_cursor_get(cursor, &key, &data, MDB_LAST)); + printf("key: %.*s, data: %.*s\n", + (int) key.mv_size, (char *) key.mv_data, + (int) data.mv_size, (char *) data.mv_data); printf("Cursor prev\n"); while ((rc = mdb_cursor_get(cursor, &key, &data, MDB_PREV)) == 0) { printf("key: %.*s, data: %.*s\n", (int) key.mv_size, (char *) key.mv_data, (int) data.mv_size, (char *) data.mv_data); } -#if 0 - /* write ops aren't coordinated with cursors, - * this stuff all breaks - */ + CHECK(rc == MDB_NOTFOUND, "mdb_cursor_get"); + printf("Cursor last/prev\n"); + E(mdb_cursor_get(cursor, &key, &data, MDB_LAST)); + printf("key: %.*s, data: %.*s\n", + (int) key.mv_size, (char *) key.mv_data, + (int) data.mv_size, (char *) data.mv_data); + E(mdb_cursor_get(cursor, &key, &data, MDB_PREV)); + printf("key: %.*s, data: %.*s\n", + (int) key.mv_size, (char *) key.mv_data, + (int) data.mv_size, (char *) data.mv_data); + + mdb_cursor_close(cursor); + mdb_txn_abort(txn); + printf("Deleting with cursor\n"); - rc = mdb_txn_begin(env, NULL, 0, &txn); - rc = mdb_cursor_open(db, txn, &cur2); + E(mdb_txn_begin(env, NULL, 0, &txn)); + E(mdb_cursor_open(txn, dbi, &cur2)); for (i=0; i<50; i++) { - rc = mdb_cursor_get(cur2, &key, &data, MDB_NEXT); + if (RES(MDB_NOTFOUND, mdb_cursor_get(cur2, &key, &data, MDB_NEXT))) + break; printf("key: %p %.*s, data: %p %.*s\n", key.mv_data, (int) key.mv_size, (char *) key.mv_data, data.mv_data, (int) data.mv_size, (char *) data.mv_data); - rc = mdb_del(db, txn, &key, NULL); + E(mdb_del(txn, dbi, &key, NULL)); } printf("Restarting cursor in txn\n"); - rc = mdb_cursor_get(cur2, &key, &data, MDB_FIRST); - printf("key: %p %.*s, data: %p %.*s\n", - key.mv_data, (int) key.mv_size, (char *) key.mv_data, - data.mv_data, (int) data.mv_size, (char *) data.mv_data); - for (i=0; i<32; i++) { - rc = mdb_cursor_get(cur2, &key, &data, MDB_NEXT); + for (op=MDB_FIRST, i=0; i<=32; op=MDB_NEXT, i++) { + if (RES(MDB_NOTFOUND, mdb_cursor_get(cur2, &key, &data, op))) + break; printf("key: %p %.*s, data: %p %.*s\n", key.mv_data, (int) key.mv_size, (char *) key.mv_data, data.mv_data, (int) data.mv_size, (char *) data.mv_data); } mdb_cursor_close(cur2); - rc = mdb_txn_commit(txn); - mdb_cursor_close(cursor); + E(mdb_txn_commit(txn)); + printf("Restarting cursor outside txn\n"); - rc = mdb_cursor_open(db, NULL, &cursor); - rc = mdb_cursor_get(cursor, &key, &data, MDB_FIRST); - printf("key: %p %.*s, data: %p %.*s\n", - key.mv_data, (int) key.mv_size, (char *) key.mv_data, - data.mv_data, (int) data.mv_size, (char *) data.mv_data); - for (i=0; i<32; i++) { - rc = mdb_cursor_get(cursor, &key, &data, MDB_NEXT); + E(mdb_txn_begin(env, NULL, 0, &txn)); + E(mdb_cursor_open(txn, dbi, &cursor)); + for (op=MDB_FIRST, i=0; i<=32; op=MDB_NEXT, i++) { + if (RES(MDB_NOTFOUND, mdb_cursor_get(cursor, &key, &data, op))) + break; printf("key: %p %.*s, data: %p %.*s\n", key.mv_data, (int) key.mv_size, (char *) key.mv_data, data.mv_data, (int) data.mv_size, (char *) data.mv_data); } -#endif mdb_cursor_close(cursor); - mdb_close(env, dbi); - mdb_txn_abort(txn); + + mdb_dbi_close(env, dbi); mdb_env_close(env); return 0;