log-test7.c 2.5 KB
Newer Older
1 2
/* -*- mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
// vim: expandtab:ts=8:sw=4:softtabstop=4:
3
#ident "$Id$"
Yoni Fogel's avatar
Yoni Fogel committed
4 5 6 7 8 9
#ident "Copyright (c) 2007, 2008 Tokutek Inc.  All rights reserved."

#include "test.h"

#include "includes.h"

10
#ifndef dname
11
#define dname __SRCFILE__ ".dir"
12
#endif
Yoni Fogel's avatar
Yoni Fogel committed
13 14 15 16 17 18 19 20
#define rmrf "rm -rf " dname "_*/"

// create and close, making sure that everything is deallocated properly.

#define LSIZE 100
#define NUM_LOGGERS 10
TOKULOGGER logger[NUM_LOGGERS];

21
static void setup_logger(int which) {
Yoni Fogel's avatar
Yoni Fogel committed
22 23
    char dnamewhich[200];
    int r;
24
    snprintf(dnamewhich, sizeof(dnamewhich), "%s_%d", dname, which);
25 26 27 28 29 30
    r = toku_os_mkdir(dnamewhich, S_IRWXU);
    if (r!=0) {
        int er = get_error_errno();
        printf("file %s error (%d) %s\n", dnamewhich, er, strerror(er));
        assert(r==0);
    }
Yoni Fogel's avatar
Yoni Fogel committed
31 32 33 34 35 36 37 38 39 40 41 42
    r = toku_logger_create(&logger[which]);
    assert(r == 0);
    r = toku_logger_set_lg_max(logger[which], LSIZE);
    {
	u_int32_t n;
	r = toku_logger_get_lg_max(logger[which], &n);
	assert(n==LSIZE);
    }
    r = toku_logger_open(dnamewhich, logger[which]);
    assert(r == 0);
}

43
static void play_with_logger(int which) {
Yoni Fogel's avatar
Yoni Fogel committed
44 45
    int r;
    {
46
	ml_lock(&logger[which]->input_lock);
Yoni Fogel's avatar
Yoni Fogel committed
47
	int lsize=LSIZE-12-2;
48 49 50 51 52
	r = toku_logger_make_space_in_inbuf(logger[which], lsize);       assert(r==0); 
	snprintf(logger[which]->inbuf.buf+logger[which]->inbuf.n_in_buf, lsize, "a%*d", lsize-1, 0);
	logger[which]->inbuf.n_in_buf += lsize;
	logger[which]->lsn.lsn++;
	logger[which]->inbuf.max_lsn_in_buf = logger[which]->lsn;
53
	ml_unlock(&logger[which]->input_lock);
Yoni Fogel's avatar
Yoni Fogel committed
54 55 56
    }

    {
57
	ml_lock(&logger[which]->input_lock);
58 59 60 61 62
	r = toku_logger_make_space_in_inbuf(logger[which], 2);           assert(r==0);
	memcpy(logger[which]->inbuf.buf+logger[which]->inbuf.n_in_buf, "b1", 2);
	logger[which]->inbuf.n_in_buf += 2;
	logger[which]->lsn.lsn++;
	logger[which]->inbuf.max_lsn_in_buf = logger[which]->lsn;
63
	ml_unlock(&logger[which]->input_lock);
Yoni Fogel's avatar
Yoni Fogel committed
64 65 66
    }
}

67
static void tear_down_logger(int which) {
Yoni Fogel's avatar
Yoni Fogel committed
68 69 70 71 72 73 74 75 76 77 78
    int r;
    r = toku_logger_close(&logger[which]);
    assert(r == 0);
}

int
test_main (int argc __attribute__((__unused__)),
	  const char *argv[] __attribute__((__unused__))) {
    int i;
    int loop;
    const int numloops = 100;
79
    int r;
Yoni Fogel's avatar
Yoni Fogel committed
80
    for (loop = 0; loop < numloops; loop++) {
81 82
        r = system(rmrf);
        CKERR(r);
Yoni Fogel's avatar
Yoni Fogel committed
83 84 85 86
        for (i = 0; i < NUM_LOGGERS; i++) setup_logger(i);
        for (i = 0; i < NUM_LOGGERS; i++) play_with_logger(i);
        for (i = 0; i < NUM_LOGGERS; i++) tear_down_logger(i);
    }
87 88
    r = system(rmrf);
    CKERR(r);
Yoni Fogel's avatar
Yoni Fogel committed
89 90 91

    return 0;
}