test_00040_write.c 10.3 KB
Newer Older
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
1 2 3 4
/* We are going to test whether create and close properly check their input. */

#include "test.h"

Yoni Fogel's avatar
Yoni Fogel committed
5 6
toku_range_tree* toku__lt_ifexist_selfwrite(toku_lock_tree* tree, DB_TXN* txn);
toku_range_tree* toku__lt_ifexist_selfread(toku_lock_tree* tree, DB_TXN* txn);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49

int r;
toku_lock_tree* lt  = NULL;
DB*             db  = (DB*)1;
u_int32_t mem = 1000;
u_int32_t memcnt = 0;
BOOL duplicates = FALSE;
int  nums[100];

DBT _key_left[2];
DBT _key_right[2];
DBT _data_left[2];
DBT _data_right[2];
DBT* key_left[2]   ;
DBT* key_right[2]  ;
DBT* data_left [2] ;
DBT* data_right[2] ;

toku_point qleft, qright;
toku_range query;
toku_range* buf;
unsigned buflen;
unsigned numfound;

void init_query(BOOL dups) {  
    init_point(&qleft,  lt);
    init_point(&qright, lt);
    
    qleft.key_payload  = (void *) toku_lt_neg_infinity;
    qright.key_payload = (void *) toku_lt_infinity;

    if (dups) {
        qleft.data_payload  = qleft.key_payload;
        qright.data_payload = qright.key_payload;
    }

    memset(&query,0,sizeof(query));
    query.left  = &qleft;
    query.right = &qright;
}

void setup_tree(BOOL dups) {
    memcnt = 0;
Yoni Fogel's avatar
Yoni Fogel committed
50
    r = toku_lt_create(&lt, db, dups, dbpanic, &mem, &memcnt, dbcmp, dbcmp,
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162
                       toku_malloc, toku_free, toku_realloc);
    CKERR(r);
    assert(lt);
    init_query(dups);
}

void close_tree(void) {
    assert(lt);
    r = toku_lt_close(lt);
    CKERR(r);
    lt = NULL;
}

typedef enum { null = -1, infinite = -2, neg_infinite = -3 } lt_infty;

DBT* set_to_infty(DBT *dbt, lt_infty value) {
    if (value == infinite) return (DBT*)toku_lt_infinity;
    if (value == neg_infinite) return (DBT*)toku_lt_neg_infinity;
    if (value == null) return dbt_init(dbt, NULL, 0);
    assert(value >= 0);
    return                    dbt_init(dbt, &nums[value], sizeof(nums[0]));
}


void lt_insert(BOOL dups, int r_expect, char txn, int key_l, int data_l, 
               int key_r, int data_r, BOOL read_flag) {
    DBT _key_left;
    DBT _key_right;
    DBT _data_left;
    DBT _data_right;
    DBT* key_left   = &_key_left;
    DBT* key_right  = &_key_right;
    DBT* data_left  = dups ? &_data_left : NULL;
    DBT* data_right = dups ? &_data_right: NULL;

    key_left  = set_to_infty(key_left,  key_l);
    key_right = set_to_infty(key_right, key_r);
    if (dups) {
        if (key_left != &_key_left) data_left = key_left;
        else data_left = set_to_infty(data_left,  data_l);
        if (key_right != &_key_right) data_right = key_right;
        else data_right = set_to_infty(data_right,  data_r);
        assert(key_left  && data_left);
        assert(!read_flag || (key_right && data_right));
    } else {
        data_left = data_right = NULL;
        assert(key_left  && !data_left);
        assert(!read_flag || (key_right && !data_right));
    }

    DB_TXN* local_txn = (DB_TXN*) (size_t) txn;

    if (read_flag)
        r = toku_lt_acquire_range_read_lock(lt, local_txn, key_left,  data_left,
                                            key_right, data_right);
    else
        r = toku_lt_acquire_write_lock(lt, local_txn, key_left,  data_left);
    CKERR2(r, r_expect);
}

void lt_insert_read(BOOL dups, int r_expect, char txn, int key_l, int data_l, 
                    int key_r, int data_r) {
    lt_insert(dups, r_expect, txn, key_l, data_l, key_r, data_r, TRUE);
}

void lt_insert_write(BOOL dups, int r_expect, char txn, int key_l, int data_l) {
    lt_insert(dups, r_expect, txn, key_l, data_l, 0, 0, FALSE);
}


void setup_payload_len(void** payload, u_int32_t* len, int val) {
    assert(payload && len);

    DBT temp;

    *payload = set_to_infty(&temp, val);
    
    if (val < 0) {
        *len = 0;
    }
    else {
        *len = sizeof(nums[0]);
        *payload = temp.data;
    }
}

