2006-10-16 00:53:20 +04:00
/*
Unix SMB / CIFS implementation .
local test for tdb / ldb speed
Copyright ( C ) Andrew Tridgell 2004
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-10 06:07:03 +04:00
the Free Software Foundation ; either version 3 of the License , or
2006-10-16 00:53:20 +04:00
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 06:07:03 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2006-10-16 00:53:20 +04:00
*/
# include "includes.h"
# include "system/filesys.h"
2008-09-16 18:09:50 +04:00
# include "../tdb/include/tdb.h"
2006-10-16 00:53:20 +04:00
# include "lib/ldb/include/ldb.h"
# include "lib/ldb/include/ldb_errors.h"
2007-11-16 22:12:00 +03:00
# include "lib/ldb_wrap.h"
# include "lib/tdb_wrap.h"
2008-04-27 17:02:46 +04:00
# include "torture/smbtorture.h"
2007-10-01 22:52:55 +04:00
# include "param/param.h"
2006-10-16 00:53:20 +04:00
2007-02-18 05:12:50 +03:00
float tdb_speed ;
2006-10-16 00:53:20 +04:00
2007-09-08 20:46:30 +04:00
static bool tdb_add_record ( struct tdb_wrap * tdbw , const char * fmt1 ,
const char * fmt2 , int i )
2006-10-16 00:53:20 +04:00
{
TDB_DATA key , data ;
int ret ;
key . dptr = ( uint8_t * ) talloc_asprintf ( tdbw , fmt1 , i ) ;
key . dsize = strlen ( ( char * ) key . dptr ) + 1 ;
data . dptr = ( uint8_t * ) talloc_asprintf ( tdbw , fmt2 , i + 10000 ) ;
data . dsize = strlen ( ( char * ) data . dptr ) + 1 ;
ret = tdb_store ( tdbw - > tdb , key , data , TDB_INSERT ) ;
talloc_free ( key . dptr ) ;
talloc_free ( data . dptr ) ;
return ret = = 0 ;
}
/*
test tdb speed
*/
2007-10-07 02:28:14 +04:00
static bool test_tdb_speed ( struct torture_context * torture , const void * _data )
2006-10-16 00:53:20 +04:00
{
struct timeval tv ;
struct tdb_wrap * tdbw ;
2006-10-18 18:23:19 +04:00
int timelimit = torture_setting_int ( torture , " timelimit " , 10 ) ;
2006-10-16 00:53:20 +04:00
int i , count ;
TALLOC_CTX * tmp_ctx = talloc_new ( torture ) ;
unlink ( " test.tdb " ) ;
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Testing tdb speed for sidmap \n " ) ;
2006-10-16 00:53:20 +04:00
tdbw = tdb_wrap_open ( tmp_ctx , " test.tdb " ,
10000 , 0 , O_RDWR | O_CREAT | O_TRUNC , 0600 ) ;
if ( ! tdbw ) {
2007-02-07 05:57:44 +03:00
unlink ( " test.tdb " ) ;
talloc_free ( tmp_ctx ) ;
2007-01-16 04:36:15 +03:00
torture_fail ( torture , " Failed to open test.tdb " ) ;
2006-10-16 00:53:20 +04:00
}
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Adding %d SID records \n " , torture_entries ) ;
2006-10-16 00:53:20 +04:00
for ( i = 0 ; i < torture_entries ; i + + ) {
if ( ! tdb_add_record ( tdbw ,
" S-1-5-21-53173311-3623041448-2049097239-%u " ,
" UID %u " , i ) ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " Failed to add SID %d \n " , i ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
if ( ! tdb_add_record ( tdbw ,
" UID %u " ,
" S-1-5-21-53173311-3623041448-2049097239-%u " , i ) ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " Failed to add UID %d \n " , i ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
}
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Testing for %d seconds \n " , timelimit ) ;
2006-10-16 00:53:20 +04:00
tv = timeval_current ( ) ;
for ( count = 0 ; timeval_elapsed ( & tv ) < timelimit ; count + + ) {
TDB_DATA key , data ;
i = random ( ) % torture_entries ;
key . dptr = ( uint8_t * ) talloc_asprintf ( tmp_ctx , " S-1-5-21-53173311-3623041448-2049097239-%u " , i ) ;
key . dsize = strlen ( ( char * ) key . dptr ) + 1 ;
data = tdb_fetch ( tdbw - > tdb , key ) ;
2007-02-18 14:11:57 +03:00
talloc_free ( key . dptr ) ;
2006-10-16 00:53:20 +04:00
if ( data . dptr = = NULL ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " Failed to fetch SID %d \n " , i ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
free ( data . dptr ) ;
key . dptr = ( uint8_t * ) talloc_asprintf ( tmp_ctx , " UID %u " , i ) ;
key . dsize = strlen ( ( char * ) key . dptr ) + 1 ;
data = tdb_fetch ( tdbw - > tdb , key ) ;
2007-02-18 14:11:57 +03:00
talloc_free ( key . dptr ) ;
2006-10-16 00:53:20 +04:00
if ( data . dptr = = NULL ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " Failed to fetch UID %d \n " , i ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
free ( data . dptr ) ;
}
2007-02-18 05:12:50 +03:00
tdb_speed = count / timeval_elapsed ( & tv ) ;
torture_comment ( torture , " tdb speed %.2f ops/sec \n " , tdb_speed ) ;
2006-10-16 00:53:20 +04:00
unlink ( " test.tdb " ) ;
talloc_free ( tmp_ctx ) ;
2007-10-07 02:28:14 +04:00
return true ;
2006-10-16 00:53:20 +04:00
failed :
unlink ( " test.tdb " ) ;
talloc_free ( tmp_ctx ) ;
2007-10-07 02:28:14 +04:00
return false ;
2006-10-16 00:53:20 +04:00
}
2007-10-07 02:28:14 +04:00
static bool ldb_add_record ( struct ldb_context * ldb , unsigned rid )
2006-10-16 00:53:20 +04:00
{
struct ldb_message * msg ;
int ret ;
msg = ldb_msg_new ( ldb ) ;
if ( msg = = NULL ) {
2007-10-07 02:28:14 +04:00
return false ;
2006-10-16 00:53:20 +04:00
}
2006-11-22 03:59:34 +03:00
msg - > dn = ldb_dn_new_fmt ( msg , ldb , " SID=S-1-5-21-53173311-3623041448-2049097239-%u " , rid ) ;
2006-10-16 00:53:20 +04:00
if ( msg - > dn = = NULL ) {
2007-10-07 02:28:14 +04:00
return false ;
2006-10-16 00:53:20 +04:00
}
if ( ldb_msg_add_fmt ( msg , " UID " , " %u " , rid ) ! = 0 ) {
2007-10-07 02:28:14 +04:00
return false ;
2006-10-16 00:53:20 +04:00
}
ret = ldb_add ( ldb , msg ) ;
talloc_free ( msg ) ;
return ret = = LDB_SUCCESS ;
}
/*
test ldb speed
*/
2007-10-07 02:28:14 +04:00
static bool test_ldb_speed ( struct torture_context * torture , const void * _data )
2006-10-16 00:53:20 +04:00
{
struct timeval tv ;
struct ldb_context * ldb ;
2006-10-18 18:23:19 +04:00
int timelimit = torture_setting_int ( torture , " timelimit " , 10 ) ;
2006-10-16 00:53:20 +04:00
int i , count ;
TALLOC_CTX * tmp_ctx = talloc_new ( torture ) ;
struct ldb_ldif * ldif ;
const char * init_ldif = " dn: @INDEXLIST \n " \
" @IDXATTR: UID \n " ;
2007-02-18 05:12:50 +03:00
float ldb_speed ;
2006-10-16 00:53:20 +04:00
unlink ( " ./test.ldb " ) ;
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Testing ldb speed for sidmap \n " ) ;
2006-10-16 00:53:20 +04:00
2008-04-17 14:23:44 +04:00
ldb = ldb_wrap_connect ( tmp_ctx , torture - > ev , torture - > lp_ctx , " tdb://test.ldb " ,
2006-10-16 00:53:20 +04:00
NULL , NULL , LDB_FLG_NOSYNC , NULL ) ;
if ( ! ldb ) {
2007-02-07 05:57:44 +03:00
unlink ( " ./test.ldb " ) ;
talloc_free ( tmp_ctx ) ;
2007-01-16 04:36:15 +03:00
torture_fail ( torture , " Failed to open test.ldb " ) ;
2006-10-16 00:53:20 +04:00
}
/* add an index */
ldif = ldb_ldif_read_string ( ldb , & init_ldif ) ;
if ( ldif = = NULL ) goto failed ;
if ( ldb_add ( ldb , ldif - > msg ) ! = LDB_SUCCESS ) goto failed ;
talloc_free ( ldif ) ;
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Adding %d SID records \n " , torture_entries ) ;
2006-10-16 00:53:20 +04:00
for ( i = 0 ; i < torture_entries ; i + + ) {
if ( ! ldb_add_record ( ldb , i ) ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " Failed to add SID %d \n " , i ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
}
if ( talloc_total_blocks ( torture ) > 100 ) {
2006-11-03 01:02:37 +03:00
torture_result ( torture , TORTURE_FAIL , " memory leak in ldb add \n " ) ;
2006-10-16 00:53:20 +04:00
goto failed ;
}
2006-11-03 01:02:37 +03:00
torture_comment ( torture , " Testing for %d seconds \n " , timelimit ) ;
2006-10-16 00:53:20 +04:00
tv = timeval_current ( ) ;
for ( count = 0 ; timeval_elapsed ( & tv ) < timelimit ; count + + ) {
struct ldb_dn * dn ;
struct ldb_result * res ;
i = random ( ) % torture_entries ;
2006-11-22 03:59:34 +03:00
dn = ldb_dn_new_fmt ( tmp_ctx , ldb , " SID=S-1-5-21-53173311-3623041448-2049097239-%u " , i ) ;
2008-09-23 22:30:06 +04:00
if ( ldb_search ( ldb , tmp_ctx , & res , dn , LDB_SCOPE_BASE , NULL , NULL ) ! = LDB_SUCCESS | | res - > count ! = 1 ) {
2007-01-16 04:36:15 +03:00
torture_fail ( torture , talloc_asprintf ( torture , " Failed to find SID %d " , i ) ) ;
2006-10-16 00:53:20 +04:00
}
talloc_free ( res ) ;
talloc_free ( dn ) ;
2008-09-23 22:30:06 +04:00
if ( ldb_search ( ldb , tmp_ctx , & res , NULL , LDB_SCOPE_SUBTREE , NULL , " (UID=%u) " , i ) ! = LDB_SUCCESS | | res - > count ! = 1 ) {
2007-01-16 04:36:15 +03:00
torture_fail ( torture , talloc_asprintf ( torture , " Failed to find UID %d " , i ) ) ;
2006-10-16 00:53:20 +04:00
}
talloc_free ( res ) ;
}
2006-11-22 03:59:34 +03:00
2006-10-16 00:53:20 +04:00
if ( talloc_total_blocks ( torture ) > 100 ) {
2007-02-07 05:57:44 +03:00
unlink ( " ./test.ldb " ) ;
talloc_free ( tmp_ctx ) ;
2007-01-16 04:36:15 +03:00
torture_fail ( torture , " memory leak in ldb search " ) ;
2006-10-16 00:53:20 +04:00
}
2007-02-18 05:12:50 +03:00
ldb_speed = count / timeval_elapsed ( & tv ) ;
torture_comment ( torture , " ldb speed %.2f ops/sec \n " , ldb_speed ) ;
torture_comment ( torture , " ldb/tdb speed ratio is %.2f%% \n " , ( 100 * ldb_speed / tdb_speed ) ) ;
2006-10-16 00:53:20 +04:00
unlink ( " ./test.ldb " ) ;
talloc_free ( tmp_ctx ) ;
2007-10-07 02:28:14 +04:00
return true ;
2006-10-16 00:53:20 +04:00
failed :
unlink ( " ./test.ldb " ) ;
talloc_free ( tmp_ctx ) ;
2007-10-07 02:28:14 +04:00
return false ;
2006-10-16 00:53:20 +04:00
}
struct torture_suite * torture_local_dbspeed ( TALLOC_CTX * mem_ctx )
{
2006-10-17 03:09:15 +04:00
struct torture_suite * s = torture_suite_create ( mem_ctx , " DBSPEED " ) ;
2007-12-24 22:04:56 +03:00
torture_suite_add_simple_tcase_const ( s , " tdb_speed " , test_tdb_speed ,
NULL ) ;
torture_suite_add_simple_tcase_const ( s , " ldb_speed " , test_ldb_speed ,
NULL ) ;
2006-10-16 00:53:20 +04:00
return s ;
}