1 #include <ccan/tdb2/tdb.c>
2 #include <ccan/tdb2/open.c>
3 #include <ccan/tdb2/free.c>
4 #include <ccan/tdb2/lock.c>
5 #include <ccan/tdb2/io.c>
6 #include <ccan/tdb2/hash.c>
7 #include <ccan/tdb2/check.c>
8 #include <ccan/tdb2/transaction.c>
9 #include <ccan/tdb2/traverse.c>
10 #include <ccan/tap/tap.h>
13 int main(int argc, char *argv[])
16 struct tdb_context *tdb;
17 int flags[] = { TDB_DEFAULT, TDB_NOMMAP,
18 TDB_CONVERT, TDB_NOMMAP|TDB_CONVERT };
20 plan_tests(sizeof(flags) / sizeof(flags[0]) * 11);
22 for (i = 0; i < sizeof(flags) / sizeof(flags[0]); i++) {
23 union tdb_attribute *attr;
24 struct tdb_data key = tdb_mkdata("key", 3);
26 tdb = tdb_open("run-91-get-stats.tdb", flags[i],
27 O_RDWR|O_CREAT|O_TRUNC, 0600, &tap_log_attr);
29 ok1(tdb_store(tdb, key, key, TDB_REPLACE) == 0);
31 /* Use malloc so valgrind will catch overruns. */
32 attr = malloc(sizeof *attr);
33 attr->stats.base.attr = TDB_ATTRIBUTE_STATS;
34 attr->stats.size = sizeof(*attr);
36 ok1(tdb_get_attribute(tdb, attr) == 0);
37 ok1(attr->stats.size == sizeof(*attr));
38 ok1(attr->stats.allocs > 0);
39 ok1(attr->stats.expands > 0);
40 ok1(attr->stats.locks > 0);
44 attr = malloc(offsetof(struct tdb_attribute_stats, allocs)
45 + sizeof(attr->stats.allocs));
46 attr->stats.base.attr = TDB_ATTRIBUTE_STATS;
47 attr->stats.size = offsetof(struct tdb_attribute_stats, allocs)
48 + sizeof(attr->stats.allocs);
49 ok1(tdb_get_attribute(tdb, attr) == 0);
50 ok1(attr->stats.size == sizeof(*attr));
51 ok1(attr->stats.allocs > 0);
53 ok1(tap_log_messages == 0);