2013-04-17 00:00:59 -04:00
/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- */
// vim: ft=cpp:expandtab:ts=8:sw=4:softtabstop=4:
2013-04-16 23:59:22 -04:00
# ident "$Id$"
# ident "Copyright (c) 2010 Tokutek Inc. All rights reserved."
# ident "The technology is licensed by the Massachusetts Institute of Technology, Rutgers State University of New Jersey, and the Research Foundation of State University of New York at Stony Brook under United States of America Serial No. 11 / 760379 and to the patents and / or patent applications resulting from it."
# include "test.h"
2013-04-17 00:01:15 -04:00
2013-04-16 23:59:22 -04:00
# include "toku_os.h"
# include "checkpoint.h"
2013-04-17 00:01:28 -04:00
# define FILENAME "test0.ft"
2013-04-16 23:59:22 -04:00
static void test_it ( int N ) {
2013-04-17 00:00:35 -04:00
FT_HANDLE brt ;
2013-04-16 23:59:22 -04:00
int r ;
2013-04-17 00:01:28 -04:00
toku_os_recursive_delete ( TOKU_TEST_FILENAME ) ;
r = toku_os_mkdir ( TOKU_TEST_FILENAME , S_IRWXU ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
TOKULOGGER logger ;
r = toku_logger_create ( & logger ) ; CKERR ( r ) ;
2013-04-17 00:01:28 -04:00
r = toku_logger_open ( TOKU_TEST_FILENAME , logger ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
CACHETABLE ct ;
2013-04-17 00:01:08 -04:00
toku_cachetable_create ( & ct , 0 , ZERO_LSN , logger ) ;
2013-04-17 00:01:28 -04:00
toku_cachetable_set_env_dir ( ct , TOKU_TEST_FILENAME ) ;
2013-04-16 23:59:22 -04:00
toku_logger_set_cachetable ( logger , ct ) ;
2013-04-17 00:01:01 -04:00
r = toku_logger_open_rollback ( logger , ct , true ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
TOKUTXN txn ;
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
2013-04-17 00:00:35 -04:00
r = toku_open_ft_handle ( FILENAME , 1 , & brt , 1024 , 256 , TOKU_DEFAULT_COMPRESSION_METHOD , ct , txn , toku_builtin_compare_fun ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
2013-04-17 00:01:03 -04:00
CHECKPOINTER cp = toku_cachetable_get_checkpointer ( ct ) ;
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_close_ft_handle_nolsn ( brt , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
unsigned int rands [ N ] ;
for ( int i = 0 ; i < N ; i + + ) {
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_open_ft_handle ( FILENAME , 0 , & brt , 1024 , 256 , TOKU_DEFAULT_COMPRESSION_METHOD , ct , txn , toku_builtin_compare_fun ) ; CKERR ( r ) ;
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
char key [ 100 ] , val [ 300 ] ;
DBT k , v ;
rands [ i ] = random ( ) ;
snprintf ( key , sizeof ( key ) , " key%x.%x " , rands [ i ] , i ) ;
memset ( val , ' v ' , sizeof ( val ) ) ;
val [ sizeof ( val ) - 1 ] = 0 ;
2013-04-17 00:01:08 -04:00
toku_ft_insert ( brt , toku_fill_dbt ( & k , key , 1 + strlen ( key ) ) , toku_fill_dbt ( & v , val , 1 + strlen ( val ) ) , txn ) ;
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
2013-04-17 00:01:03 -04:00
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_close_ft_handle_nolsn ( brt , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
if ( verbose ) printf ( " i=%d \n " , i ) ;
}
for ( int i = 0 ; i < N ; i + + ) {
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_open_ft_handle ( FILENAME , 0 , & brt , 1024 , 256 , TOKU_DEFAULT_COMPRESSION_METHOD , ct , txn , toku_builtin_compare_fun ) ; CKERR ( r ) ;
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
char key [ 100 ] ;
DBT k ;
snprintf ( key , sizeof ( key ) , " key%x.%x " , rands [ i ] , i ) ;
2013-04-17 00:01:08 -04:00
toku_ft_delete ( brt , toku_fill_dbt ( & k , key , 1 + strlen ( key ) ) , txn ) ;
2013-04-16 23:59:22 -04:00
if ( 0 ) {
2013-04-17 00:01:01 -04:00
bool is_empty ;
2013-04-17 00:00:35 -04:00
is_empty = toku_ft_is_empty_fast ( brt ) ;
2013-04-16 23:59:22 -04:00
assert ( ! is_empty ) ;
}
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
2013-04-17 00:01:03 -04:00
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_close_ft_handle_nolsn ( brt , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
if ( verbose ) printf ( " d=%d \n " , i ) ;
}
2013-04-17 00:01:26 -04:00
r = toku_txn_begin_txn ( ( DB_TXN * ) NULL , ( TOKUTXN ) 0 , & txn , logger , TXN_SNAPSHOT_ROOT , false ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_open_ft_handle ( FILENAME , 0 , & brt , 1024 , 256 , TOKU_DEFAULT_COMPRESSION_METHOD , ct , txn , toku_builtin_compare_fun ) ; CKERR ( r ) ;
2013-04-17 00:01:01 -04:00
r = toku_txn_commit_txn ( txn , false , NULL , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
toku_txn_close_txn ( txn ) ;
if ( 0 ) {
2013-04-17 00:01:01 -04:00
bool is_empty ;
2013-04-17 00:00:35 -04:00
is_empty = toku_ft_is_empty_fast ( brt ) ;
2013-04-16 23:59:22 -04:00
assert ( is_empty ) ;
}
2013-04-17 00:01:03 -04:00
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:00:35 -04:00
r = toku_close_ft_handle_nolsn ( brt , NULL ) ; CKERR ( r ) ;
2013-04-16 23:59:22 -04:00
2013-04-17 00:01:03 -04:00
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:01:09 -04:00
toku_logger_close_rollback ( logger ) ;
2013-04-17 00:01:03 -04:00
r = toku_checkpoint ( cp , logger , NULL , NULL , NULL , NULL , CLIENT_CHECKPOINT ) ; CKERR ( r ) ;
2013-04-17 00:01:08 -04:00
toku_cachetable_close ( & ct ) ;
2013-04-16 23:59:22 -04:00
r = toku_logger_close ( & logger ) ; assert ( r = = 0 ) ;
}
int test_main ( int argc , const char * argv [ ] ) {
default_parse_args ( argc , argv ) ;
for ( int i = 1 ; i < = 64 ; i + + ) {
test_it ( i ) ;
}
return 0 ;
}