1 #define _XOPEN_SOURCE 500
6 #include "tdb/freelist.c"
7 #include "tdb/traverse.c"
8 #include "tdb/transaction.c"
16 static bool correct_key(TDB_DATA key)
18 return key.dsize == strlen("hi")
19 && memcmp(key.dptr, "hi", key.dsize) == 0;
22 static bool correct_data(TDB_DATA data)
24 return data.dsize == strlen("world")
25 && memcmp(data.dptr, "world", data.dsize) == 0;
28 static int traverse2(struct tdb_context *tdb, TDB_DATA key, TDB_DATA data,
31 ok1(correct_key(key));
32 ok1(correct_data(data));
36 static int traverse1(struct tdb_context *tdb, TDB_DATA key, TDB_DATA data,
39 ok1(correct_key(key));
40 ok1(correct_data(data));
41 ok1(tdb->have_transaction_lock);
42 tdb_traverse(tdb, traverse2, NULL);
44 /* That should *not* release the transaction lock! */
45 ok1(tdb->have_transaction_lock);
49 int main(int argc, char *argv[])
51 struct tdb_context *tdb;
55 tdb = tdb_open("/tmp/test.tdb", 1024, TDB_CLEAR_IF_FIRST,
56 O_CREAT|O_TRUNC|O_RDWR, 0600);
59 /* Tickle bug on appending zero length buffer to zero length buffer. */
60 key.dsize = strlen("hi");
61 key.dptr = (void *)"hi";
62 data.dptr = (void *)"world";
63 data.dsize = strlen("world");
65 ok1(tdb_store(tdb, key, data, TDB_INSERT) == 0);
66 tdb_traverse(tdb, traverse1, NULL);
67 tdb_traverse_read(tdb, traverse1, NULL);