cachetable-prefetch-close-test.c 3.26 KB
Newer Older
1 2 3
/* -*- mode: C; c-basic-offset: 4 -*- */

// verify that closing the cachetable with prefetches in progress works
4 5
#ident "$Id$"
#ident "Copyright (c) 2007-2011 Tokutek Inc.  All rights reserved."
6 7 8
#include "includes.h"
#include "test.h"

Zardosht Kasheff's avatar
Zardosht Kasheff committed
9 10
BOOL expect_pf;

11 12
static void
flush (CACHEFILE f __attribute__((__unused__)),
13
       int UU(fd),
14 15
       CACHEKEY k  __attribute__((__unused__)),
       void *v     __attribute__((__unused__)),
Zardosht Kasheff's avatar
Zardosht Kasheff committed
16
       void** UU(dd),
17
       void *e     __attribute__((__unused__)),
Zardosht Kasheff's avatar
Zardosht Kasheff committed
18 19
       PAIR_ATTR s      __attribute__((__unused__)),
       PAIR_ATTR* new_size      __attribute__((__unused__)),
20 21
       BOOL w      __attribute__((__unused__)),
       BOOL keep   __attribute__((__unused__)),
Zardosht Kasheff's avatar
Zardosht Kasheff committed
22 23
       BOOL c      __attribute__((__unused__)),
        BOOL UU(is_clone)
24 25 26 27 28 29 30 31
       ) {
    assert(w == FALSE);
}

static int fetch_calls = 0;

static int
fetch (CACHEFILE f        __attribute__((__unused__)),
32
       int UU(fd),
33 34 35
       CACHEKEY k         __attribute__((__unused__)),
       u_int32_t fullhash __attribute__((__unused__)),
       void **value       __attribute__((__unused__)),
Zardosht Kasheff's avatar
Zardosht Kasheff committed
36
       void** UU(dd),
Zardosht Kasheff's avatar
Zardosht Kasheff committed
37
       PAIR_ATTR *sizep        __attribute__((__unused__)),
38
       int  *dirtyp       __attribute__((__unused__)),
39
       void *extraargs    __attribute__((__unused__))
40 41 42
       ) {

    fetch_calls++;
Zardosht Kasheff's avatar
Zardosht Kasheff committed
43
    sleep(2);
44 45

    *value = 0;
Zardosht Kasheff's avatar
Zardosht Kasheff committed
46
    *sizep = make_pair_attr(1);
47
    *dirtyp = 0;
48 49 50 51

    return 0;
}

Zardosht Kasheff's avatar
Zardosht Kasheff committed
52 53 54
static void cachetable_prefetch_full_test (BOOL partial_fetch) {
    const int test_limit = 2;
    expect_pf = FALSE;
55 56 57
    int r;
    CACHETABLE ct;
    r = toku_create_cachetable(&ct, test_limit, ZERO_LSN, NULL_LOGGER); assert(r == 0);
58
    char fname1[] = __SRCFILE__ "test1.dat";
59 60
    unlink(fname1);
    CACHEFILE f1;
Yoni Fogel's avatar
Yoni Fogel committed
61
    r = toku_cachetable_openf(&f1, ct, fname1, O_RDWR|O_CREAT, S_IRWXU|S_IRWXG|S_IRWXO); assert(r == 0);
62

Zardosht Kasheff's avatar
Zardosht Kasheff committed
63
    // prefetch block 0. this will take 2 seconds.
64 65
    CACHEKEY key = make_blocknum(0);
    u_int32_t fullhash = toku_cachetable_hash(f1, make_blocknum(0));
Zardosht Kasheff's avatar
Zardosht Kasheff committed
66 67 68 69

    // if we want to do a test of partial fetch,
    // we first put the key into the cachefile so that
    // the subsequent prefetch does a partial fetch
Zardosht Kasheff's avatar
Zardosht Kasheff committed
70 71
    CACHETABLE_WRITE_CALLBACK wc = def_write_callback(NULL);
    wc.flush_callback = flush;
Zardosht Kasheff's avatar
Zardosht Kasheff committed
72 73 74 75 76 77 78 79 80 81
    if (partial_fetch) {
        expect_pf = TRUE;
        void* value;
        long size;
        r = toku_cachetable_get_and_pin(
            f1, 
            key, 
            fullhash, 
            &value, 
            &size, 
Zardosht Kasheff's avatar
Zardosht Kasheff committed
82
            wc, 
Zardosht Kasheff's avatar
Zardosht Kasheff committed
83
            fetch,
Zardosht Kasheff's avatar
Zardosht Kasheff committed
84 85
            def_pf_req_callback,
            def_pf_callback,
Zardosht Kasheff's avatar
Zardosht Kasheff committed
86
            TRUE, 
Zardosht Kasheff's avatar
Zardosht Kasheff committed
87 88 89
            0
            );
        assert(r==0);
Zardosht Kasheff's avatar
Zardosht Kasheff committed
90
        r = toku_cachetable_unpin(f1, key, fullhash, CACHETABLE_CLEAN, make_pair_attr(1));
Zardosht Kasheff's avatar
Zardosht Kasheff committed
91 92
    }
    
Zardosht Kasheff's avatar
Zardosht Kasheff committed
93
    r = toku_cachefile_prefetch(f1, key, fullhash, wc, fetch, def_pf_req_callback, def_pf_callback, 0, NULL);
94 95 96 97
    toku_cachetable_verify(ct);

    // close with the prefetch in progress. the close should block until
    // all of the reads and writes are complete.
98
    r = toku_cachefile_close(&f1, 0, FALSE, ZERO_LSN); assert(r == 0);
99 100 101 102 103 104
    r = toku_cachetable_close(&ct); assert(r == 0 && ct == 0);
}

int
test_main(int argc, const char *argv[]) {
    default_parse_args(argc, argv);
Zardosht Kasheff's avatar
Zardosht Kasheff committed
105 106
    cachetable_prefetch_full_test(TRUE);
    cachetable_prefetch_full_test(FALSE);
107 108
    return 0;
}