#ident "$Id$" #include "includes.h" #include "test.h" static void cachetable_debug_test (int n) { const int test_limit = n; int r; CACHETABLE ct; r = toku_create_cachetable(&ct, test_limit, ZERO_LSN, NULL_LOGGER); assert(r == 0); char fname1[] = __FILE__ "test1.dat"; unlink(fname1); CACHEFILE f1; r = toku_cachetable_openf(&f1, ct, fname1, O_RDWR|O_CREAT, S_IRWXU|S_IRWXG|S_IRWXO); assert(r == 0); int num_entries, hash_size; long size_current, size_limit, size_max; toku_cachetable_get_state(ct, &num_entries, &hash_size, &size_current, &size_limit, &size_max); assert(num_entries == 0); assert(size_current == 0); assert(size_limit == n); // printf("%d %d %ld %ld\n", num_entries, hash_size, size_current, size_limit); int i; for (i=1; i<=n; i++) { const int item_size = 1; u_int32_t hi; hi = toku_cachetable_hash(f1, make_blocknum(i)); r = toku_cachetable_put(f1, make_blocknum(i), hi, (void *)(long)i, make_pair_attr(item_size), def_flush, def_pe_est_callback, def_pe_callback, def_cleaner_callback, 0); assert(r == 0); void *v; int dirty; long long pinned; long pair_size; r = toku_cachetable_get_key_state(ct, make_blocknum(i), f1, &v, &dirty, &pinned, &pair_size); assert(r == 0); assert(v == (void *)(long)i); assert(dirty == CACHETABLE_DIRTY); assert(pinned == 1); assert(pair_size == item_size); r = toku_cachetable_unpin(f1, make_blocknum(i), hi, CACHETABLE_CLEAN, make_pair_attr(1)); assert(r == 0); toku_cachetable_get_state(ct, &num_entries, &hash_size, &size_current, &size_limit, &size_max); assert(num_entries == i); assert(size_current == i); assert(size_limit == n); if (verbose) toku_cachetable_print_state(ct); } toku_cachetable_verify(ct); if (verbose) toku_cachetable_print_hash_histogram(); r = toku_cachefile_close(&f1, 0, FALSE, ZERO_LSN); assert(r == 0 && f1 == 0); r = toku_cachetable_close(&ct); assert(r == 0 && ct == 0); } int test_main(int argc, const char *argv[]) { default_parse_args(argc, argv); cachetable_debug_test(8); return 0; }