2006-10-15 20:53:20 +00: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 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2006-10-15 20:53:20 +00: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 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2006-10-15 20:53:20 +00:00
*/
# include "includes.h"
# include "system/filesys.h"
2011-06-20 18:40:25 +09:30
# include "tdb_compat.h"
2011-02-10 14:12:51 +11:00
# include <ldb.h>
# include <ldb_errors.h>
2010-06-16 13:43:38 +02:00
# include "ldb_wrap.h"
2011-05-04 10:28:15 +10:00
# include "lib/util/tdb_wrap.h"
2008-04-27 14:02:46 +01:00
# include "torture/smbtorture.h"
2007-10-01 18:52:55 +00:00
# include "param/param.h"
2006-10-15 20:53:20 +00:00
2007-02-18 02:12:50 +00:00
float tdb_speed ;
2006-10-15 20:53:20 +00:00
2007-09-08 16:46:30 +00:00
static bool tdb_add_record ( struct tdb_wrap * tdbw , const char * fmt1 ,
const char * fmt2 , int i )
2006-10-15 20:53:20 +00:00
{
TDB_DATA key , data ;
int ret ;
2010-04-11 21:44:20 +02:00
2006-10-15 20:53:20 +00:00
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-06 22:28:14 +00:00
static bool test_tdb_speed ( struct torture_context * torture , const void * _data )
2006-10-15 20:53:20 +00:00
{
struct timeval tv ;
struct tdb_wrap * tdbw ;
2006-10-18 14:23:19 +00:00
int timelimit = torture_setting_int ( torture , " timelimit " , 10 ) ;
2006-10-15 20:53:20 +00:00
int i , count ;
TALLOC_CTX * tmp_ctx = talloc_new ( torture ) ;
unlink ( " test.tdb " ) ;
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Testing tdb speed for sidmap \n " ) ;
2006-10-15 20:53:20 +00:00
tdbw = tdb_wrap_open ( tmp_ctx , " test.tdb " ,
10000 , 0 , O_RDWR | O_CREAT | O_TRUNC , 0600 ) ;
if ( ! tdbw ) {
2010-04-11 21:44:20 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to open test.tdb " ) ;
goto failed ;
2006-10-15 20:53:20 +00:00
}
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Adding %d SID records \n " , torture_entries ) ;
2006-10-15 20:53:20 +00:00
for ( i = 0 ; i < torture_entries ; i + + ) {
if ( ! tdb_add_record ( tdbw ,
" S-1-5-21-53173311-3623041448-2049097239-%u " ,
" UID %u " , i ) ) {
2010-04-11 21:44:20 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to add SID %d! " , i ) ;
2006-10-15 20:53:20 +00:00
goto failed ;
}
if ( ! tdb_add_record ( tdbw ,
" UID %u " ,
" S-1-5-21-53173311-3623041448-2049097239-%u " , i ) ) {
2010-04-11 21:44:20 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to add UID %d! " , i ) ;
2006-10-15 20:53:20 +00:00
goto failed ;
}
}
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Testing for %d seconds \n " , timelimit ) ;
2006-10-15 20:53:20 +00: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 11:11:57 +00:00
talloc_free ( key . dptr ) ;
2006-10-15 20:53:20 +00:00
if ( data . dptr = = NULL ) {
2010-04-11 21:44:20 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to find SID %d! " , i ) ;
2006-10-15 20:53:20 +00: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 11:11:57 +00:00
talloc_free ( key . dptr ) ;
2006-10-15 20:53:20 +00:00
if ( data . dptr = = NULL ) {
2010-04-11 21:44:20 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to find UID %d! " , i ) ;
2006-10-15 20:53:20 +00:00
goto failed ;
}
free ( data . dptr ) ;
}
2007-02-18 02:12:50 +00:00
tdb_speed = count / timeval_elapsed ( & tv ) ;
torture_comment ( torture , " tdb speed %.2f ops/sec \n " , tdb_speed ) ;
2006-10-15 20:53:20 +00:00
talloc_free ( tmp_ctx ) ;
2010-04-11 21:44:20 +02:00
unlink ( " test.tdb " ) ;
2007-10-06 22:28:14 +00:00
return true ;
2006-10-15 20:53:20 +00:00
failed :
talloc_free ( tmp_ctx ) ;
2010-04-11 21:44:20 +02:00
unlink ( " test.tdb " ) ;
2007-10-06 22:28:14 +00:00
return false ;
2006-10-15 20:53:20 +00:00
}
2007-10-06 22:28:14 +00:00
static bool ldb_add_record ( struct ldb_context * ldb , unsigned rid )
2006-10-15 20:53:20 +00:00
{
struct ldb_message * msg ;
int ret ;
msg = ldb_msg_new ( ldb ) ;
if ( msg = = NULL ) {
2007-10-06 22:28:14 +00:00
return false ;
2006-10-15 20:53:20 +00:00
}
2006-11-22 00:59:34 +00:00
msg - > dn = ldb_dn_new_fmt ( msg , ldb , " SID=S-1-5-21-53173311-3623041448-2049097239-%u " , rid ) ;
2006-10-15 20:53:20 +00:00
if ( msg - > dn = = NULL ) {
2010-04-11 11:13:31 +02:00
talloc_free ( msg ) ;
2007-10-06 22:28:14 +00:00
return false ;
2006-10-15 20:53:20 +00:00
}
2010-10-15 20:18:22 +02:00
ret = ldb_msg_add_fmt ( msg , " UID " , " %u " , rid ) ;
if ( ret ! = LDB_SUCCESS ) {
2010-04-11 11:13:31 +02:00
talloc_free ( msg ) ;
2007-10-06 22:28:14 +00:00
return false ;
2006-10-15 20:53:20 +00:00
}
ret = ldb_add ( ldb , msg ) ;
talloc_free ( msg ) ;
return ret = = LDB_SUCCESS ;
}
/*
test ldb speed
*/
2007-10-06 22:28:14 +00:00
static bool test_ldb_speed ( struct torture_context * torture , const void * _data )
2006-10-15 20:53:20 +00:00
{
struct timeval tv ;
struct ldb_context * ldb ;
2006-10-18 14:23:19 +00:00
int timelimit = torture_setting_int ( torture , " timelimit " , 10 ) ;
2006-10-15 20:53:20 +00: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 02:12:50 +00:00
float ldb_speed ;
2006-10-15 20:53:20 +00:00
unlink ( " ./test.ldb " ) ;
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Testing ldb speed for sidmap \n " ) ;
2006-10-15 20:53:20 +00:00
2010-07-16 14:32:42 +10:00
ldb = ldb_wrap_connect ( tmp_ctx , torture - > ev , torture - > lp_ctx , " tdb://test.ldb " ,
2009-10-23 14:27:00 +11:00
NULL , NULL , LDB_FLG_NOSYNC ) ;
2006-10-15 20:53:20 +00:00
if ( ! ldb ) {
2010-04-11 11:21:19 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to open test.ldb " ) ;
goto failed ;
2006-10-15 20:53:20 +00:00
}
/* add an index */
ldif = ldb_ldif_read_string ( ldb , & init_ldif ) ;
2010-04-11 11:21:19 +02:00
if ( ldif = = NULL ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " Didn't get LDIF data! " ) ;
2010-04-11 11:21:19 +02:00
goto failed ;
}
if ( ldb_add ( ldb , ldif - > msg ) ! = LDB_SUCCESS ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " Couldn't apply LDIF data! " ) ;
2010-04-11 11:21:19 +02:00
talloc_free ( ldif ) ;
goto failed ;
}
2006-10-15 20:53:20 +00:00
talloc_free ( ldif ) ;
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Adding %d SID records \n " , torture_entries ) ;
2006-10-15 20:53:20 +00:00
for ( i = 0 ; i < torture_entries ; i + + ) {
if ( ! ldb_add_record ( ldb , i ) ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to add SID %d " , i ) ;
2006-10-15 20:53:20 +00:00
goto failed ;
}
}
2010-04-11 11:22:41 +02:00
if ( talloc_total_blocks ( tmp_ctx ) > 100 ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " memory leak in ldb add " ) ;
2006-10-15 20:53:20 +00:00
goto failed ;
}
2006-11-02 22:02:37 +00:00
torture_comment ( torture , " Testing for %d seconds \n " , timelimit ) ;
2006-10-15 20:53:20 +00: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 00:59:34 +00:00
dn = ldb_dn_new_fmt ( tmp_ctx , ldb , " SID=S-1-5-21-53173311-3623041448-2049097239-%u " , i ) ;
2008-09-23 14:30:06 -04:00
if ( ldb_search ( ldb , tmp_ctx , & res , dn , LDB_SCOPE_BASE , NULL , NULL ) ! = LDB_SUCCESS | | res - > count ! = 1 ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to find SID %d! " , i ) ;
2010-04-11 11:21:19 +02:00
goto failed ;
2006-10-15 20:53:20 +00:00
}
talloc_free ( res ) ;
talloc_free ( dn ) ;
2008-09-23 14:30:06 -04:00
if ( ldb_search ( ldb , tmp_ctx , & res , NULL , LDB_SCOPE_SUBTREE , NULL , " (UID=%u) " , i ) ! = LDB_SUCCESS | | res - > count ! = 1 ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " Failed to find UID %d! " , i ) ;
2010-04-11 11:21:19 +02:00
goto failed ;
2006-10-15 20:53:20 +00:00
}
talloc_free ( res ) ;
}
2006-11-22 00:59:34 +00:00
2010-04-11 11:22:41 +02:00
if ( talloc_total_blocks ( tmp_ctx ) > 100 ) {
2010-04-11 21:37:23 +02:00
torture_result ( torture , TORTURE_FAIL , " memory leak in ldb search " ) ;
2010-04-11 11:21:19 +02:00
goto failed ;
2006-10-15 20:53:20 +00:00
}
2007-02-18 02:12:50 +00: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-15 20:53:20 +00:00
talloc_free ( tmp_ctx ) ;
2010-04-11 11:13:31 +02:00
unlink ( " ./test.ldb " ) ;
2007-10-06 22:28:14 +00:00
return true ;
2006-10-15 20:53:20 +00:00
failed :
talloc_free ( tmp_ctx ) ;
2010-04-11 11:13:31 +02:00
unlink ( " ./test.ldb " ) ;
2007-10-06 22:28:14 +00:00
return false ;
2006-10-15 20:53:20 +00:00
}
struct torture_suite * torture_local_dbspeed ( TALLOC_CTX * mem_ctx )
{
2010-12-11 03:26:31 +01:00
struct torture_suite * s = torture_suite_create ( mem_ctx , " dbspeed " ) ;
2007-12-24 13:04:56 -06: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-15 20:53:20 +00:00
return s ;
}