void lt_find(BOOL dups, toku_range_tree* rt,
                        unsigned k, int key_l, int data_l,
                                    int key_r, int data_r,
                                    char char_txn) {

    r = toku_rt_find(rt, &query, 0, &buf, &buflen, &numfound);
    CKERR(r);
    assert(numfound==k);

    DB_TXN* find_txn = (DB_TXN *) (size_t) char_txn;

    toku_point left, right;
    init_point(&left, lt);
    setup_payload_len(&left.key_payload, &left.key_len, key_l);
    if (dups) {
        if (key_l < null) left.data_payload = left.key_payload;
        else setup_payload_len(&left.data_payload, &left.data_len, data_l);
    }
    init_point(&right, lt);
    setup_payload_len(&right.key_payload, &right.key_len, key_r);
    if (dups) {
        if (key_r < null) right.data_payload = right.key_payload;
        else setup_payload_len(&right.data_payload, &right.data_len, data_r);
    }
    unsigned i;
    for (i = 0; i < numfound; i++) {
Yoni Fogel's avatar
Yoni Fogel committed
163 164
        if (toku__lt_point_cmp(buf[i].left,  &left ) == 0 &&
            toku__lt_point_cmp(buf[i].right, &right) == 0 &&
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200
            buf[i].data == find_txn) return;
    }
    assert(FALSE);  //Crash since we didn't find it.
}

void lt_unlock(char ctxn) {
  int r;
  r = toku_lt_unlock(lt, (DB_TXN *) (size_t) ctxn);
  CKERR(r);
}
              
void runtest(BOOL dups) {
    
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 1, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 1, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_read (dups, 0, 'a', 1, 1, 1, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
Yoni Fogel's avatar
Yoni Fogel committed
201
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'b', 1, 1, 1, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
202 203 204 205
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_read (dups, 0, 'b', 1, 1, 1, 1);
Yoni Fogel's avatar
Yoni Fogel committed
206
    lt_insert_write(dups, DB_LOCK_NOTGRANTED, 'a', 1, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
207 208 209 210 211 212 213 214
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
Yoni Fogel's avatar
Yoni Fogel committed
215
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'b', 2, 1, 4, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
216 217 218 219 220 221 222 223
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
Yoni Fogel's avatar
Yoni Fogel committed
224
    lt_insert_write (dups, DB_LOCK_NOTGRANTED, 'b', 2, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
    lt_insert_read (dups, 0, 'b', 3, 1, 3, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
    lt_insert_read (dups, 0, 'b', 3, 1, 3, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'b', 1, 1);
    lt_insert_write(dups, 0, 'b', 2, 1);
    lt_insert_write(dups, 0, 'b', 3, 1);
    lt_insert_write(dups, 0, 'b', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
    lt_insert_write(dups, 0, 'a', 6, 1);
    lt_insert_write(dups, 0, 'a', 7, 1);
    lt_insert_write(dups, 0, 'a', 8, 1);
    lt_insert_write(dups, 0, 'a', 9, 1);
Yoni Fogel's avatar
Yoni Fogel committed
253
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'a', 3, 1, 7, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
254 255 256 257 258 259 260 261 262 263 264 265
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'b', 1, 1);
    lt_insert_write(dups, 0, 'b', 2, 1);
    lt_insert_write(dups, 0, 'b', 3, 1);
    lt_insert_write(dups, 0, 'b', 4, 1);
    lt_insert_write(dups, 0, 'b', 5, 1);
    lt_insert_write(dups, 0, 'b', 6, 1);
    lt_insert_write(dups, 0, 'b', 7, 1);
    lt_insert_write(dups, 0, 'b', 8, 1);
    lt_insert_write(dups, 0, 'b', 9, 1);
Yoni Fogel's avatar
Yoni Fogel committed
266
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'a', 3, 1, 7, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
267 268 269 270 271 272 273 274 275 276 277 278 279 280 281
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_read (dups, 0, 'a', 3, 1, 7, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'b', 1, 1);
    lt_insert_write(dups, 0, 'b', 2, 1);
    lt_insert_write(dups, 0, 'b', 3, 1);
    lt_insert_write(dups, 0, 'b', 4, 1);
Yoni Fogel's avatar
Yoni Fogel committed
282
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'a', 3, 1, 7, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
    lt_insert_write(dups, 0, 'a', 5, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'b', 4, 1);
    lt_insert_write(dups, 0, 'b', 5, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 2, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    lt_insert_write(dups, 0, 'a', 4, 1);
Yoni Fogel's avatar
Yoni Fogel committed
306
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'b', 3, 1, 3, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
307 308
    lt_unlock('a');
    lt_insert_write(dups, 0, 'b', 3, 1);
Yoni Fogel's avatar
Yoni Fogel committed
309
    lt_insert_read (dups, DB_LOCK_NOTGRANTED, 'a', 3, 1, 3, 1);
Vincenzo Liberatore's avatar
Vincenzo Liberatore committed
310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345
    lt_unlock('b');
    lt_insert_read (dups, 0, 'a', 3, 1, 3, 1);
    close_tree();
    /* ********************* */
    setup_tree(dups);
    lt_insert_write(dups, 0, 'a', 1, 1);
    lt_insert_write(dups, 0, 'a', 3, 1);
    lt_insert_write(dups, 0, 'b', 2, 1);
    lt_unlock('b');
    close_tree();
    /* ********************* */
}


void init_test(void) {
    unsigned i;
    for (i = 0; i < sizeof(nums)/sizeof(nums[0]); i++) nums[i] = i;

    buflen = 64;
    buf = (toku_range*) toku_malloc(buflen*sizeof(toku_range));
}





int main(int argc, const char *argv[]) {
    parse_args(argc, argv);

    init_test();

    runtest(FALSE);
    runtest(TRUE);

    return 0;
}