2003-11-03 07:26:30 +00:00
/*
Unix SMB / CIFS implementation .
test suite for echo rpc operations
Copyright ( C ) Andrew Tridgell 2003
2005-01-11 16:53:02 +00:00
Copyright ( C ) Stefan ( metze ) Metzmacher 2005
2005-02-18 23:43:40 +00:00
Copyright ( C ) Jelmer Vernooij 2005
2003-11-03 07:26:30 +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-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2003-11-03 07:26:30 +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/>.
2003-11-03 07:26:30 +00:00
*/
# include "includes.h"
2010-04-13 22:06:51 +02:00
# include "torture/rpc/torture_rpc.h"
2005-02-03 11:56:03 +00:00
# include "lib/events/events.h"
2006-03-14 23:35:30 +00:00
# include "librpc/gen_ndr/ndr_echo_c.h"
2003-11-03 07:26:30 +00:00
2003-11-03 08:37:48 +00:00
/*
test the AddOne interface
*/
2006-10-16 13:06:41 +00:00
# define TEST_ADDONE(tctx, value) do { \
2005-08-01 00:58:33 +00:00
n = i = value ; \
r . in . in_data = n ; \
r . out . out_data = & n ; \
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_AddOne_r ( b , tctx , & r ) , \
talloc_asprintf ( tctx , " AddOne(%d) failed " , i ) ) ; \
2006-10-16 13:06:41 +00:00
torture_assert ( tctx , n = = i + 1 , talloc_asprintf ( tctx , " %d + 1 != %u (should be %u) \n " , i , n , i + 1 ) ) ; \
torture_comment ( tctx , " %d + 1 = %u \n " , i , n ) ; \
2005-08-01 00:58:33 +00:00
} while ( 0 )
2006-10-16 13:06:41 +00:00
static bool test_addone ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-03 08:37:48 +00:00
{
2005-08-01 00:58:33 +00:00
uint32_t i ;
uint32_t n ;
struct echo_AddOne r ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-03 08:37:48 +00:00
for ( i = 0 ; i < 10 ; i + + ) {
2006-10-16 13:06:41 +00:00
TEST_ADDONE ( tctx , i ) ;
2003-11-03 08:37:48 +00:00
}
2006-10-16 13:06:41 +00:00
TEST_ADDONE ( tctx , 0x7FFFFFFE ) ;
TEST_ADDONE ( tctx , 0xFFFFFFFE ) ;
TEST_ADDONE ( tctx , 0xFFFFFFFF ) ;
TEST_ADDONE ( tctx , random ( ) & 0xFFFFFFFF ) ;
return true ;
2003-11-03 08:37:48 +00:00
}
2003-11-03 09:18:38 +00:00
/*
test the EchoData interface
*/
2006-10-16 13:06:41 +00:00
static bool test_echodata ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-03 09:18:38 +00:00
{
int i ;
2004-11-25 18:01:40 +00:00
uint8_t * data_in , * data_out ;
2006-01-10 03:26:39 +00:00
int len ;
2003-11-09 07:24:06 +00:00
struct echo_EchoData r ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-03 09:18:38 +00:00
2006-10-16 13:06:41 +00:00
if ( torture_setting_bool ( tctx , " quick " , false ) & &
2006-01-10 03:26:39 +00:00
( p - > conn - > flags & DCERPC_DEBUG_VALIDATE_BOTH ) ) {
len = 1 + ( random ( ) % 500 ) ;
} else {
len = 1 + ( random ( ) % 5000 ) ;
}
2007-09-08 16:46:30 +00:00
data_in = talloc_array ( tctx , uint8_t , len ) ;
data_out = talloc_array ( tctx , uint8_t , len ) ;
2003-11-03 09:18:38 +00:00
for ( i = 0 ; i < len ; i + + ) {
2003-11-09 07:24:06 +00:00
data_in [ i ] = i ;
2003-11-03 09:18:38 +00:00
}
2003-11-09 07:24:06 +00:00
r . in . len = len ;
2003-11-13 09:26:53 +00:00
r . in . in_data = data_in ;
2003-11-03 09:18:38 +00:00
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_EchoData_r ( b , tctx , & r ) ,
talloc_asprintf ( tctx , " EchoData(%d) failed \n " , len ) ) ;
2003-11-03 09:18:38 +00:00
2003-11-13 09:26:53 +00:00
data_out = r . out . out_data ;
for ( i = 0 ; i < len ; i + + ) {
if ( data_in [ i ] ! = data_out [ i ] ) {
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Bad data returned for len %d at offset %d \n " ,
2003-11-13 09:26:53 +00:00
len , i ) ;
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " in: \n " ) ;
2003-11-13 10:29:58 +00:00
dump_data ( 0 , data_in + i , MIN ( len - i , 16 ) ) ;
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " out: \n " ) ;
2003-11-13 10:29:58 +00:00
dump_data ( 0 , data_out + i , MIN ( len - 1 , 16 ) ) ;
2006-10-16 13:06:41 +00:00
return false ;
2003-11-13 09:26:53 +00:00
}
2003-11-03 09:18:38 +00:00
}
2006-10-16 13:06:41 +00:00
return true ;
2003-11-03 09:18:38 +00:00
}
2003-11-03 10:01:20 +00:00
/*
test the SourceData interface
*/
2006-10-16 13:06:41 +00:00
static bool test_sourcedata ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-03 10:01:20 +00:00
{
int i ;
2006-01-10 03:18:33 +00:00
int len ;
2003-11-09 07:24:06 +00:00
struct echo_SourceData r ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-03 10:01:20 +00:00
2006-10-16 13:06:41 +00:00
if ( torture_setting_bool ( tctx , " quick " , false ) & &
2006-01-10 03:18:33 +00:00
( p - > conn - > flags & DCERPC_DEBUG_VALIDATE_BOTH ) ) {
2006-01-10 03:26:39 +00:00
len = 100 + ( random ( ) % 500 ) ;
2006-01-10 03:18:33 +00:00
} else {
len = 200000 + ( random ( ) % 5000 ) ;
}
2003-11-09 07:24:06 +00:00
r . in . len = len ;
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_SourceData_r ( b , tctx , & r ) ,
talloc_asprintf ( tctx , " SourceData(%d) failed " , len ) ) ;
2003-11-03 10:01:20 +00:00
for ( i = 0 ; i < len ; i + + ) {
2005-06-02 13:21:11 +00:00
uint8_t * v = ( uint8_t * ) r . out . data ;
2006-10-16 13:06:41 +00:00
torture_assert ( tctx , v [ i ] = = ( i & 0xFF ) ,
talloc_asprintf ( tctx ,
" bad data 0x%x at %d \n " , ( uint8_t ) r . out . data [ i ] , i ) ) ;
2003-11-03 10:01:20 +00:00
}
2006-10-16 13:06:41 +00:00
return true ;
2003-11-03 10:01:20 +00:00
}
/*
test the SinkData interface
*/
2006-10-16 13:06:41 +00:00
static bool test_sinkdata ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-03 10:01:20 +00:00
{
int i ;
2004-11-25 18:01:40 +00:00
uint8_t * data_in ;
2006-01-10 03:18:33 +00:00
int len ;
2003-11-09 07:24:06 +00:00
struct echo_SinkData r ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-03 10:01:20 +00:00
2006-10-16 13:06:41 +00:00
if ( torture_setting_bool ( tctx , " quick " , false ) & &
2006-01-10 03:18:33 +00:00
( p - > conn - > flags & DCERPC_DEBUG_VALIDATE_BOTH ) ) {
len = 100 + ( random ( ) % 5000 ) ;
} else {
len = 200000 + ( random ( ) % 5000 ) ;
}
2007-09-08 16:46:30 +00:00
data_in = talloc_array ( tctx , uint8_t , len ) ;
2003-11-03 10:01:20 +00:00
for ( i = 0 ; i < len ; i + + ) {
data_in [ i ] = i + 1 ;
}
2003-11-09 07:24:06 +00:00
r . in . len = len ;
r . in . data = data_in ;
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_SinkData_r ( b , tctx , & r ) ,
talloc_asprintf ( tctx , " SinkData(%d) failed " , len ) ) ;
2003-11-04 09:10:31 +00:00
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " sunk %d bytes \n " , len ) ;
return true ;
2003-11-03 10:01:20 +00:00
}
2003-11-13 09:26:53 +00:00
/*
test the testcall interface
*/
2006-10-16 13:06:41 +00:00
static bool test_testcall ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-13 09:26:53 +00:00
{
2003-12-14 13:22:12 +00:00
struct echo_TestCall r ;
2006-10-16 13:06:41 +00:00
const char * s = NULL ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-17 09:34:19 +00:00
2003-11-19 12:03:11 +00:00
r . in . s1 = " input string " ;
2006-09-15 20:07:55 +00:00
r . out . s2 = & s ;
2003-11-13 09:26:53 +00:00
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_TestCall_r ( b , tctx , & r ) ,
" TestCall failed " ) ;
2003-11-13 09:26:53 +00:00
2006-10-16 13:06:41 +00:00
torture_assert_str_equal ( tctx , s , " input string " , " Didn't receive back same string " ) ;
2006-09-15 20:07:55 +00:00
2006-10-16 13:06:41 +00:00
return true ;
2003-11-13 09:26:53 +00:00
}
2003-11-19 12:03:11 +00:00
/*
test the testcall interface
*/
2006-10-16 13:06:41 +00:00
static bool test_testcall2 ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2003-11-19 12:03:11 +00:00
{
2003-12-14 13:22:12 +00:00
struct echo_TestCall2 r ;
2003-11-19 12:03:11 +00:00
int i ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2003-11-19 12:03:11 +00:00
for ( i = 1 ; i < = 7 ; i + + ) {
r . in . level = i ;
2006-10-16 13:06:41 +00:00
r . out . info = talloc ( tctx , union echo_Info ) ;
2003-11-19 12:03:11 +00:00
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Testing TestCall2 level %d \n " , i ) ;
2010-03-24 09:31:17 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_TestCall2_r ( b , tctx , & r ) ,
" TestCall2 failed " ) ;
torture_assert_ntstatus_ok ( tctx , r . out . result , " TestCall2 failed " ) ;
2003-11-19 12:03:11 +00:00
}
2006-10-16 13:06:41 +00:00
return true ;
2003-11-19 12:03:11 +00:00
}
2010-03-09 15:46:55 +01:00
static void test_sleep_done ( struct tevent_req * subreq )
2010-02-27 10:01:50 +01:00
{
2010-03-09 15:46:55 +01:00
bool * done1 = ( bool * ) tevent_req_callback_data_void ( subreq ) ;
2010-02-27 10:01:50 +01:00
* done1 = true ;
}
2004-08-30 07:36:16 +00:00
/*
test the TestSleep interface
*/
2006-10-16 13:06:41 +00:00
static bool test_sleep ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2004-08-30 07:36:16 +00:00
{
int i ;
2005-01-11 16:53:02 +00:00
# define ASYNC_COUNT 3
2010-03-09 15:46:55 +01:00
struct tevent_req * req [ ASYNC_COUNT ] ;
2004-08-30 07:36:16 +00:00
struct echo_TestSleep r [ ASYNC_COUNT ] ;
2010-02-27 10:01:50 +01:00
bool done1 [ ASYNC_COUNT ] ;
bool done2 [ ASYNC_COUNT ] ;
2005-01-11 16:53:02 +00:00
struct timeval snd [ ASYNC_COUNT ] ;
struct timeval rcv [ ASYNC_COUNT ] ;
struct timeval diff [ ASYNC_COUNT ] ;
2004-08-30 07:36:16 +00:00
int total_done = 0 ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2016-09-15 08:45:51 +02:00
enum dcerpc_transport_t transport ;
uint32_t assoc_group_id ;
struct dcerpc_pipe * p2 = NULL ;
NTSTATUS status ;
2004-08-30 07:36:16 +00:00
2006-10-16 13:06:41 +00:00
if ( torture_setting_bool ( tctx , " quick " , false ) ) {
torture_skip ( tctx , " TestSleep disabled - use \" torture:quick=no \" to enable \n " ) ;
2005-06-08 17:55:58 +00:00
}
2007-09-01 23:01:33 +00:00
torture_comment ( tctx , " Testing TestSleep - use \" torture:quick=yes \" to disable \n " ) ;
2004-08-30 07:36:16 +00:00
2016-09-15 08:45:51 +02:00
transport = dcerpc_binding_get_transport ( p - > binding ) ;
assoc_group_id = dcerpc_binding_get_assoc_group_id ( p - > binding ) ;
torture_comment ( tctx , " connect echo connection 2 with "
" DCERPC_CONCURRENT_MULTIPLEX \n " ) ;
status = torture_rpc_connection_transport ( tctx , & p2 ,
& ndr_table_rpcecho ,
transport ,
assoc_group_id ,
DCERPC_CONCURRENT_MULTIPLEX ) ;
torture_assert_ntstatus_ok ( tctx , status , " opening echo connection 2 " ) ;
b = p2 - > binding_handle ;
2004-08-30 07:36:16 +00:00
for ( i = 0 ; i < ASYNC_COUNT ; i + + ) {
2010-02-27 10:01:50 +01:00
done1 [ i ] = false ;
done2 [ i ] = false ;
2005-01-11 16:53:02 +00:00
snd [ i ] = timeval_current ( ) ;
rcv [ i ] = timeval_zero ( ) ;
2004-08-30 07:36:16 +00:00
r [ i ] . in . seconds = ASYNC_COUNT - i ;
2010-03-11 12:30:24 +01:00
req [ i ] = dcerpc_echo_TestSleep_r_send ( tctx , tctx - > ev , b , & r [ i ] ) ;
2006-10-16 13:06:41 +00:00
torture_assert ( tctx , req [ i ] , " Failed to send async sleep request \n " ) ;
2010-03-09 15:46:55 +01:00
tevent_req_set_callback ( req [ i ] , test_sleep_done , & done1 [ i ] ) ;
2004-08-30 07:36:16 +00:00
}
while ( total_done < ASYNC_COUNT ) {
2014-01-14 12:34:58 +01:00
torture_assert ( tctx , tevent_loop_once ( tctx - > ev ) = = 0 ,
2006-10-16 13:06:41 +00:00
" Event context loop failed " ) ;
2004-08-30 07:36:16 +00:00
for ( i = 0 ; i < ASYNC_COUNT ; i + + ) {
2010-02-27 10:01:50 +01:00
if ( done2 [ i ] = = false & & done1 [ i ] = = true ) {
2006-10-17 06:07:54 +00:00
int rounded_tdiff ;
2004-08-30 07:36:16 +00:00
total_done + + ;
2010-02-27 10:01:50 +01:00
done2 [ i ] = true ;
2005-01-11 16:53:02 +00:00
rcv [ i ] = timeval_current ( ) ;
2005-08-01 00:34:39 +00:00
diff [ i ] = timeval_until ( & snd [ i ] , & rcv [ i ] ) ;
2006-10-17 06:07:54 +00:00
rounded_tdiff = ( int ) ( 0.5 + diff [ i ] . tv_sec + ( 1.0e-6 * diff [ i ] . tv_usec ) ) ;
2007-09-01 23:01:33 +00:00
torture_comment ( tctx , " rounded_tdiff=%d \n " , rounded_tdiff ) ;
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx ,
dcerpc_echo_TestSleep_r_recv ( req [ i ] , tctx ) ,
talloc_asprintf ( tctx , " TestSleep(%d) failed " , i ) ) ;
2006-10-16 13:06:41 +00:00
torture_assert ( tctx , r [ i ] . out . result = = r [ i ] . in . seconds ,
talloc_asprintf ( tctx , " Failed - Asked to sleep for %u seconds (server replied with %u seconds and the reply takes only %u seconds) " ,
2010-01-05 09:42:54 -08:00
r [ i ] . out . result , r [ i ] . in . seconds , ( unsigned int ) diff [ i ] . tv_sec ) ) ;
2006-10-17 06:07:54 +00:00
torture_assert ( tctx , r [ i ] . out . result < = rounded_tdiff ,
2006-10-16 13:06:41 +00:00
talloc_asprintf ( tctx , " Failed - Slept for %u seconds (but reply takes only %u.%06u seconds) " ,
2010-01-05 09:42:54 -08:00
r [ i ] . out . result , ( unsigned int ) diff [ i ] . tv_sec , ( unsigned int ) diff [ i ] . tv_usec ) ) ;
2006-10-17 06:07:54 +00:00
if ( r [ i ] . out . result + 1 = = rounded_tdiff ) {
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Slept for %u seconds (but reply takes %u.%06u seconds - busy server?) \n " ,
2010-01-05 09:42:54 -08:00
r [ i ] . out . result , ( unsigned int ) diff [ i ] . tv_sec , ( unsigned int ) diff [ i ] . tv_usec ) ;
2006-10-17 06:07:54 +00:00
} else if ( r [ i ] . out . result = = rounded_tdiff ) {
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Slept for %u seconds (reply takes %u.%06u seconds - ok) \n " ,
2010-01-05 09:42:54 -08:00
r [ i ] . out . result , ( unsigned int ) diff [ i ] . tv_sec , ( unsigned int ) diff [ i ] . tv_usec ) ;
2004-08-30 07:36:16 +00:00
} else {
2010-02-27 10:16:56 +01:00
torture_fail ( tctx , talloc_asprintf ( tctx ,
" (Failed) - Not async - Slept for %u seconds (but reply takes %u.%06u seconds) \n " ,
r [ i ] . out . result , ( unsigned int ) diff [ i ] . tv_sec , ( unsigned int ) diff [ i ] . tv_usec ) ) ;
2004-08-30 07:36:16 +00:00
}
}
}
}
2007-09-01 23:01:33 +00:00
torture_comment ( tctx , " \n " ) ;
2006-10-16 13:06:41 +00:00
return true ;
2004-08-30 07:36:16 +00:00
}
2005-01-04 23:27:12 +00:00
/*
test enum handling
*/
2006-10-16 13:06:41 +00:00
static bool test_enum ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
2005-01-04 23:27:12 +00:00
{
struct echo_TestEnum r ;
enum echo_Enum1 v = ECHO_ENUM1 ;
struct echo_Enum2 e2 ;
union echo_Enum3 e3 ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2005-01-04 23:27:12 +00:00
r . in . foo1 = & v ;
r . in . foo2 = & e2 ;
r . in . foo3 = & e3 ;
r . out . foo1 = & v ;
r . out . foo2 = & e2 ;
r . out . foo3 = & e3 ;
e2 . e1 = 76 ;
e2 . e2 = ECHO_ENUM1_32 ;
e3 . e1 = ECHO_ENUM2 ;
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_TestEnum_r ( b , tctx , & r ) ,
" TestEnum failed " ) ;
2006-10-16 13:06:41 +00:00
return true ;
2005-01-04 23:27:12 +00:00
}
2005-02-18 23:30:26 +00:00
/*
test surrounding conformant array handling
*/
2006-10-16 13:06:41 +00:00
static bool test_surrounding ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
2005-02-18 23:30:26 +00:00
{
struct echo_TestSurrounding r ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2005-02-18 23:30:26 +00:00
ZERO_STRUCT ( r ) ;
2006-10-16 13:06:41 +00:00
r . in . data = talloc ( tctx , struct echo_Surrounding ) ;
2005-02-18 23:30:26 +00:00
r . in . data - > x = 20 ;
2006-10-16 13:06:41 +00:00
r . in . data - > surrounding = talloc_zero_array ( tctx , uint16_t , r . in . data - > x ) ;
2005-02-18 23:30:26 +00:00
2006-10-16 13:06:41 +00:00
r . out . data = talloc ( tctx , struct echo_Surrounding ) ;
2005-02-18 23:30:26 +00:00
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_TestSurrounding_r ( b , tctx , & r ) ,
" TestSurrounding failed " ) ;
2005-02-18 23:30:26 +00:00
2006-10-16 13:06:41 +00:00
torture_assert ( tctx , r . out . data - > x = = 2 * r . in . data - > x ,
" TestSurrounding did not make the array twice as large " ) ;
2005-02-18 23:30:26 +00:00
2006-10-16 13:06:41 +00:00
return true ;
2005-02-18 23:30:26 +00:00
}
2005-02-20 02:57:38 +00:00
/*
test multiple levels of pointers
*/
2006-10-16 13:06:41 +00:00
static bool test_doublepointer ( struct torture_context * tctx ,
2010-03-24 09:45:21 +01:00
struct dcerpc_pipe * p )
2005-02-20 02:57:38 +00:00
{
struct echo_TestDoublePointer r ;
uint16_t value = 12 ;
uint16_t * pvalue = & value ;
uint16_t * * ppvalue = & pvalue ;
2010-03-11 12:30:24 +01:00
struct dcerpc_binding_handle * b = p - > binding_handle ;
2005-02-20 02:57:38 +00:00
ZERO_STRUCT ( r ) ;
r . in . data = & ppvalue ;
2010-03-24 09:45:21 +01:00
torture_assert_ntstatus_ok ( tctx , dcerpc_echo_TestDoublePointer_r ( b , tctx , & r ) ,
" TestDoublePointer failed " ) ;
2005-02-20 02:57:38 +00:00
2006-10-16 13:06:41 +00:00
torture_assert_int_equal ( tctx , value , r . out . result ,
" TestDoublePointer did not return original value " ) ;
return true ;
2005-02-20 02:57:38 +00:00
}
2005-06-16 23:28:24 +00:00
/*
test request timeouts
*/
2009-04-17 19:59:25 +02:00
#if 0 /* this test needs fixing to work over ncacn_np */
2006-10-16 13:06:41 +00:00
static bool test_timeout ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
2005-06-16 23:28:24 +00:00
{
NTSTATUS status ;
struct rpc_request * req ;
struct echo_TestSleep r ;
int timeout_saved = p - > request_timeout ;
2006-10-16 13:06:41 +00:00
if ( torture_setting_bool ( tctx , " quick " , false ) ) {
torture_skip ( tctx , " timeout testing disabled - use \" torture:quick=no \" to enable \n " ) ;
2005-06-16 23:28:24 +00:00
}
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " testing request timeouts \n " ) ;
2005-06-16 23:28:24 +00:00
r . in . seconds = 2 ;
p - > request_timeout = 1 ;
2007-04-23 12:31:12 +00:00
req = dcerpc_echo_TestSleep_send ( p , tctx , & r ) ;
if ( ! req ) {
torture_comment ( tctx , " Failed to send async sleep request \n " ) ;
goto failed ;
}
2007-10-06 22:28:14 +00:00
req - > ignore_timeout = true ;
2005-06-16 23:28:24 +00:00
2010-02-27 10:59:14 +01:00
status = dcerpc_echo_TestSleep_recv ( req ) ;
2006-10-16 13:06:41 +00:00
torture_assert_ntstatus_equal ( tctx , status , NT_STATUS_IO_TIMEOUT ,
" request should have timed out " ) ;
2005-06-16 23:28:24 +00:00
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " testing request destruction \n " ) ;
req = dcerpc_echo_TestSleep_send ( p , tctx , & r ) ;
2005-06-16 23:28:24 +00:00
if ( ! req ) {
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Failed to send async sleep request \n " ) ;
2005-06-16 23:28:24 +00:00
goto failed ;
}
talloc_free ( req ) ;
2006-10-16 13:06:41 +00:00
req = dcerpc_echo_TestSleep_send ( p , tctx , & r ) ;
2005-06-16 23:28:24 +00:00
if ( ! req ) {
2006-10-16 13:06:41 +00:00
torture_comment ( tctx , " Failed to send async sleep request \n " ) ;
2005-06-16 23:28:24 +00:00
goto failed ;
}
2007-10-06 22:28:14 +00:00
req - > ignore_timeout = true ;
2010-02-27 10:59:14 +01:00
status = dcerpc_echo_TestSleep_recv ( req ) ;
2006-10-16 13:06:41 +00:00
torture_assert_ntstatus_equal ( tctx , status , NT_STATUS_IO_TIMEOUT ,
" request should have timed out " ) ;
2005-06-16 23:28:24 +00:00
p - > request_timeout = timeout_saved ;
2006-10-16 13:06:41 +00:00
return test_addone ( tctx , p ) ;
2005-06-16 23:28:24 +00:00
failed :
p - > request_timeout = timeout_saved ;
2006-10-16 13:06:41 +00:00
return false ;
2005-06-16 23:28:24 +00:00
}
2009-04-17 19:59:25 +02:00
# endif
2005-06-16 23:28:24 +00:00
2007-08-31 22:34:52 +00:00
struct torture_suite * torture_rpc_echo ( TALLOC_CTX * mem_ctx )
2003-11-03 07:26:30 +00:00
{
2010-12-11 03:26:31 +01:00
struct torture_suite * suite = torture_suite_create ( mem_ctx , " echo " ) ;
2007-08-28 16:24:18 +00:00
struct torture_rpc_tcase * tcase ;
2006-10-16 13:06:41 +00:00
tcase = torture_suite_add_rpc_iface_tcase ( suite , " echo " ,
2007-08-19 21:23:03 +00:00
& ndr_table_rpcecho ) ;
2006-10-16 13:06:41 +00:00
torture_rpc_tcase_add_test ( tcase , " addone " , test_addone ) ;
torture_rpc_tcase_add_test ( tcase , " sinkdata " , test_sinkdata ) ;
torture_rpc_tcase_add_test ( tcase , " echodata " , test_echodata ) ;
torture_rpc_tcase_add_test ( tcase , " sourcedata " , test_sourcedata ) ;
torture_rpc_tcase_add_test ( tcase , " testcall " , test_testcall ) ;
torture_rpc_tcase_add_test ( tcase , " testcall2 " , test_testcall2 ) ;
torture_rpc_tcase_add_test ( tcase , " enum " , test_enum ) ;
torture_rpc_tcase_add_test ( tcase , " surrounding " , test_surrounding ) ;
torture_rpc_tcase_add_test ( tcase , " doublepointer " , test_doublepointer ) ;
torture_rpc_tcase_add_test ( tcase , " sleep " , test_sleep ) ;
2009-04-17 19:59:25 +02:00
#if 0 /* this test needs fixing to work over ncacn_np */
2006-10-16 13:06:41 +00:00
torture_rpc_tcase_add_test ( tcase , " timeout " , test_timeout ) ;
2009-04-17 19:59:25 +02:00
# endif
2006-10-16 13:06:41 +00:00
return suite ;
2003-11-03 07:26:30 +00:00
}