2000-09-11 07:03:10 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
2000-09-13 07:07:17 +00:00
Copyright ( C ) Andrew Tridgell 2000
2010-07-19 21:00:31 +02:00
2000-09-11 07:03:10 +00:00
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-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
2000-09-11 07:03:10 +00:00
( at your option ) any later version .
2010-07-19 21:00:31 +02:00
2000-09-11 07:03:10 +00:00
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 .
2010-07-19 21:00:31 +02:00
2000-09-11 07:03:10 +00:00
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2000-09-11 07:03:10 +00:00
*/
/*
2000-09-13 07:07:17 +00:00
test code for internal messaging
2000-09-11 07:03:10 +00:00
*/
# include "includes.h"
2011-03-24 15:31:06 +01:00
# include "messages.h"
2000-09-11 07:03:10 +00:00
2000-09-12 06:57:25 +00:00
static int pong_count ;
2006-05-20 02:09:35 +00:00
2000-09-12 06:57:25 +00:00
/****************************************************************************
a useful function for testing the message system
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-05-15 14:39:18 +00:00
static void pong_message ( struct messaging_context * msg_ctx ,
void * private_data ,
uint32_t msg_type ,
struct server_id pid ,
DATA_BLOB * data )
2000-09-12 06:57:25 +00:00
{
pong_count + + ;
}
2000-09-11 07:03:10 +00:00
int main ( int argc , char * argv [ ] )
{
2009-01-21 07:31:33 +01:00
struct tevent_context * evt_ctx ;
2007-05-15 14:39:18 +00:00
struct messaging_context * msg_ctx ;
2000-09-11 07:03:10 +00:00
pid_t pid ;
2000-09-12 06:57:25 +00:00
int i , n ;
2000-11-16 21:38:24 +00:00
char buf [ 12 ] ;
2009-01-21 07:31:33 +01:00
int ret ;
2014-04-22 15:55:53 -07:00
TALLOC_CTX * frame = talloc_stackframe ( ) ;
2000-09-11 07:03:10 +00:00
2015-03-21 20:00:06 +01:00
smb_init_locale ( ) ;
2006-05-20 02:04:19 +00:00
2010-10-29 14:19:32 +11:00
setup_logging ( argv [ 0 ] , DEBUG_STDOUT ) ;
2010-07-19 21:00:31 +02:00
2011-07-27 17:03:51 +02:00
lp_load_global ( get_dyn_CONFIGFILE ( ) ) ;
2000-09-11 07:03:10 +00:00
2013-02-18 09:11:19 +01:00
if ( ! ( evt_ctx = samba_tevent_context_init ( NULL ) ) | |
2011-12-12 14:55:54 +01:00
! ( msg_ctx = messaging_init ( NULL , evt_ctx ) ) ) {
2007-05-15 14:39:18 +00:00
fprintf ( stderr , " could not init messaging context \n " ) ;
2014-04-22 15:55:53 -07:00
TALLOC_FREE ( frame ) ;
2007-05-15 14:39:18 +00:00
exit ( 1 ) ;
}
2010-07-19 21:00:31 +02:00
2000-11-16 21:38:24 +00:00
if ( argc ! = 3 ) {
2006-07-31 21:11:03 +00:00
fprintf ( stderr , " %s: Usage - %s pid count \n " , argv [ 0 ] ,
argv [ 0 ] ) ;
2014-04-22 15:55:53 -07:00
TALLOC_FREE ( frame ) ;
2000-11-16 21:38:24 +00:00
exit ( 1 ) ;
}
2000-09-11 07:03:10 +00:00
pid = atoi ( argv [ 1 ] ) ;
2000-09-12 06:57:25 +00:00
n = atoi ( argv [ 2 ] ) ;
2007-05-15 14:39:18 +00:00
messaging_register ( msg_ctx , NULL , MSG_PONG , pong_message ) ;
2000-09-12 06:57:25 +00:00
for ( i = 0 ; i < n ; i + + ) {
2007-05-15 14:39:18 +00:00
messaging_send ( msg_ctx , pid_to_procid ( pid ) , MSG_PING ,
& data_blob_null ) ;
2000-09-12 06:57:25 +00:00
}
2000-09-11 07:03:10 +00:00
2000-09-13 07:07:17 +00:00
while ( pong_count < i ) {
2009-01-21 07:31:33 +01:00
ret = tevent_loop_once ( evt_ctx ) ;
if ( ret ! = 0 ) {
break ;
}
2000-09-12 06:57:25 +00:00
}
2000-09-11 07:03:10 +00:00
2014-04-22 16:07:18 -07:00
/* Ensure all messages get through to ourselves. */
2000-11-16 21:38:24 +00:00
pong_count = 0 ;
2011-05-03 13:10:01 -07:00
strlcpy ( buf , " 1234567890 " , sizeof ( buf ) ) ;
2000-11-16 21:38:24 +00:00
for ( i = 0 ; i < n ; i + + ) {
2010-07-19 21:00:41 +02:00
messaging_send ( msg_ctx , messaging_server_id ( msg_ctx ) , MSG_PING ,
2007-05-15 14:39:18 +00:00
& data_blob_null ) ;
2010-07-19 21:00:41 +02:00
messaging_send_buf ( msg_ctx , messaging_server_id ( msg_ctx ) ,
2015-05-08 20:10:12 -07:00
MSG_PING , ( uint8_t * ) buf , 11 ) ;
2000-11-16 21:38:24 +00:00
}
2014-04-22 16:07:18 -07:00
/*
* We have to loop at least 2 times for
* each message as local ping messages are
* handled by an immediate callback , that
* has to be dispatched , which sends a pong
* message , which also has to be dispatched .
* Above we sent 2 * n messages , which means
* we have to dispatch 4 * n times .
*/
while ( pong_count < n * 2 ) {
2009-01-21 07:31:33 +01:00
ret = tevent_loop_once ( evt_ctx ) ;
if ( ret ! = 0 ) {
break ;
}
2000-11-16 21:38:24 +00:00
}
2014-04-22 16:07:18 -07:00
if ( pong_count ! = 2 * n ) {
fprintf ( stderr , " Message count failed (%d). \n " , pong_count ) ;
2006-05-20 02:09:35 +00:00
}
/* Speed testing */
pong_count = 0 ;
{
struct timeval tv = timeval_current ( ) ;
size_t timelimit = n ;
size_t ping_count = 0 ;
2006-07-11 21:23:44 +00:00
printf ( " Sending pings for %d seconds \n " , ( int ) timelimit ) ;
2006-07-31 21:11:03 +00:00
while ( timeval_elapsed ( & tv ) < timelimit ) {
2007-05-15 14:39:18 +00:00
if ( NT_STATUS_IS_OK ( messaging_send_buf (
msg_ctx , pid_to_procid ( pid ) ,
MSG_PING ,
2015-05-08 20:10:12 -07:00
( uint8_t * ) buf , 11 ) ) )
2007-02-01 22:06:59 +00:00
ping_count + + ;
2007-05-15 14:39:18 +00:00
if ( NT_STATUS_IS_OK ( messaging_send (
msg_ctx , pid_to_procid ( pid ) ,
MSG_PING , & data_blob_null ) ) )
2007-02-01 22:06:59 +00:00
ping_count + + ;
2006-05-20 02:09:35 +00:00
while ( ping_count > pong_count + 20 ) {
2009-01-21 07:31:33 +01:00
ret = tevent_loop_once ( evt_ctx ) ;
if ( ret ! = 0 ) {
break ;
}
2006-05-20 02:09:35 +00:00
}
}
2010-07-19 21:00:31 +02:00
2006-05-20 02:09:35 +00:00
printf ( " waiting for %d remaining replies (done %d) \n " ,
2006-07-11 21:23:44 +00:00
( int ) ( ping_count - pong_count ) , pong_count ) ;
2006-05-20 02:09:35 +00:00
while ( timeval_elapsed ( & tv ) < 30 & & pong_count < ping_count ) {
2009-01-21 07:31:33 +01:00
ret = tevent_loop_once ( evt_ctx ) ;
if ( ret ! = 0 ) {
break ;
}
2006-05-20 02:09:35 +00:00
}
2010-07-19 21:00:31 +02:00
2006-05-20 02:09:35 +00:00
if ( ping_count ! = pong_count ) {
2006-07-11 21:23:44 +00:00
fprintf ( stderr , " ping test failed! received %d, sent "
" %d \n " , pong_count , ( int ) ping_count ) ;
2006-05-20 02:09:35 +00:00
}
2010-07-19 21:00:31 +02:00
2006-05-20 02:09:35 +00:00
printf ( " ping rate of %.0f messages/sec \n " ,
2006-07-31 21:11:03 +00:00
( ping_count + pong_count ) / timeval_elapsed ( & tv ) ) ;
2000-11-16 21:38:24 +00:00
}
2014-04-22 15:55:53 -07:00
TALLOC_FREE ( frame ) ;
2000-09-11 07:03:10 +00:00
return ( 0 ) ;
}