tdb2: clean up logging
[ccan] / ccan / tdb2 / test / run-001-encode.c
1 #include <ccan/tdb2/tdb.c>
2 #include <ccan/tdb2/free.c>
3 #include <ccan/tdb2/lock.c>
4 #include <ccan/tdb2/hash.c>
5 #include <ccan/tdb2/io.c>
6 #include <ccan/tdb2/transaction.c>
7 #include <ccan/tdb2/check.c>
8 #include <ccan/tap/tap.h>
9 #include "logging.h"
10
11 int main(int argc, char *argv[])
12 {
13         unsigned int i;
14         struct tdb_used_record rec;
15         struct tdb_context tdb = { .logfn = tap_log_fn };
16
17         plan_tests(64 + 32 + 48*6 + 1);
18
19         /* We should be able to encode any data value. */
20         for (i = 0; i < 64; i++)
21                 ok1(set_used_header(&tdb, &rec, 0, 1ULL << i, 1ULL << i, 0)
22                     == 0);
23
24         /* And any key and data with < 64 bits between them. */
25         for (i = 0; i < 32; i++) {
26                 tdb_len_t dlen = 1ULL >> (63 - i), klen = 1ULL << i;
27                 ok1(set_used_header(&tdb, &rec, klen, dlen, klen + dlen, 0)
28                     == 0);
29         }
30
31         /* We should neatly encode all values. */
32         for (i = 0; i < 48; i++) {
33                 uint64_t h = 1ULL << (i < 5 ? i : 4);
34                 uint64_t klen = 1ULL << (i < 16 ? i : 15);
35                 uint64_t dlen = 1ULL << i;
36                 uint64_t xlen = 1ULL << (i < 32 ? i : 31);
37                 ok1(set_used_header(&tdb, &rec, klen, dlen, klen+dlen+xlen, h)
38                     == 0);
39                 ok1(rec_key_length(&rec) == klen);
40                 ok1(rec_data_length(&rec) == dlen);
41                 ok1(rec_extra_padding(&rec) == xlen);
42                 ok1((uint64_t)rec_hash(&rec) == h);
43                 ok1(rec_magic(&rec) == TDB_MAGIC);
44         }
45         ok1(tap_log_messages == 0);
46         return exit_status();
47 }