2001-06-19 02:02:19 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
2001-06-19 02:02:19 +00:00
SMB torture tester
Copyright ( C ) Andrew Tridgell 1997 - 1998
2009-10-20 17:41:27 -07:00
Copyright ( C ) Jeremy Allison 2009
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +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
2001-06-19 02:02:19 +00:00
( at your option ) any later version .
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +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 .
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +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/>.
2001-06-19 02:02:19 +00:00
*/
# include "includes.h"
2011-02-25 17:03:27 +01:00
# include "system/shmem.h"
2010-12-08 20:11:46 +01:00
# include "wbc_async.h"
2009-11-24 11:43:56 +01:00
# include "torture/proto.h"
2010-10-12 15:27:50 +11:00
# include "libcli/security/security.h"
2010-05-17 17:17:44 -07:00
# include "tldap.h"
# include "tldap_util.h"
2010-08-05 15:25:35 +02:00
# include "../librpc/gen_ndr/svcctl.h"
2010-08-18 12:24:35 +02:00
# include "memcache.h"
2010-08-18 12:42:49 +02:00
# include "nsswitch/winbind_client.h"
2011-07-07 17:42:08 +02:00
# include "dbwrap/dbwrap.h"
2011-07-06 16:40:21 +02:00
# include "dbwrap/dbwrap_open.h"
2011-08-16 16:20:14 +02:00
# include "dbwrap/dbwrap_rbt.h"
2010-08-18 19:05:59 +02:00
# include "talloc_dict.h"
2010-08-26 09:58:09 +02:00
# include "async_smb.h"
2011-05-06 11:47:43 +02:00
# include "libsmb/libsmb.h"
2011-02-24 10:46:55 +01:00
# include "libsmb/clirap.h"
2011-02-25 00:03:01 +01:00
# include "trans2.h"
2011-03-23 14:18:59 +01:00
# include "libsmb/nmblib.h"
2011-04-28 17:38:09 +02:00
# include "../lib/util/tevent_ntstatus.h"
2011-05-05 11:25:29 +02:00
# include "util_tdb.h"
2011-10-24 08:42:10 +02:00
# include "../libcli/smb/read_smb.h"
2012-05-19 16:58:28 +02:00
# include "../libcli/smb/smbXcli_base.h"
2001-06-19 02:02:19 +00:00
2005-05-02 17:49:43 +00:00
extern char * optarg ;
extern int optind ;
2011-05-05 18:12:07 +02:00
fstring host , workgroup , share , password , username , myname ;
2003-01-03 08:28:12 +00:00
static const char * sockops = " TCP_NODELAY " ;
2012-04-04 14:29:33 +02:00
int torture_nprocs = 1 ;
2003-04-01 16:48:18 +00:00
static int port_to_use = 0 ;
2002-04-12 10:18:46 +00:00
int torture_numops = 100 ;
2008-12-19 23:41:19 +01:00
int torture_blocksize = 1024 * 1024 ;
2001-06-19 02:02:19 +00:00
static int procnum ; /* records process count number when forking */
2003-04-18 03:35:39 +00:00
static struct cli_state * current_cli ;
2001-06-19 02:02:19 +00:00
static fstring randomfname ;
2007-10-18 17:40:25 -07:00
static bool use_oplocks ;
static bool use_level_II_oplocks ;
2003-01-03 08:28:12 +00:00
static const char * client_txt = " client_oplocks.txt " ;
2011-09-08 09:56:16 +02:00
static bool disable_spnego ;
2007-10-18 17:40:25 -07:00
static bool use_kerberos ;
2011-09-08 09:24:11 +02:00
static bool force_dos_errors ;
2006-07-31 09:41:25 +00:00
static fstring multishare_conn_fname ;
2007-10-18 17:40:25 -07:00
static bool use_multishare_conn = False ;
2008-01-04 16:09:24 -08:00
static bool do_encrypt ;
2009-10-20 17:37:43 -07:00
static const char * local_path = NULL ;
2013-03-13 15:43:21 -07:00
static enum smb_signing_setting signing_state = SMB_SIGNING_DEFAULT ;
2011-05-04 17:45:34 +02:00
char * test_filename ;
2002-02-05 01:31:47 +00:00
2007-10-18 17:40:25 -07:00
bool torture_showall = False ;
2001-06-19 02:02:19 +00:00
2007-10-18 17:40:25 -07:00
static double create_procs ( bool ( * fn ) ( int ) , bool * result ) ;
2001-06-19 02:02:19 +00:00
2008-01-04 16:09:24 -08:00
/********************************************************************
Ensure a connection is encrypted .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static bool force_cli_encryption ( struct cli_state * c ,
const char * sharename )
{
uint16 major , minor ;
uint32 caplow , caphigh ;
NTSTATUS status ;
if ( ! SERVER_HAS_UNIX_CIFS ( c ) ) {
d_printf ( " Encryption required and "
" server that doesn't support "
" UNIX extensions - failing connect \n " ) ;
return false ;
}
2009-11-12 23:07:21 +01:00
status = cli_unix_extensions_version ( c , & major , & minor , & caplow ,
& caphigh ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2008-01-04 16:09:24 -08:00
d_printf ( " Encryption required and "
" can't get UNIX CIFS extensions "
2009-11-12 23:07:21 +01:00
" version from server: %s \n " , nt_errstr ( status ) ) ;
2008-01-04 16:09:24 -08:00
return false ;
}
if ( ! ( caplow & CIFS_UNIX_TRANSPORT_ENCRYPTION_CAP ) ) {
d_printf ( " Encryption required and "
" share %s doesn't support "
" encryption. \n " , sharename ) ;
return false ;
}
if ( c - > use_kerberos ) {
status = cli_gss_smb_encryption_start ( c ) ;
} else {
status = cli_raw_ntlm_smb_encryption_start ( c ,
username ,
password ,
workgroup ) ;
}
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " Encryption required and "
" setup failed with error %s. \n " ,
nt_errstr ( status ) ) ;
return false ;
}
return true ;
}
2001-06-19 02:02:19 +00:00
2006-07-11 18:01:26 +00:00
static struct cli_state * open_nbt_connection ( void )
2001-06-19 02:02:19 +00:00
{
2006-07-11 18:01:26 +00:00
struct cli_state * c ;
2007-06-20 17:38:42 +00:00
NTSTATUS status ;
2011-09-07 20:35:51 +02:00
int flags = 0 ;
2011-09-08 09:56:16 +02:00
if ( disable_spnego ) {
flags | = CLI_FULL_CONNECTION_DONT_SPNEGO ;
}
2011-09-07 20:35:51 +02:00
if ( use_oplocks ) {
flags | = CLI_FULL_CONNECTION_OPLOCKS ;
}
if ( use_level_II_oplocks ) {
flags | = CLI_FULL_CONNECTION_LEVEL_II_OPLOCKS ;
}
if ( use_kerberos ) {
flags | = CLI_FULL_CONNECTION_USE_KERBEROS ;
}
2001-06-19 02:02:19 +00:00
2011-09-08 09:24:11 +02:00
if ( force_dos_errors ) {
flags | = CLI_FULL_CONNECTION_FORCE_DOS_ERRORS ;
}
2011-05-28 23:34:26 +02:00
status = cli_connect_nb ( host , NULL , port_to_use , 0x20 , myname ,
2011-09-07 20:35:51 +02:00
signing_state , flags , & c ) ;
2007-06-20 17:38:42 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Failed to connect with %s. Error %s \n " , host , nt_errstr ( status ) ) ;
2006-07-11 18:01:26 +00:00
return NULL ;
2001-06-19 02:02:19 +00:00
}
2011-08-02 22:55:32 +02:00
cli_set_timeout ( c , 120000 ) ; /* set a really long timeout (2 minutes) */
2001-06-19 02:02:19 +00:00
2006-07-11 18:01:26 +00:00
return c ;
2001-06-19 02:02:19 +00:00
}
2010-09-27 18:24:01 -07:00
/****************************************************************************
Send a corrupt session request . See rfc1002 . txt 4.3 and 4.3 .2 .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2011-05-29 18:17:18 +02:00
static bool cli_bad_session_request ( int fd ,
2010-09-27 18:24:01 -07:00
struct nmb_name * calling , struct nmb_name * called )
{
2011-05-19 18:48:09 +02:00
TALLOC_CTX * frame ;
uint8_t len_buf [ 4 ] ;
struct iovec iov [ 3 ] ;
ssize_t len ;
uint8_t * inbuf ;
int err ;
bool ret = false ;
2011-05-29 18:49:14 +02:00
uint8_t message_type ;
uint8_t error ;
2013-02-18 09:55:58 +01:00
struct tevent_context * ev ;
2011-09-20 04:43:05 +02:00
struct tevent_req * req ;
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
frame = talloc_stackframe ( ) ;
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
iov [ 0 ] . iov_base = len_buf ;
iov [ 0 ] . iov_len = sizeof ( len_buf ) ;
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
/* put in the destination name */
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
iov [ 1 ] . iov_base = name_mangle ( talloc_tos ( ) , called - > name ,
called - > name_type ) ;
if ( iov [ 1 ] . iov_base = = NULL ) {
goto fail ;
}
iov [ 1 ] . iov_len = name_len ( ( unsigned char * ) iov [ 1 ] . iov_base ,
talloc_get_size ( iov [ 1 ] . iov_base ) ) ;
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
/* and my name */
iov [ 2 ] . iov_base = name_mangle ( talloc_tos ( ) , calling - > name ,
calling - > name_type ) ;
if ( iov [ 2 ] . iov_base = = NULL ) {
goto fail ;
}
iov [ 2 ] . iov_len = name_len ( ( unsigned char * ) iov [ 2 ] . iov_base ,
talloc_get_size ( iov [ 2 ] . iov_base ) ) ;
2010-09-27 18:24:01 -07:00
/* Deliberately corrupt the name len (first byte) */
2011-05-19 18:48:09 +02:00
* ( ( uint8_t * ) iov [ 2 ] . iov_base ) = 100 ;
2010-09-27 18:24:01 -07:00
2011-05-19 18:48:09 +02:00
/* send a session request (RFC 1002) */
/* setup the packet length
2010-09-27 18:24:01 -07:00
* Remove four bytes from the length count , since the length
* field in the NBT Session Service header counts the number
* of bytes which follow . The cli_send_smb ( ) function knows
* about this and accounts for those four bytes .
* CRH .
*/
2011-05-19 18:48:09 +02:00
_smb_setlen ( len_buf , iov [ 1 ] . iov_len + iov [ 2 ] . iov_len ) ;
SCVAL ( len_buf , 0 , 0x81 ) ;
2010-09-27 18:24:01 -07:00
2011-05-29 18:17:18 +02:00
len = write_data_iov ( fd , iov , 3 ) ;
2011-05-19 18:48:09 +02:00
if ( len = = - 1 ) {
goto fail ;
}
2011-09-20 04:43:05 +02:00
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( frame ) ;
2011-09-20 04:43:05 +02:00
if ( ev = = NULL ) {
goto fail ;
}
req = read_smb_send ( frame , ev , fd ) ;
if ( req = = NULL ) {
goto fail ;
}
if ( ! tevent_req_poll ( req , ev ) ) {
goto fail ;
}
len = read_smb_recv ( req , talloc_tos ( ) , & inbuf , & err ) ;
2011-05-19 18:48:09 +02:00
if ( len = = - 1 ) {
errno = err ;
goto fail ;
}
2011-09-20 04:43:05 +02:00
TALLOC_FREE ( ev ) ;
2010-09-27 18:24:01 -07:00
2011-05-29 18:49:14 +02:00
message_type = CVAL ( inbuf , 0 ) ;
if ( message_type ! = 0x83 ) {
d_fprintf ( stderr , " Expected msg type 0x83, got 0x%2.2x \n " ,
message_type ) ;
goto fail ;
}
if ( smb_len ( inbuf ) ! = 1 ) {
d_fprintf ( stderr , " Expected smb_len 1, got %d \n " ,
( int ) smb_len ( inbuf ) ) ;
goto fail ;
}
error = CVAL ( inbuf , 4 ) ;
if ( error ! = 0x82 ) {
d_fprintf ( stderr , " Expected error 0x82, got %d \n " ,
( int ) error ) ;
2011-05-19 18:48:09 +02:00
goto fail ;
2010-09-27 18:24:01 -07:00
}
2011-05-19 18:48:09 +02:00
ret = true ;
fail :
TALLOC_FREE ( frame ) ;
return ret ;
2010-09-27 18:24:01 -07:00
}
2006-07-31 09:41:25 +00:00
/* Insert a NULL at the first separator of the given path and return a pointer
* to the remainder of the string .
*/
static char *
terminate_path_at_separator ( char * path )
{
char * p ;
if ( ! path ) {
return NULL ;
}
if ( ( p = strchr_m ( path , ' / ' ) ) ) {
* p = ' \0 ' ;
return p + 1 ;
}
if ( ( p = strchr_m ( path , ' \\ ' ) ) ) {
* p = ' \0 ' ;
return p + 1 ;
}
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
/* No separator. */
return NULL ;
}
/*
parse a //server/share type UNC name
*/
2007-10-18 17:40:25 -07:00
bool smbcli_parse_unc ( const char * unc_name , TALLOC_CTX * mem_ctx ,
2006-07-31 09:41:25 +00:00
char * * hostname , char * * sharename )
{
char * p ;
* hostname = * sharename = NULL ;
if ( strncmp ( unc_name , " \\ \\ " , 2 ) & &
strncmp ( unc_name , " // " , 2 ) ) {
return False ;
}
* hostname = talloc_strdup ( mem_ctx , & unc_name [ 2 ] ) ;
p = terminate_path_at_separator ( * hostname ) ;
if ( p & & * p ) {
* sharename = talloc_strdup ( mem_ctx , p ) ;
terminate_path_at_separator ( * sharename ) ;
}
if ( * hostname & & * sharename ) {
return True ;
}
TALLOC_FREE ( * hostname ) ;
TALLOC_FREE ( * sharename ) ;
return False ;
}
2007-10-18 17:40:25 -07:00
static bool torture_open_connection_share ( struct cli_state * * c ,
2006-07-31 09:41:25 +00:00
const char * hostname ,
const char * sharename )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
int flags = 0 ;
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( use_kerberos )
flags | = CLI_FULL_CONNECTION_USE_KERBEROS ;
2009-04-06 20:45:08 +02:00
if ( use_oplocks )
flags | = CLI_FULL_CONNECTION_OPLOCKS ;
if ( use_level_II_oplocks )
flags | = CLI_FULL_CONNECTION_LEVEL_II_OPLOCKS ;
2006-07-31 09:41:25 +00:00
2003-04-18 03:35:39 +00:00
status = cli_full_connection ( c , myname ,
2006-07-31 09:41:25 +00:00
hostname , NULL , port_to_use ,
sharename , " ????? " ,
2003-04-18 03:35:39 +00:00
username , workgroup ,
2010-12-20 16:37:23 +01:00
password , flags , signing_state ) ;
2003-04-18 03:35:39 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2006-09-05 10:37:18 +00:00
printf ( " failed to open share connection: //%s/%s port:%d - %s \n " ,
hostname , sharename , port_to_use , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
return False ;
}
2011-08-02 22:55:32 +02:00
cli_set_timeout ( * c , 120000 ) ; /* set a really long timeout (2 minutes) */
2001-06-19 02:02:19 +00:00
2008-01-04 16:09:24 -08:00
if ( do_encrypt ) {
return force_cli_encryption ( * c ,
sharename ) ;
}
2003-04-18 03:35:39 +00:00
return True ;
}
2001-06-19 02:02:19 +00:00
2007-10-18 17:40:25 -07:00
bool torture_open_connection ( struct cli_state * * c , int conn_index )
2006-07-31 09:41:25 +00:00
{
char * * unc_list = NULL ;
int num_unc_names = 0 ;
2007-10-18 17:40:25 -07:00
bool result ;
2006-07-31 09:41:25 +00:00
if ( use_multishare_conn = = True ) {
char * h , * s ;
2008-10-12 18:29:36 +02:00
unc_list = file_lines_load ( multishare_conn_fname , & num_unc_names , 0 , NULL ) ;
2006-07-31 09:41:25 +00:00
if ( ! unc_list | | num_unc_names < = 0 ) {
printf ( " Failed to load unc names list from '%s' \n " , multishare_conn_fname ) ;
exit ( 1 ) ;
}
if ( ! smbcli_parse_unc ( unc_list [ conn_index % num_unc_names ] ,
NULL , & h , & s ) ) {
printf ( " Failed to parse UNC name %s \n " ,
unc_list [ conn_index % num_unc_names ] ) ;
2008-10-12 18:29:36 +02:00
TALLOC_FREE ( unc_list ) ;
2006-07-31 09:41:25 +00:00
exit ( 1 ) ;
}
result = torture_open_connection_share ( c , h , s ) ;
/* h, s were copied earlier */
2008-10-12 18:29:36 +02:00
TALLOC_FREE ( unc_list ) ;
2006-07-31 09:41:25 +00:00
return result ;
}
return torture_open_connection_share ( c , host , share ) ;
}
2011-05-05 18:12:07 +02:00
bool torture_init_connection ( struct cli_state * * pcli )
{
struct cli_state * cli ;
cli = open_nbt_connection ( ) ;
if ( cli = = NULL ) {
return false ;
}
* pcli = cli ;
return true ;
}
2007-10-18 17:40:25 -07:00
bool torture_cli_session_setup2 ( struct cli_state * cli , uint16 * new_vuid )
2003-04-18 03:35:39 +00:00
{
2011-07-21 09:20:43 +02:00
uint16_t old_vuid = cli_state_get_uid ( cli ) ;
2003-04-18 03:35:39 +00:00
fstring old_user_name ;
size_t passlen = strlen ( password ) ;
2009-03-13 17:49:24 -07:00
NTSTATUS status ;
2007-10-18 17:40:25 -07:00
bool ret ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
fstrcpy ( old_user_name , cli - > user_name ) ;
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , 0 ) ;
2006-08-16 17:14:16 +00:00
ret = NT_STATUS_IS_OK ( cli_session_setup ( cli , username ,
password , passlen ,
password , passlen ,
workgroup ) ) ;
2011-07-21 09:20:43 +02:00
* new_vuid = cli_state_get_uid ( cli ) ;
cli_state_set_uid ( cli , old_vuid ) ;
2009-03-13 17:49:24 -07:00
status = cli_set_username ( cli , old_user_name ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return false ;
}
2003-04-18 03:35:39 +00:00
return ret ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
bool torture_close_connection ( struct cli_state * c )
2001-06-19 02:02:19 +00:00
{
2007-10-18 17:40:25 -07:00
bool ret = True ;
2010-01-03 18:46:57 +01:00
NTSTATUS status ;
status = cli_tdis ( c ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " tdis failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
ret = False ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
cli_shutdown ( c ) ;
return ret ;
2001-06-19 02:02:19 +00:00
}
2011-07-07 16:27:39 +02:00
/* check if the server produced the expected dos or nt error code */
static bool check_both_error ( int line , NTSTATUS status ,
uint8 eclass , uint32 ecode , NTSTATUS nterr )
{
if ( NT_STATUS_IS_DOS ( status ) ) {
uint8 cclass ;
uint32 num ;
/* Check DOS error */
cclass = NT_STATUS_DOS_CLASS ( status ) ;
num = NT_STATUS_DOS_CODE ( status ) ;
if ( eclass ! = cclass | | ecode ! = num ) {
printf ( " unexpected error code class=%d code=%d \n " ,
( int ) cclass , ( int ) num ) ;
printf ( " expected %d/%d %s (line=%d) \n " ,
( int ) eclass , ( int ) ecode , nt_errstr ( nterr ) , line ) ;
return false ;
}
} else {
/* Check NT error */
if ( ! NT_STATUS_EQUAL ( nterr , status ) ) {
printf ( " unexpected error code %s \n " ,
nt_errstr ( status ) ) ;
printf ( " expected %s (line=%d) \n " ,
nt_errstr ( nterr ) , line ) ;
return false ;
}
}
return true ;
}
2001-06-19 02:02:19 +00:00
/* check if the server produced the expected error code */
2011-07-27 21:51:45 +02:00
static bool check_error ( int line , NTSTATUS status ,
2001-09-04 11:52:42 +00:00
uint8 eclass , uint32 ecode , NTSTATUS nterr )
2001-06-19 02:02:19 +00:00
{
2011-07-27 21:51:45 +02:00
if ( NT_STATUS_IS_DOS ( status ) ) {
2005-06-25 09:07:42 +00:00
uint8 cclass ;
2001-08-13 04:08:42 +00:00
uint32 num ;
/* Check DOS error */
2011-07-27 21:51:45 +02:00
cclass = NT_STATUS_DOS_CLASS ( status ) ;
num = NT_STATUS_DOS_CODE ( status ) ;
2001-08-13 04:08:42 +00:00
2005-06-25 09:07:42 +00:00
if ( eclass ! = cclass | | ecode ! = num ) {
2001-08-13 04:08:42 +00:00
printf ( " unexpected error code class=%d code=%d \n " ,
2005-06-25 09:07:42 +00:00
( int ) cclass , ( int ) num ) ;
2001-09-04 11:52:42 +00:00
printf ( " expected %d/%d %s (line=%d) \n " ,
2011-07-27 21:51:13 +02:00
( int ) eclass , ( int ) ecode , nt_errstr ( nterr ) ,
line ) ;
2001-08-13 04:08:42 +00:00
return False ;
}
} else {
/* Check NT error */
2001-09-04 11:52:42 +00:00
if ( NT_STATUS_V ( nterr ) ! = NT_STATUS_V ( status ) ) {
2011-07-27 21:51:13 +02:00
printf ( " unexpected error code %s \n " ,
nt_errstr ( status ) ) ;
printf ( " expected %s (line=%d) \n " , nt_errstr ( nterr ) ,
line ) ;
2001-08-13 04:08:42 +00:00
return False ;
}
}
2001-06-19 02:02:19 +00:00
return True ;
}
2007-10-18 17:40:25 -07:00
static bool wait_lock ( struct cli_state * c , int fnum , uint32 offset , uint32 len )
2001-06-19 02:02:19 +00:00
{
2011-07-11 11:50:59 +02:00
NTSTATUS status ;
status = cli_lock32 ( c , fnum , offset , len , - 1 , WRITE_LOCK ) ;
while ( ! NT_STATUS_IS_OK ( status ) ) {
if ( ! check_both_error ( __LINE__ , status , ERRDOS ,
ERRlock , NT_STATUS_LOCK_NOT_GRANTED ) ) {
return false ;
}
status = cli_lock32 ( c , fnum , offset , len , - 1 , WRITE_LOCK ) ;
2001-06-19 02:02:19 +00:00
}
2011-07-11 11:50:59 +02:00
return true ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool rw_torture ( struct cli_state * c )
2001-06-19 02:02:19 +00:00
{
2003-01-03 08:28:12 +00:00
const char * lockfname = " \\ torture.lck " ;
2001-06-19 02:02:19 +00:00
fstring fname ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
uint16_t fnum2 ;
2001-06-19 02:02:19 +00:00
pid_t pid2 , pid = getpid ( ) ;
int i , j ;
char buf [ 1024 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-07-19 15:29:14 +02:00
size_t nread = 0 ;
2009-04-30 15:26:43 -07:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2007-03-23 19:12:08 +00:00
memset ( buf , ' \0 ' , sizeof ( buf ) ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( c , lockfname , O_RDWR | O_CREAT | O_EXCL ,
2009-04-30 15:26:43 -07:00
DENY_NONE , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
status = cli_openx ( c , lockfname , O_RDWR , DENY_NONE , & fnum2 ) ;
2009-04-30 15:26:43 -07:00
}
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-01-20 14:21:40 +01:00
printf ( " open of %s failed (%s) \n " ,
lockfname , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
return False ;
}
2002-04-12 10:18:46 +00:00
for ( i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
unsigned n = ( unsigned ) sys_random ( ) % 10 ;
2011-04-02 11:46:30 +02:00
2001-06-19 02:02:19 +00:00
if ( i % 10 = = 0 ) {
printf ( " %d \r " , i ) ; fflush ( stdout ) ;
}
slprintf ( fname , sizeof ( fstring ) - 1 , " \\ torture.%u " , n ) ;
if ( ! wait_lock ( c , fnum2 , n * sizeof ( int ) , sizeof ( int ) ) ) {
return False ;
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( c , fname , O_RDWR | O_CREAT | O_TRUNC ,
2011-01-20 14:21:40 +01:00
DENY_ALL , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
break ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( c , fnum , 0 , ( uint8_t * ) & pid , 0 ,
sizeof ( pid ) , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
for ( j = 0 ; j < 50 ; j + + ) {
2011-04-02 11:46:30 +02:00
status = cli_writeall ( c , fnum , 0 , ( uint8_t * ) buf ,
sizeof ( pid ) + ( j * sizeof ( buf ) ) ,
sizeof ( buf ) , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " ,
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
}
pid2 = 0 ;
2011-07-19 15:29:14 +02:00
status = cli_read ( c , fnum , ( char * ) & pid2 , 0 , sizeof ( pid ) ,
& nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " read failed (%s) \n " , nt_errstr ( status ) ) ;
correct = false ;
} else if ( nread ! = sizeof ( pid ) ) {
printf ( " read/write compare failed: "
" recv %ld req %ld \n " , ( unsigned long ) nread ,
( unsigned long ) sizeof ( pid ) ) ;
correct = false ;
2001-06-19 02:02:19 +00:00
}
if ( pid2 ! = pid ) {
printf ( " data corruption! \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( c , fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( c , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlock ( c , fnum2 , n * sizeof ( int ) , sizeof ( int ) ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlock failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
}
cli_close ( c , fnum2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( c , lockfname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
printf ( " %d \n " , i ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_torture ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool ret ;
2001-06-19 02:02:19 +00:00
cli = current_cli ;
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
ret = rw_torture ( cli ) ;
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
ret = False ;
}
return ret ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool rw_torture3 ( struct cli_state * c , char * lockfname )
2001-06-19 02:02:19 +00:00
{
2009-04-30 15:26:43 -07:00
uint16_t fnum = ( uint16_t ) - 1 ;
2003-04-18 03:35:39 +00:00
unsigned int i = 0 ;
2001-06-19 02:02:19 +00:00
char buf [ 131072 ] ;
char buf_rd [ 131072 ] ;
unsigned count ;
unsigned countprev = 0 ;
2011-07-19 15:49:03 +02:00
size_t sent = 0 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-21 15:35:11 +01:00
NTSTATUS status = NT_STATUS_OK ;
2001-06-19 02:02:19 +00:00
srandom ( 1 ) ;
for ( i = 0 ; i < sizeof ( buf ) ; i + = sizeof ( uint32 ) )
{
SIVAL ( buf , i , sys_random ( ) ) ;
}
if ( procnum = = 0 )
{
2011-07-07 15:42:33 +02:00
status = cli_unlink (
c , lockfname ,
FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) (normal, this file should "
" not exist) \n " , nt_errstr ( status ) ) ;
2011-02-22 11:21:53 +11:00
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( c , lockfname , O_RDWR | O_CREAT | O_EXCL ,
2011-01-20 14:21:40 +01:00
DENY_NONE , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " first open read/write of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
lockfname , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
return False ;
}
}
else
{
2009-05-03 22:45:42 +02:00
for ( i = 0 ; i < 500 & & fnum = = ( uint16_t ) - 1 ; i + + )
2001-06-19 02:02:19 +00:00
{
2011-12-03 21:13:08 -08:00
status = cli_openx ( c , lockfname , O_RDONLY ,
2009-04-30 15:26:43 -07:00
DENY_NONE , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
break ;
}
2004-02-23 02:54:03 +00:00
smb_msleep ( 10 ) ;
2001-06-19 02:02:19 +00:00
}
2009-04-30 15:26:43 -07:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " second open read-only of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
lockfname , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
return False ;
}
}
i = 0 ;
for ( count = 0 ; count < sizeof ( buf ) ; count + = sent )
{
if ( count > = countprev ) {
printf ( " %d %8d \r " , i , count ) ;
fflush ( stdout ) ;
i + + ;
countprev + = ( sizeof ( buf ) / 20 ) ;
}
if ( procnum = = 0 )
{
sent = ( ( unsigned ) sys_random ( ) % ( 20 ) ) + 1 ;
if ( sent > sizeof ( buf ) - count )
{
sent = sizeof ( buf ) - count ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( c , fnum , 0 , ( uint8_t * ) buf + count ,
2011-07-19 15:49:03 +02:00
count , sent , NULL ) ;
2011-04-02 11:46:30 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " ,
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
}
else
{
2011-07-19 15:49:03 +02:00
status = cli_read ( c , fnum , buf_rd + count , count ,
sizeof ( buf ) - count , & sent ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2003-11-06 22:11:08 +00:00
printf ( " read failed offset:%d size:%ld (%s) \n " ,
count , ( unsigned long ) sizeof ( buf ) - count ,
2011-07-19 15:49:03 +02:00
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
sent = 0 ;
2011-07-19 15:49:03 +02:00
} else if ( sent > 0 ) {
2001-06-19 02:02:19 +00:00
if ( memcmp ( buf_rd + count , buf + count , sent ) ! = 0 )
{
printf ( " read/write compare failed \n " ) ;
2003-11-06 22:11:08 +00:00
printf ( " offset: %d req %ld recvd %ld \n " , count , ( unsigned long ) sizeof ( buf ) - count , ( unsigned long ) sent ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
break ;
}
}
}
}
2011-01-20 14:21:40 +01:00
status = cli_close ( c , fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool rw_torture2 ( struct cli_state * c1 , struct cli_state * c2 )
2001-06-19 02:02:19 +00:00
{
2003-01-03 08:28:12 +00:00
const char * lockfname = " \\ torture2.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
uint16_t fnum2 ;
2001-06-19 02:02:19 +00:00
int i ;
2006-07-11 18:01:26 +00:00
char buf [ 131072 ] ;
char buf_rd [ 131072 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-07-19 16:01:42 +02:00
size_t bytes_read ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_unlink ( c1 , lockfname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) (normal, this file should not exist) \n " , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( c1 , lockfname , O_RDWR | O_CREAT | O_EXCL ,
2011-01-20 14:21:40 +01:00
DENY_NONE , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " first open read/write of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
lockfname , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( c2 , lockfname , O_RDONLY , DENY_NONE , & fnum2 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " second open read-only of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
lockfname , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
cli_close ( c1 , fnum1 ) ;
return False ;
}
2011-01-20 14:21:40 +01:00
for ( i = 0 ; i < torture_numops ; i + + )
2001-06-19 02:02:19 +00:00
{
2001-07-02 03:21:17 +00:00
size_t buf_size = ( ( unsigned ) sys_random ( ) % ( sizeof ( buf ) - 1 ) ) + 1 ;
2001-06-19 02:02:19 +00:00
if ( i % 10 = = 0 ) {
printf ( " %d \r " , i ) ; fflush ( stdout ) ;
}
2006-07-11 18:01:26 +00:00
generate_random_buffer ( ( unsigned char * ) buf , buf_size ) ;
2001-06-19 02:02:19 +00:00
2011-04-02 11:46:30 +02:00
status = cli_writeall ( c1 , fnum1 , 0 , ( uint8_t * ) buf , 0 ,
buf_size , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2003-04-23 08:12:34 +00:00
break ;
2001-06-19 02:02:19 +00:00
}
2011-07-19 16:01:42 +02:00
status = cli_read ( c2 , fnum2 , buf_rd , 0 , buf_size , & bytes_read ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " read failed (%s) \n " , nt_errstr ( status ) ) ;
correct = false ;
break ;
} else if ( bytes_read ! = buf_size ) {
printf ( " read failed \n " ) ;
printf ( " read %ld, expected %ld \n " ,
( unsigned long ) bytes_read ,
2003-11-06 22:11:08 +00:00
( unsigned long ) buf_size ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2003-04-23 08:12:34 +00:00
break ;
2001-06-19 02:02:19 +00:00
}
if ( memcmp ( buf_rd , buf , buf_size ) ! = 0 )
{
printf ( " read/write compare failed \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2003-04-23 08:12:34 +00:00
break ;
2001-06-19 02:02:19 +00:00
}
}
2011-01-20 14:21:40 +01:00
status = cli_close ( c2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( c1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( c1 , lockfname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_readwritetest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2009-07-02 11:06:21 +02:00
struct cli_state * cli1 , * cli2 ;
2007-10-18 17:40:25 -07:00
bool test1 , test2 = False ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting readwritetest \n " ) ;
2003-04-18 03:35:39 +00:00
test1 = rw_torture2 ( cli1 , cli2 ) ;
2001-07-02 03:21:17 +00:00
printf ( " Passed readwritetest v1: %s \n " , BOOLSTR ( test1 ) ) ;
2001-06-19 02:02:19 +00:00
2003-04-23 08:12:34 +00:00
if ( test1 ) {
test2 = rw_torture2 ( cli1 , cli1 ) ;
printf ( " Passed readwritetest v2: %s \n " , BOOLSTR ( test2 ) ) ;
}
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
test1 = False ;
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli2 ) ) {
2001-07-02 03:21:17 +00:00
test2 = False ;
}
return ( test1 & & test2 ) ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_readwritemulti ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool test ;
2001-06-19 02:02:19 +00:00
cli = current_cli ;
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " run_readwritemulti: fname %s \n " , randomfname ) ;
2003-04-23 08:12:34 +00:00
test = rw_torture3 ( cli , randomfname ) ;
2001-06-19 02:02:19 +00:00
2003-04-23 08:12:34 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
test = False ;
}
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
return test ;
2001-06-19 02:02:19 +00:00
}
2011-09-13 13:14:41 +02:00
static bool run_readwritelarge_internal ( void )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2003-01-03 08:28:12 +00:00
const char * lockfname = " \\ large.dat " ;
2012-04-05 14:53:08 +10:00
off_t fsize ;
2002-03-20 01:47:31 +00:00
char buf [ 126 * 1024 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
memset ( buf , ' \0 ' , sizeof ( buf ) ) ;
2009-04-22 11:51:03 +02:00
2010-11-10 17:54:57 -08:00
printf ( " starting readwritelarge_internal \n " ) ;
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , lockfname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , lockfname , O_RDWR | O_CREAT | O_EXCL ,
2011-01-20 14:21:40 +01:00
DENY_NONE , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open read/write of %s failed (%s) \n " , lockfname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2011-04-02 11:46:30 +02:00
cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 0 , sizeof ( buf ) , NULL ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_qfileinfo_basic ( cli1 , fnum1 , NULL , & fsize , NULL , NULL ,
NULL , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " qfileinfo failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
if ( fsize = = sizeof ( buf ) )
2010-11-10 17:54:57 -08:00
printf ( " readwritelarge_internal test 1 succeeded (size = %lx) \n " ,
2003-11-06 22:11:08 +00:00
( unsigned long ) fsize ) ;
2001-07-02 03:21:17 +00:00
else {
2010-11-10 17:54:57 -08:00
printf ( " readwritelarge_internal test 1 failed (size = %lx) \n " ,
2003-11-06 22:11:08 +00:00
( unsigned long ) fsize ) ;
2001-07-07 06:21:32 +00:00
correct = False ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-20 01:47:31 +00:00
correct = False ;
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , lockfname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , lockfname , O_RDWR | O_CREAT | O_EXCL ,
2011-01-20 14:21:40 +01:00
DENY_NONE , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open read/write of %s failed (%s) \n " , lockfname , nt_errstr ( status ) ) ;
2001-07-07 06:21:32 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-03-27 17:04:56 +02:00
cli_smbwrite ( cli1 , fnum1 , buf , 0 , sizeof ( buf ) , NULL ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_qfileinfo_basic ( cli1 , fnum1 , NULL , & fsize , NULL , NULL ,
NULL , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " qfileinfo failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-20 01:47:31 +00:00
correct = False ;
}
if ( fsize = = sizeof ( buf ) )
2010-11-10 17:54:57 -08:00
printf ( " readwritelarge_internal test 2 succeeded (size = %lx) \n " ,
2003-11-06 22:11:08 +00:00
( unsigned long ) fsize ) ;
2002-03-20 01:47:31 +00:00
else {
2010-11-10 17:54:57 -08:00
printf ( " readwritelarge_internal test 2 failed (size = %lx) \n " ,
2003-11-06 22:11:08 +00:00
( unsigned long ) fsize ) ;
2002-03-20 01:47:31 +00:00
correct = False ;
}
2002-03-23 02:57:44 +00:00
#if 0
/* ToDo - set allocation. JRA */
2003-04-18 03:35:39 +00:00
if ( ! cli_set_allocation_size ( cli1 , fnum1 , 0 ) ) {
2002-03-23 02:57:44 +00:00
printf ( " set allocation size to zero failed (%s) \n " , cli_errstr ( & cli1 ) ) ;
return False ;
}
2010-10-23 09:28:47 +02:00
if ( ! cli_qfileinfo_basic ( cli1 , fnum1 , NULL , & fsize , NULL , NULL , NULL ,
NULL , NULL ) ) {
2003-04-18 03:35:39 +00:00
printf ( " qfileinfo failed (%s) \n " , cli_errstr ( cli1 ) ) ;
2002-03-23 02:57:44 +00:00
correct = False ;
}
if ( fsize ! = 0 )
printf ( " readwritelarge test 3 (truncate test) succeeded (size = %x) \n " , fsize ) ;
# endif
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-07 06:21:32 +00:00
correct = False ;
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
return correct ;
2003-04-18 03:35:39 +00:00
}
2001-06-19 02:02:19 +00:00
2010-11-10 17:54:57 -08:00
static bool run_readwritelarge ( int dummy )
{
2011-09-13 13:14:41 +02:00
return run_readwritelarge_internal ( ) ;
2010-11-10 17:54:57 -08:00
}
static bool run_readwritelarge_signtest ( int dummy )
{
bool ret ;
2011-11-02 18:41:50 +01:00
signing_state = SMB_SIGNING_REQUIRED ;
2011-09-13 13:14:41 +02:00
ret = run_readwritelarge_internal ( ) ;
2011-11-02 18:41:50 +01:00
signing_state = SMB_SIGNING_DEFAULT ;
2010-11-10 17:54:57 -08:00
return ret ;
}
2001-06-19 02:02:19 +00:00
int line_count = 0 ;
2002-02-05 01:31:47 +00:00
int nbio_id ;
# define ival(s) strtol(s, NULL, 0)
2001-06-19 02:02:19 +00:00
/* run a test that simulates an approximate netbench client load */
2007-10-18 17:40:25 -07:00
static bool run_netbench ( int client )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2001-06-19 02:02:19 +00:00
int i ;
2007-12-04 17:05:33 -08:00
char line [ 1024 ] ;
2001-06-19 02:02:19 +00:00
char cname [ 20 ] ;
FILE * f ;
2003-04-23 08:12:34 +00:00
const char * params [ 20 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-06-19 02:02:19 +00:00
cli = current_cli ;
2002-02-05 01:31:47 +00:00
nbio_id = client ;
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
nb_setup ( cli ) ;
2001-06-19 02:02:19 +00:00
2005-07-20 13:43:38 +00:00
slprintf ( cname , sizeof ( cname ) - 1 , " client%d " , client ) ;
2001-06-19 02:02:19 +00:00
2002-02-05 01:31:47 +00:00
f = fopen ( client_txt , " r " ) ;
2001-06-19 02:02:19 +00:00
if ( ! f ) {
2002-02-05 01:31:47 +00:00
perror ( client_txt ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
while ( fgets ( line , sizeof ( line ) - 1 , f ) ) {
2008-01-23 11:04:10 +01:00
char * saveptr ;
2001-06-19 02:02:19 +00:00
line_count + + ;
line [ strlen ( line ) - 1 ] = 0 ;
/* printf("[%d] %s\n", line_count, line); */
2002-02-05 01:31:47 +00:00
all_string_sub ( line , " client1 " , cname , sizeof ( line ) ) ;
2007-12-04 17:05:33 -08:00
2001-06-19 02:02:19 +00:00
/* parse the command parameters */
2008-01-23 11:04:10 +01:00
params [ 0 ] = strtok_r ( line , " " , & saveptr ) ;
2001-06-19 02:02:19 +00:00
i = 0 ;
2008-01-23 11:04:10 +01:00
while ( params [ i ] ) params [ + + i ] = strtok_r ( NULL , " " , & saveptr ) ;
2001-06-19 02:02:19 +00:00
params [ i ] = " " ;
if ( i < 2 ) continue ;
2002-02-05 01:31:47 +00:00
if ( ! strncmp ( params [ 0 ] , " SMB " , 3 ) ) {
printf ( " ERROR: You are using a dbench 1 load file \n " ) ;
exit ( 1 ) ;
}
if ( ! strcmp ( params [ 0 ] , " NTCreateX " ) ) {
nb_createx ( params [ 1 ] , ival ( params [ 2 ] ) , ival ( params [ 3 ] ) ,
ival ( params [ 4 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " Close " ) ) {
nb_close ( ival ( params [ 1 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " Rename " ) ) {
nb_rename ( params [ 1 ] , params [ 2 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " Unlink " ) ) {
nb_unlink ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " Deltree " ) ) {
nb_deltree ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " Rmdir " ) ) {
nb_rmdir ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " QUERY_PATH_INFORMATION " ) ) {
nb_qpathinfo ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " QUERY_FILE_INFORMATION " ) ) {
nb_qfileinfo ( ival ( params [ 1 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " QUERY_FS_INFORMATION " ) ) {
nb_qfsinfo ( ival ( params [ 1 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " FIND_FIRST " ) ) {
nb_findfirst ( params [ 1 ] ) ;
} else if ( ! strcmp ( params [ 0 ] , " WriteX " ) ) {
nb_writex ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , ival ( params [ 4 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " ReadX " ) ) {
nb_readx ( ival ( params [ 1 ] ) ,
ival ( params [ 2 ] ) , ival ( params [ 3 ] ) , ival ( params [ 4 ] ) ) ;
} else if ( ! strcmp ( params [ 0 ] , " Flush " ) ) {
nb_flush ( ival ( params [ 1 ] ) ) ;
2001-06-19 02:02:19 +00:00
} else {
2002-02-05 01:31:47 +00:00
printf ( " Unknown operation %s \n " , params [ 0 ] ) ;
exit ( 1 ) ;
2001-06-19 02:02:19 +00:00
}
}
fclose ( f ) ;
2002-02-05 03:55:20 +00:00
nb_cleanup ( ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2002-02-05 01:31:47 +00:00
/* run a test that simulates an approximate netbench client load */
2007-10-18 17:40:25 -07:00
static bool run_nbench ( int dummy )
2001-06-19 02:02:19 +00:00
{
double t ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-06-19 02:02:19 +00:00
2012-04-04 14:29:33 +02:00
nbio_shmem ( torture_nprocs ) ;
2002-02-05 01:31:47 +00:00
nbio_id = - 1 ;
signal ( SIGALRM , nb_alarm ) ;
alarm ( 1 ) ;
2001-07-02 03:21:17 +00:00
t = create_procs ( run_netbench , & correct ) ;
2002-02-05 01:31:47 +00:00
alarm ( 0 ) ;
printf ( " \n Throughput %g MB/sec \n " ,
1.0e-6 * nbio_total ( ) / t ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
This test checks for two things :
1 ) correct support for retaining locks over a close ( ie . the server
must not use posix semantics )
2 ) support for lock timeouts
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest1 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt1.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 , fnum3 ;
2001-06-19 02:02:19 +00:00
time_t t1 , t2 ;
2002-09-25 15:19:00 +00:00
unsigned lock_timeout ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting locktest1 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli2 , fname , O_RDWR , DENY_NONE , & fnum3 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open3 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:05:14 +02:00
status = cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " lock1 failed (%s) \n " , nt_errstr ( status ) ) ;
return false ;
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:05:14 +02:00
status = cli_lock32 ( cli2 , fnum3 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock2 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:05:14 +02:00
return false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:05:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_LOCK_NOT_GRANTED ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2002-09-25 15:19:00 +00:00
lock_timeout = ( 1 + ( random ( ) % 20 ) ) ;
printf ( " Testing lock timeout with timeout=%u \n " , lock_timeout ) ;
2001-06-19 02:02:19 +00:00
t1 = time ( NULL ) ;
2011-07-11 14:05:14 +02:00
status = cli_lock32 ( cli2 , fnum3 , 0 , 4 , lock_timeout * 1000 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock3 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:05:14 +02:00
return false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:05:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_FILE_LOCK_CONFLICT ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
t2 = time ( NULL ) ;
2003-06-10 14:01:57 +00:00
if ( ABS ( t2 - t1 ) < lock_timeout - 1 ) {
2001-06-19 02:02:19 +00:00
printf ( " error: This server appears not to support timed lock requests \n " ) ;
}
2003-06-10 14:01:57 +00:00
2002-09-25 15:19:00 +00:00
printf ( " server slept for %u seconds for a %u second timeout \n " ,
( unsigned int ) ( t2 - t1 ) , lock_timeout ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:05:14 +02:00
status = cli_lock32 ( cli2 , fnum3 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock4 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:05:14 +02:00
return false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:05:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_FILE_LOCK_CONFLICT ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum3 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close3 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli2 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2001-06-19 02:02:19 +00:00
printf ( " Passed locktest1 \n " ) ;
2001-07-02 03:21:17 +00:00
return True ;
2001-06-19 02:02:19 +00:00
}
/*
2003-04-18 03:35:39 +00:00
this checks to see if a secondary tconx can use open files from an
earlier tconx
2001-06-19 02:02:19 +00:00
*/
2007-10-18 17:40:25 -07:00
static bool run_tcon_test ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ tcontest.tmp " ;
2009-04-30 15:26:43 -07:00
uint16 fnum1 ;
2003-04-18 03:35:39 +00:00
uint16 cnum1 , cnum2 , cnum3 ;
uint16 vuid1 , vuid2 ;
2001-06-19 02:02:19 +00:00
char buf [ 4 ] ;
2007-10-18 17:40:25 -07:00
bool ret = True ;
2009-01-26 08:37:13 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2007-03-25 02:17:05 +00:00
memset ( buf , ' \0 ' , sizeof ( buf ) ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting tcontest \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-19 16:25:52 +02:00
cnum1 = cli_state_get_tid ( cli ) ;
2011-07-21 09:20:43 +02:00
vuid1 = cli_state_get_uid ( cli ) ;
2001-06-19 02:02:19 +00:00
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " initial write failed (%s) " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-10-31 17:49:29 +01:00
status = cli_tree_connect ( cli , share , " ????? " ,
password , strlen ( password ) + 1 ) ;
2009-01-26 08:37:13 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " %s refused 2nd tree connect (%s) \n " , host ,
2009-01-26 08:37:13 +01:00
nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
cli_shutdown ( cli ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-19 16:25:52 +02:00
cnum2 = cli_state_get_tid ( cli ) ;
2003-04-18 03:35:39 +00:00
cnum3 = MAX ( cnum1 , cnum2 ) + 1 ; /* any invalid number */
2011-07-21 09:20:43 +02:00
vuid2 = cli_state_get_uid ( cli ) + 1 ;
2003-04-18 03:35:39 +00:00
/* try a write with the wrong tid */
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum2 ) ;
2003-04-18 03:35:39 +00:00
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2003-04-18 03:35:39 +00:00
printf ( " * server allows write with wrong TID \n " ) ;
ret = False ;
} else {
2011-04-02 11:46:30 +02:00
printf ( " server fails write with wrong TID : %s \n " ,
nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
}
/* try a write with an invalid tid */
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum3 ) ;
2003-04-18 03:35:39 +00:00
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2003-04-18 03:35:39 +00:00
printf ( " * server allows write with invalid TID \n " ) ;
ret = False ;
} else {
2011-04-02 11:46:30 +02:00
printf ( " server fails write with invalid TID : %s \n " ,
nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
}
/* try a write with an invalid vuid */
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , vuid2 ) ;
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum1 ) ;
2003-04-18 03:35:39 +00:00
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2003-04-18 03:35:39 +00:00
printf ( " * server allows write with invalid VUID \n " ) ;
ret = False ;
} else {
2011-04-02 11:46:30 +02:00
printf ( " server fails write with invalid VUID : %s \n " ,
nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
}
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum1 ) ;
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , vuid1 ) ;
2003-04-18 03:35:39 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum2 ) ;
2003-04-18 03:35:39 +00:00
2010-01-03 18:46:57 +01:00
status = cli_tdis ( cli ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " secondary tdis failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , cnum1 ) ;
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
return ret ;
}
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
/*
checks for old style tcon support
*/
2007-10-18 17:40:25 -07:00
static bool run_tcon2_test ( int dummy )
2003-04-18 03:35:39 +00:00
{
static struct cli_state * cli ;
uint16 cnum , max_xmit ;
char * service ;
NTSTATUS status ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2003-04-18 03:35:39 +00:00
printf ( " starting tcon2 test \n " ) ;
2009-01-02 11:38:24 -08:00
if ( asprintf ( & service , " \\ \\ %s \\ %s " , host , share ) = = - 1 ) {
return false ;
}
2003-04-18 03:35:39 +00:00
status = cli_raw_tcon ( cli , service , password , " ????? " , & max_xmit , & cnum ) ;
2011-03-27 17:43:11 +02:00
SAFE_FREE ( service ) ;
2003-04-18 03:35:39 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-03-27 17:37:24 +02:00
printf ( " tcon2 failed : %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
} else {
2011-03-27 18:03:24 +02:00
printf ( " tcon OK : max_xmit=%d cnum=%d \n " ,
( int ) max_xmit , ( int ) cnum ) ;
2003-04-18 03:35:39 +00:00
}
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
printf ( " Passed tcon2 test \n " ) ;
2001-07-02 03:21:17 +00:00
return True ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool tcon_devtest ( struct cli_state * cli ,
2003-03-30 16:37:10 +00:00
const char * myshare , const char * devtype ,
2003-04-23 09:26:07 +00:00
const char * return_devtype ,
2003-03-30 16:37:10 +00:00
NTSTATUS expected_error )
{
2009-01-26 08:37:13 +01:00
NTSTATUS status ;
2007-10-18 17:40:25 -07:00
bool ret ;
2003-03-30 16:37:10 +00:00
2011-10-31 17:49:29 +01:00
status = cli_tree_connect ( cli , myshare , devtype ,
password , strlen ( password ) + 1 ) ;
2003-03-30 16:37:10 +00:00
if ( NT_STATUS_IS_OK ( expected_error ) ) {
2009-01-26 08:37:13 +01:00
if ( NT_STATUS_IS_OK ( status ) ) {
2003-04-23 09:26:07 +00:00
if ( strcmp ( cli - > dev , return_devtype ) = = 0 ) {
ret = True ;
} else {
printf ( " tconX to share %s with type %s "
" succeeded but returned the wrong "
" device type (got [%s] but should have got [%s]) \n " ,
myshare , devtype , cli - > dev , return_devtype ) ;
ret = False ;
}
2003-03-30 16:37:10 +00:00
} else {
printf ( " tconX to share %s with type %s "
" should have succeeded but failed \n " ,
myshare , devtype ) ;
ret = False ;
}
cli_tdis ( cli ) ;
} else {
2009-01-26 08:37:13 +01:00
if ( NT_STATUS_IS_OK ( status ) ) {
2003-03-30 16:37:10 +00:00
printf ( " tconx to share %s with type %s "
" should have failed but succeeded \n " ,
myshare , devtype ) ;
ret = False ;
} else {
2011-11-16 16:21:13 +01:00
if ( NT_STATUS_EQUAL ( status , expected_error ) ) {
2003-03-30 16:37:10 +00:00
ret = True ;
} else {
printf ( " Returned unexpected error \n " ) ;
ret = False ;
}
}
}
return ret ;
}
/*
checks for correct tconX support
*/
2007-10-18 17:40:25 -07:00
static bool run_tcon_devtype_test ( int dummy )
2003-03-30 16:37:10 +00:00
{
static struct cli_state * cli1 = NULL ;
int flags = 0 ;
NTSTATUS status ;
2007-10-18 17:40:25 -07:00
bool ret = True ;
2003-03-30 16:37:10 +00:00
status = cli_full_connection ( & cli1 , myname ,
host , NULL , port_to_use ,
NULL , NULL ,
username , workgroup ,
2010-12-20 16:37:23 +01:00
password , flags , signing_state ) ;
2003-03-30 16:37:10 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " could not open connection \n " ) ;
return False ;
}
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , " IPC$ " , " A: " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , " IPC$ " , " ????? " , " IPC " , NT_STATUS_OK ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , " IPC$ " , " LPT: " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , " IPC$ " , " IPC " , " IPC " , NT_STATUS_OK ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2009-04-22 11:51:03 +02:00
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , " IPC$ " , " FOOBA " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , share , " A: " , " A: " , NT_STATUS_OK ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , share , " ????? " , " A: " , NT_STATUS_OK ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , share , " LPT: " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , share , " IPC " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
2009-04-22 11:51:03 +02:00
2003-04-23 09:26:07 +00:00
if ( ! tcon_devtest ( cli1 , share , " FOOBA " , NULL , NT_STATUS_BAD_DEVICE_TYPE ) )
2003-03-30 16:37:10 +00:00
ret = False ;
cli_shutdown ( cli1 ) ;
if ( ret )
printf ( " Passed tcondevtest \n " ) ;
return ret ;
}
2001-06-19 02:02:19 +00:00
/*
This test checks that
1 ) the server supports multiple locking contexts on the one SMB
connection , distinguished by PID .
2 ) the server correctly fails overlapping locks made by the same PID ( this
goes against POSIX behaviour , which is why it is tricky to implement )
3 ) the server denies unlock requests by an incorrect client PID
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest2 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt2.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 , fnum3 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting locktest2 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 1 ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 2 ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR , DENY_NONE , & fnum3 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open3 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 1 ) ;
2001-06-19 02:02:19 +00:00
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " lock1 failed (%s) \n " , nt_errstr ( status ) ) ;
return false ;
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " WRITE lock1 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:20:14 +02:00
correct = false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:20:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_LOCK_NOT_GRANTED ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum2 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " WRITE lock2 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:20:14 +02:00
correct = false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:20:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_LOCK_NOT_GRANTED ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum2 , 0 , 4 , 0 , READ_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " READ lock2 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:20:14 +02:00
correct = false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:20:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_FILE_LOCK_CONFLICT ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum1 , 100 , 4 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " lock at 100 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-07 06:21:32 +00:00
}
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 2 ) ;
2009-07-15 11:49:33 -07:00
if ( NT_STATUS_IS_OK ( cli_unlock ( cli , fnum1 , 100 , 4 ) ) ) {
2001-07-07 06:21:32 +00:00
printf ( " unlock at 100 succeeded! This is a locking bug \n " ) ;
correct = False ;
}
2001-06-19 02:02:19 +00:00
2011-07-11 14:23:30 +02:00
status = cli_unlock ( cli , fnum1 , 0 , 4 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " unlock1 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:23:30 +02:00
correct = false ;
2001-07-07 06:21:32 +00:00
} else {
2011-07-11 14:23:30 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_RANGE_NOT_LOCKED ) ) {
return false ;
}
2001-07-07 06:21:32 +00:00
}
2011-07-11 14:23:30 +02:00
status = cli_unlock ( cli , fnum1 , 0 , 8 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-07-07 06:21:32 +00:00
printf ( " unlock2 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:23:30 +02:00
correct = false ;
2001-07-07 06:21:32 +00:00
} else {
2011-07-11 14:23:30 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_RANGE_NOT_LOCKED ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2011-07-11 14:20:14 +02:00
status = cli_lock32 ( cli , fnum3 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock3 succeeded! This is a locking bug \n " ) ;
2011-07-11 14:20:14 +02:00
correct = false ;
2001-06-19 02:02:19 +00:00
} else {
2011-07-11 14:20:14 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRlock ,
NT_STATUS_LOCK_NOT_GRANTED ) ) {
return false ;
}
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 1 ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli , fnum3 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close3 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " locktest2 finished \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
This test checks that
1 ) the server supports the full offset range in lock requests
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest3 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt3.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 ;
int i ;
2001-06-19 02:02:19 +00:00
uint32 offset ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2002-04-12 10:18:46 +00:00
# define NEXT_OFFSET offset += (~(uint32)0) / torture_numops
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting locktest3 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli2 , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2002-04-12 10:18:46 +00:00
for ( offset = i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
NEXT_OFFSET ;
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli1 , fnum1 , offset - 1 , 1 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock1 %d failed (%s) \n " ,
i ,
2011-07-18 12:39:35 +02:00
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli2 , fnum2 , offset - 2 , 1 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " lock2 %d failed (%s) \n " ,
i ,
2011-07-18 12:39:35 +02:00
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
}
2002-04-12 10:18:46 +00:00
for ( offset = i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
NEXT_OFFSET ;
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli1 , fnum1 , offset - 2 , 1 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " error: lock1 %d succeeded! \n " , i ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli2 , fnum2 , offset - 1 , 1 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " error: lock2 %d succeeded! \n " , i ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli1 , fnum1 , offset - 1 , 1 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " error: lock3 %d succeeded! \n " , i ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-18 12:39:35 +02:00
status = cli_lock32 ( cli2 , fnum2 , offset - 2 , 1 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " error: lock4 %d succeeded! \n " , i ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
}
2002-04-12 10:18:46 +00:00
for ( offset = i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
NEXT_OFFSET ;
2011-01-20 14:21:40 +01:00
status = cli_unlock ( cli1 , fnum1 , offset - 1 , 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " unlock1 %d failed (%s) \n " ,
i ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlock ( cli2 , fnum2 , offset - 2 , 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " unlock2 %d failed (%s) \n " ,
i ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli2 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished locktest3 \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2011-07-22 10:48:35 +02:00
static bool test_cli_read ( struct cli_state * cli , uint16_t fnum ,
char * buf , off_t offset , size_t size ,
size_t * nread , size_t expect )
{
NTSTATUS status ;
size_t l_nread ;
status = cli_read ( cli , fnum , buf , offset , size , & l_nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return false ;
} else if ( l_nread ! = expect ) {
return false ;
}
if ( nread ) {
* nread = l_nread ;
}
return true ;
}
2001-07-02 03:21:17 +00:00
# define EXPECTED(ret, v) if ((ret) != (v)) { \
printf ( " ** " ) ; correct = False ; \
}
2001-06-19 02:02:19 +00:00
/*
looks at overlapping locks
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest4 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt4.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 , f ;
2007-10-18 17:40:25 -07:00
bool ret ;
2001-06-19 02:02:19 +00:00
char buf [ 1000 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-04-02 11:46:30 +02:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting locktest4 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
cli_openx ( cli2 , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
2001-06-19 02:02:19 +00:00
memset ( buf , 0 , sizeof ( buf ) ) ;
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 0 , sizeof ( buf ) ,
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Failed to create file: %s \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
goto fail ;
}
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 2 , 4 , 0 , WRITE_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same process %s set overlapping write locks \n " , ret ? " can " : " cannot " ) ;
2009-04-22 11:51:03 +02:00
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 10 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 12 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s set overlapping read locks \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 20 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli2 , fnum2 , 22 , 4 , 0 , WRITE_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " a different connection %s set overlapping write locks \n " , ret ? " can " : " cannot " ) ;
2009-04-22 11:51:03 +02:00
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 30 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli2 , fnum2 , 32 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " a different connection %s set overlapping read locks \n " , ret ? " can " : " cannot " ) ;
2009-04-22 11:51:03 +02:00
2011-07-18 14:03:55 +02:00
ret = ( cli_setpid ( cli1 , 1 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 40 , 4 , 0 , WRITE_LOCK ) ) ) & &
( cli_setpid ( cli1 , 2 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 42 , 4 , 0 , WRITE_LOCK ) ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " a different pid %s set overlapping write locks \n " , ret ? " can " : " cannot " ) ;
2009-04-22 11:51:03 +02:00
2011-07-18 14:03:55 +02:00
ret = ( cli_setpid ( cli1 , 1 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 50 , 4 , 0 , READ_LOCK ) ) ) & &
( cli_setpid ( cli1 , 2 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 52 , 4 , 0 , READ_LOCK ) ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " a different pid %s set overlapping read locks \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 60 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 60 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s set the same read lock twice \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 70 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 70 , 4 , 0 , WRITE_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same process %s set the same write lock twice \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 80 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 80 , 4 , 0 , WRITE_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same process %s overlay a read lock with a write lock \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 90 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 90 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s overlay a write lock with a read lock \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = ( cli_setpid ( cli1 , 1 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 100 , 4 , 0 , WRITE_LOCK ) ) ) & &
( cli_setpid ( cli1 , 2 ) ,
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 100 , 4 , 0 , READ_LOCK ) ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " a different pid %s overlay a write lock with a read lock \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 110 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 112 , 4 , 0 , READ_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 110 , 6 ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same process %s coalesce read locks \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 120 , 4 , 0 , WRITE_LOCK ) ) & &
2011-07-22 11:18:30 +02:00
test_cli_read ( cli2 , fnum2 , buf , 120 , 4 , NULL , 4 ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " this server %s strict write locking \n " , ret ? " doesn't do " : " does " ) ;
2011-07-18 14:03:55 +02:00
status = cli_lock32 ( cli1 , fnum1 , 130 , 4 , 0 , READ_LOCK ) ;
ret = NT_STATUS_IS_OK ( status ) ;
2011-04-02 11:46:30 +02:00
if ( ret ) {
status = cli_writeall ( cli2 , fnum2 , 0 , ( uint8_t * ) buf , 130 , 4 ,
NULL ) ;
ret = NT_STATUS_IS_OK ( status ) ;
}
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " this server %s strict read locking \n " , ret ? " doesn't do " : " does " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 140 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 140 , 4 , 0 , READ_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 140 , 4 ) ) & &
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 140 , 4 ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " this server %s do recursive read locking \n " , ret ? " does " : " doesn't " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 150 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 150 , 4 , 0 , READ_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 150 , 4 ) ) & &
2011-07-22 11:18:30 +02:00
test_cli_read ( cli2 , fnum2 , buf , 150 , 4 , NULL , 4 ) & &
2011-04-02 11:46:30 +02:00
! ( NT_STATUS_IS_OK ( cli_writeall ( cli2 , fnum2 , 0 , ( uint8_t * ) buf ,
150 , 4 , NULL ) ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 150 , 4 ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " this server %s do recursive lock overlays \n " , ret ? " does " : " doesn't " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 160 , 4 , 0 , READ_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 160 , 4 ) ) & &
2011-04-02 11:46:30 +02:00
NT_STATUS_IS_OK ( cli_writeall ( cli2 , fnum2 , 0 , ( uint8_t * ) buf ,
160 , 4 , NULL ) ) & &
2011-07-22 11:18:30 +02:00
test_cli_read ( cli2 , fnum2 , buf , 160 , 4 , NULL , 4 ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s remove a read lock using write locking \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 170 , 4 , 0 , WRITE_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 170 , 4 ) ) & &
2011-04-02 11:46:30 +02:00
NT_STATUS_IS_OK ( cli_writeall ( cli2 , fnum2 , 0 , ( uint8_t * ) buf ,
170 , 4 , NULL ) ) & &
2011-07-22 11:18:30 +02:00
test_cli_read ( cli2 , fnum2 , buf , 170 , 4 , NULL , 4 ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s remove a write lock using read locking \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 190 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 190 , 4 , 0 , READ_LOCK ) ) & &
2009-07-15 11:49:33 -07:00
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 190 , 4 ) ) & &
2011-04-02 11:46:30 +02:00
! NT_STATUS_IS_OK ( cli_writeall ( cli2 , fnum2 , 0 , ( uint8_t * ) buf ,
190 , 4 , NULL ) ) & &
2011-07-22 11:18:30 +02:00
test_cli_read ( cli2 , fnum2 , buf , 190 , 4 , NULL , 4 ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s remove the first lock first \n " , ret ? " does " : " doesn't " ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
cli_close ( cli2 , fnum2 ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & f ) ;
2011-07-18 14:03:55 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 8 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , f , 0 , 1 , 0 , READ_LOCK ) ) & &
2009-04-30 16:57:42 -07:00
NT_STATUS_IS_OK ( cli_close ( cli1 , fnum1 ) ) & &
2011-12-03 21:13:08 -08:00
NT_STATUS_IS_OK ( cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ) & &
2011-07-18 14:03:55 +02:00
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 7 , 1 , 0 , WRITE_LOCK ) ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , f ) ;
cli_close ( cli1 , fnum1 ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the server %s have the NT byte range lock bug \n " , ! ret ? " does " : " doesn't " ) ;
2002-03-11 01:37:08 +00:00
2001-06-19 02:02:19 +00:00
fail :
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
cli_close ( cli2 , fnum2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli1 ) ;
torture_close_connection ( cli2 ) ;
2001-06-19 02:02:19 +00:00
printf ( " finished locktest4 \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
looks at lock upgrade / downgrade .
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest5 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt5.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 , fnum3 ;
2007-10-18 17:40:25 -07:00
bool ret ;
2001-06-19 02:02:19 +00:00
char buf [ 1000 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-04-02 11:46:30 +02:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting locktest5 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
cli_openx ( cli2 , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum3 ) ;
2001-06-19 02:02:19 +00:00
memset ( buf , 0 , sizeof ( buf ) ) ;
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 0 , sizeof ( buf ) ,
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Failed to create file: %s \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
goto fail ;
}
/* Check for NT bug... */
2011-07-18 14:09:50 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 8 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum3 , 0 , 1 , 0 , READ_LOCK ) ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
2011-07-18 14:09:50 +02:00
status = cli_lock32 ( cli1 , fnum1 , 7 , 1 , 0 , WRITE_LOCK ) ;
ret = NT_STATUS_IS_OK ( status ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " this server %s the NT locking bug \n " , ret ? " doesn't have " : " has " ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
2003-04-18 03:35:39 +00:00
cli_unlock ( cli1 , fnum3 , 0 , 1 ) ;
2001-06-19 02:02:19 +00:00
2011-07-18 14:09:50 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 1 , 1 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s overlay a write with a read lock \n " , ret ? " can " : " cannot " ) ;
2011-07-18 14:09:50 +02:00
status = cli_lock32 ( cli2 , fnum2 , 0 , 4 , 0 , READ_LOCK ) ;
ret = NT_STATUS_IS_OK ( status ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " a different processs %s get a read lock on the first process lock stack \n " , ret ? " can " : " cannot " ) ;
/* Unlock the process 2 lock. */
2003-04-18 03:35:39 +00:00
cli_unlock ( cli2 , fnum2 , 0 , 4 ) ;
2001-06-19 02:02:19 +00:00
2011-07-18 14:09:50 +02:00
status = cli_lock32 ( cli1 , fnum3 , 0 , 4 , 0 , READ_LOCK ) ;
ret = NT_STATUS_IS_OK ( status ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same processs on a different fnum %s get a read lock \n " , ret ? " can " : " cannot " ) ;
/* Unlock the process 1 fnum3 lock. */
2003-04-18 03:35:39 +00:00
cli_unlock ( cli1 , fnum3 , 0 , 4 ) ;
2001-06-19 02:02:19 +00:00
/* Stack 2 more locks here. */
2011-07-18 14:09:50 +02:00
ret = NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , READ_LOCK ) ) & &
NT_STATUS_IS_OK ( cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s stack read locks \n " , ret ? " can " : " cannot " ) ;
/* Unlock the first process lock, then check this was the WRITE lock that was
removed . */
2009-07-15 11:49:33 -07:00
ret = NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 0 , 4 ) ) & &
2011-07-18 14:09:50 +02:00
NT_STATUS_IS_OK ( cli_lock32 ( cli2 , fnum2 , 0 , 4 , 0 , READ_LOCK ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the first unlock removes the %s lock \n " , ret ? " WRITE " : " READ " ) ;
/* Unlock the process 2 lock. */
2003-04-18 03:35:39 +00:00
cli_unlock ( cli2 , fnum2 , 0 , 4 ) ;
2001-06-19 02:02:19 +00:00
/* We should have 3 stacked locks here. Ensure we need to do 3 unlocks. */
2009-07-15 11:49:33 -07:00
ret = NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 1 , 1 ) ) & &
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 0 , 4 ) ) & &
NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 0 , 4 ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " the same process %s unlock the stack of 4 locks \n " , ret ? " can " : " cannot " ) ;
/* Ensure the next unlock fails. */
2009-07-15 11:49:33 -07:00
ret = NT_STATUS_IS_OK ( cli_unlock ( cli1 , fnum1 , 0 , 4 ) ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , False ) ;
printf ( " the same process %s count the lock stack \n " , ! ret ? " can " : " cannot " ) ;
/* Ensure connection 2 can get a write lock. */
2011-07-18 14:09:50 +02:00
status = cli_lock32 ( cli2 , fnum2 , 0 , 4 , 0 , WRITE_LOCK ) ;
ret = NT_STATUS_IS_OK ( status ) ;
2001-06-19 02:02:19 +00:00
EXPECTED ( ret , True ) ;
printf ( " a different processs %s get a write lock on the unlocked stack \n " , ret ? " can " : " cannot " ) ;
2001-07-02 03:21:17 +00:00
2001-06-19 02:02:19 +00:00
fail :
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
cli_close ( cli2 , fnum2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli2 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished locktest5 \n " ) ;
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2002-03-11 01:37:08 +00:00
/*
tries the unusual lockingX locktype bits
*/
2007-10-18 17:40:25 -07:00
static bool run_locktest6 ( int dummy )
2002-03-11 01:37:08 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2003-01-03 08:28:12 +00:00
const char * fname [ 1 ] = { " \\ lock6.txt " } ;
2002-03-11 01:57:39 +00:00
int i ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2002-03-11 01:37:08 +00:00
NTSTATUS status ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2002-03-11 01:37:08 +00:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2002-03-11 01:37:08 +00:00
printf ( " starting locktest6 \n " ) ;
2002-03-11 15:56:59 +00:00
for ( i = 0 ; i < 1 ; i + + ) {
2002-03-11 01:57:39 +00:00
printf ( " Testing %s \n " , fname [ i ] ) ;
2002-03-11 01:37:08 +00:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname [ i ] , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-11 01:37:08 +00:00
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname [ i ] , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum ) ;
2003-04-18 03:35:39 +00:00
status = cli_locktype ( cli , fnum , 0 , 8 , 0 , LOCKING_ANDX_CHANGE_LOCKTYPE ) ;
cli_close ( cli , fnum ) ;
2002-03-17 04:36:35 +00:00
printf ( " CHANGE_LOCKTYPE gave %s \n " , nt_errstr ( status ) ) ;
2002-03-11 01:57:39 +00:00
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname [ i ] , O_RDWR , DENY_NONE , & fnum ) ;
2003-04-18 03:35:39 +00:00
status = cli_locktype ( cli , fnum , 0 , 8 , 0 , LOCKING_ANDX_CANCEL_LOCK ) ;
cli_close ( cli , fnum ) ;
2002-03-17 04:36:35 +00:00
printf ( " CANCEL_LOCK gave %s \n " , nt_errstr ( status ) ) ;
2002-03-11 01:57:39 +00:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname [ i ] , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-11 01:57:39 +00:00
}
2002-03-11 01:37:08 +00:00
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli ) ;
2002-03-11 01:37:08 +00:00
printf ( " finished locktest6 \n " ) ;
return True ;
}
2007-10-18 17:40:25 -07:00
static bool run_locktest7 ( int dummy )
2003-04-18 03:35:39 +00:00
{
struct cli_state * cli1 ;
const char * fname = " \\ lockt7.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2003-04-18 03:35:39 +00:00
char buf [ 200 ] ;
2007-10-18 17:40:25 -07:00
bool correct = False ;
2011-07-23 09:16:27 +02:00
size_t nread ;
2011-04-02 11:46:30 +02:00
NTSTATUS status ;
2003-04-18 03:35:39 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2003-04-18 03:35:39 +00:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2003-04-18 03:35:39 +00:00
printf ( " starting locktest7 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
2011-12-03 21:13:08 -08:00
cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2003-04-18 03:35:39 +00:00
memset ( buf , 0 , sizeof ( buf ) ) ;
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 0 , sizeof ( buf ) ,
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Failed to create file: %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
}
cli_setpid ( cli1 , 1 ) ;
2011-07-18 12:51:19 +02:00
status = cli_lock32 ( cli1 , fnum1 , 130 , 4 , 0 , READ_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-07-23 09:16:27 +02:00
printf ( " Unable to apply read lock on range 130:4, "
" error was %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
} else {
printf ( " pid1 successfully locked range 130:4 for READ \n " ) ;
}
2011-07-23 09:16:27 +02:00
status = cli_read ( cli1 , fnum1 , buf , 130 , 4 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid1 unable to read the range 130:4, error was %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
} else if ( nread ! = 4 ) {
printf ( " pid1 unable to read the range 130:4, "
" recv %ld req %d \n " , ( unsigned long ) nread , 4 ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
} else {
printf ( " pid1 successfully read the range 130:4 \n " ) ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid1 unable to write to the range 130:4, error was "
" %s \n " , nt_errstr ( status ) ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_LOCK_CONFLICT ) ) {
2003-04-18 03:35:39 +00:00
printf ( " Incorrect error (should be NT_STATUS_FILE_LOCK_CONFLICT) \n " ) ;
goto fail ;
}
} else {
printf ( " pid1 successfully wrote to the range 130:4 (should be denied) \n " ) ;
goto fail ;
}
cli_setpid ( cli1 , 2 ) ;
2011-07-23 09:16:27 +02:00
status = cli_read ( cli1 , fnum1 , buf , 130 , 4 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid2 unable to read the range 130:4, error was %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
} else if ( nread ! = 4 ) {
printf ( " pid2 unable to read the range 130:4, "
" recv %ld req %d \n " , ( unsigned long ) nread , 4 ) ;
2011-07-23 09:10:09 +02:00
goto fail ;
2003-04-18 03:35:39 +00:00
} else {
printf ( " pid2 successfully read the range 130:4 \n " ) ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid2 unable to write to the range 130:4, error was "
" %s \n " , nt_errstr ( status ) ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_LOCK_CONFLICT ) ) {
2003-04-18 03:35:39 +00:00
printf ( " Incorrect error (should be NT_STATUS_FILE_LOCK_CONFLICT) \n " ) ;
goto fail ;
}
} else {
printf ( " pid2 successfully wrote to the range 130:4 (should be denied) \n " ) ;
goto fail ;
}
cli_setpid ( cli1 , 1 ) ;
cli_unlock ( cli1 , fnum1 , 130 , 4 ) ;
2011-07-18 12:51:19 +02:00
status = cli_lock32 ( cli1 , fnum1 , 130 , 4 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Unable to apply write lock on range 130:4, error was %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
} else {
printf ( " pid1 successfully locked range 130:4 for WRITE \n " ) ;
}
2011-07-23 09:16:27 +02:00
status = cli_read ( cli1 , fnum1 , buf , 130 , 4 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid1 unable to read the range 130:4, error was %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
} else if ( nread ! = 4 ) {
printf ( " pid1 unable to read the range 130:4, "
" recv %ld req %d \n " , ( unsigned long ) nread , 4 ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
} else {
printf ( " pid1 successfully read the range 130:4 \n " ) ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid1 unable to write to the range 130:4, error was "
" %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
} else {
printf ( " pid1 successfully wrote to the range 130:4 \n " ) ;
}
cli_setpid ( cli1 , 2 ) ;
2011-07-23 09:16:27 +02:00
status = cli_read ( cli1 , fnum1 , buf , 130 , 4 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid2 unable to read the range 130:4, error was "
" %s \n " , nt_errstr ( status ) ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_LOCK_CONFLICT ) ) {
2003-04-18 03:35:39 +00:00
printf ( " Incorrect error (should be NT_STATUS_FILE_LOCK_CONFLICT) \n " ) ;
goto fail ;
}
} else {
2011-07-23 09:16:27 +02:00
printf ( " pid2 successfully read the range 130:4 (should be denied) recv %ld \n " ,
( unsigned long ) nread ) ;
2003-04-18 03:35:39 +00:00
goto fail ;
}
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 130 , 4 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " pid2 unable to write to the range 130:4, error was "
" %s \n " , nt_errstr ( status ) ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_LOCK_CONFLICT ) ) {
2003-04-18 03:35:39 +00:00
printf ( " Incorrect error (should be NT_STATUS_FILE_LOCK_CONFLICT) \n " ) ;
goto fail ;
}
} else {
printf ( " pid2 successfully wrote to the range 130:4 (should be denied) \n " ) ;
goto fail ;
}
cli_unlock ( cli1 , fnum1 , 130 , 0 ) ;
correct = True ;
fail :
cli_close ( cli1 , fnum1 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli1 ) ;
printf ( " finished locktest7 \n " ) ;
return correct ;
}
2009-05-20 14:56:04 +02:00
/*
* This demonstrates a problem with our use of GPFS share modes : A file
* descriptor sitting in the pending close queue holding a GPFS share mode
* blocks opening a file another time . Happens with Word 2007 temp files .
* With " posix locking = yes " and " gpfs:sharemodes = yes " enabled , the third
* open is denied with NT_STATUS_SHARING_VIOLATION .
*/
static bool run_locktest8 ( int dummy )
{
struct cli_state * cli1 ;
const char * fname = " \\ lockt8.lck " ;
uint16_t fnum1 , fnum2 ;
char buf [ 200 ] ;
bool correct = False ;
NTSTATUS status ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-05-20 14:56:04 +02:00
printf ( " starting locktest8 \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-05-20 14:56:04 +02:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_WRITE ,
2009-05-20 14:56:04 +02:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
d_fprintf ( stderr , " cli_openx returned %s \n " , nt_errstr ( status ) ) ;
2009-05-20 14:56:04 +02:00
return false ;
}
memset ( buf , 0 , sizeof ( buf ) ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum2 ) ;
2009-05-20 14:56:04 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
d_fprintf ( stderr , " cli_openx second time returned %s \n " ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2009-05-20 14:56:04 +02:00
goto fail ;
}
2011-07-18 13:09:52 +02:00
status = cli_lock32 ( cli1 , fnum2 , 1 , 1 , 0 , READ_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-20 14:56:04 +02:00
printf ( " Unable to apply read lock on range 1:1, error was "
2011-07-18 13:09:52 +02:00
" %s \n " , nt_errstr ( status ) ) ;
2009-05-20 14:56:04 +02:00
goto fail ;
}
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-01-20 14:21:40 +01:00
d_fprintf ( stderr , " cli_close(fnum1) %s \n " , nt_errstr ( status ) ) ;
2009-05-20 14:56:04 +02:00
goto fail ;
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
2009-05-20 14:56:04 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
d_fprintf ( stderr , " cli_openx third time returned %s \n " ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2009-05-20 14:56:04 +02:00
goto fail ;
}
correct = true ;
fail :
cli_close ( cli1 , fnum1 ) ;
cli_close ( cli1 , fnum2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-05-20 14:56:04 +02:00
torture_close_connection ( cli1 ) ;
printf ( " finished locktest8 \n " ) ;
return correct ;
}
2009-10-20 17:37:43 -07:00
/*
* This test is designed to be run in conjunction with
* external NFS or POSIX locks taken in the filesystem .
2009-10-20 17:41:27 -07:00
* It checks that the smbd server will block until the
* lock is released and then acquire it . JRA .
2009-10-20 17:37:43 -07:00
*/
static bool got_alarm ;
2011-07-22 09:34:29 +02:00
static struct cli_state * alarm_cli ;
2009-10-20 17:37:43 -07:00
static void alarm_handler ( int dummy )
{
got_alarm = True ;
}
static void alarm_handler_parent ( int dummy )
{
2012-05-20 16:26:25 +02:00
smbXcli_conn_disconnect ( alarm_cli - > conn , NT_STATUS_OK ) ;
2009-10-20 17:37:43 -07:00
}
static void do_local_lock ( int read_fd , int write_fd )
{
int fd ;
char c = ' \0 ' ;
struct flock lock ;
const char * local_pathname = NULL ;
int ret ;
local_pathname = talloc_asprintf ( talloc_tos ( ) ,
" %s/lockt9.lck " , local_path ) ;
if ( ! local_pathname ) {
printf ( " child: alloc fail \n " ) ;
exit ( 1 ) ;
}
unlink ( local_pathname ) ;
fd = open ( local_pathname , O_RDWR | O_CREAT , 0666 ) ;
if ( fd = = - 1 ) {
printf ( " child: open of %s failed %s. \n " ,
local_pathname , strerror ( errno ) ) ;
exit ( 1 ) ;
}
/* Now take a fcntl lock. */
lock . l_type = F_WRLCK ;
lock . l_whence = SEEK_SET ;
lock . l_start = 0 ;
lock . l_len = 4 ;
lock . l_pid = getpid ( ) ;
ret = fcntl ( fd , F_SETLK , & lock ) ;
if ( ret = = - 1 ) {
printf ( " child: failed to get lock 0:4 on file %s. Error %s \n " ,
local_pathname , strerror ( errno ) ) ;
exit ( 1 ) ;
} else {
printf ( " child: got lock 0:4 on file %s. \n " ,
local_pathname ) ;
fflush ( stdout ) ;
}
CatchSignal ( SIGALRM , alarm_handler ) ;
alarm ( 5 ) ;
/* Signal the parent. */
if ( write ( write_fd , & c , 1 ) ! = 1 ) {
printf ( " child: start signal fail %s. \n " ,
strerror ( errno ) ) ;
exit ( 1 ) ;
}
alarm ( 0 ) ;
alarm ( 10 ) ;
/* Wait for the parent to be ready. */
if ( read ( read_fd , & c , 1 ) ! = 1 ) {
printf ( " child: reply signal fail %s. \n " ,
strerror ( errno ) ) ;
exit ( 1 ) ;
}
alarm ( 0 ) ;
sleep ( 5 ) ;
close ( fd ) ;
printf ( " child: released lock 0:4 on file %s. \n " ,
local_pathname ) ;
fflush ( stdout ) ;
exit ( 0 ) ;
}
static bool run_locktest9 ( int dummy )
{
struct cli_state * cli1 ;
const char * fname = " \\ lockt9.lck " ;
uint16_t fnum ;
bool correct = False ;
int pipe_in [ 2 ] , pipe_out [ 2 ] ;
pid_t child_pid ;
char c = ' \0 ' ;
int ret ;
2009-11-24 10:59:09 +01:00
struct timeval start ;
2009-10-20 17:37:43 -07:00
double seconds ;
NTSTATUS status ;
printf ( " starting locktest9 \n " ) ;
if ( local_path = = NULL ) {
d_fprintf ( stderr , " locktest9 must be given a local path via -l <localpath> \n " ) ;
return false ;
}
if ( pipe ( pipe_in ) = = - 1 | | pipe ( pipe_out ) = = - 1 ) {
return false ;
}
child_pid = fork ( ) ;
if ( child_pid = = - 1 ) {
return false ;
}
if ( child_pid = = 0 ) {
/* Child. */
do_local_lock ( pipe_out [ 0 ] , pipe_in [ 1 ] ) ;
exit ( 0 ) ;
}
close ( pipe_out [ 0 ] ) ;
close ( pipe_in [ 1 ] ) ;
pipe_out [ 0 ] = - 1 ;
pipe_in [ 1 ] = - 1 ;
/* Parent. */
ret = read ( pipe_in [ 0 ] , & c , 1 ) ;
if ( ret ! = 1 ) {
d_fprintf ( stderr , " failed to read start signal from child. %s \n " ,
strerror ( errno ) ) ;
return false ;
}
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
return false ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-10-20 17:37:43 -07:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_NONE ,
2009-10-20 17:37:43 -07:00
& fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
d_fprintf ( stderr , " cli_openx returned %s \n " , nt_errstr ( status ) ) ;
2009-10-20 17:37:43 -07:00
return false ;
}
/* Ensure the child has the lock. */
2011-07-18 13:15:49 +02:00
status = cli_lock32 ( cli1 , fnum , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2009-10-20 17:37:43 -07:00
d_fprintf ( stderr , " Got the lock on range 0:4 - this should not happen ! \n " ) ;
goto fail ;
} else {
d_printf ( " Child has the lock. \n " ) ;
}
/* Tell the child to wait 5 seconds then exit. */
ret = write ( pipe_out [ 1 ] , & c , 1 ) ;
if ( ret ! = 1 ) {
d_fprintf ( stderr , " failed to send exit signal to child. %s \n " ,
strerror ( errno ) ) ;
goto fail ;
}
/* Wait 20 seconds for the lock. */
2011-07-22 09:34:29 +02:00
alarm_cli = cli1 ;
2009-10-20 17:37:43 -07:00
CatchSignal ( SIGALRM , alarm_handler_parent ) ;
alarm ( 20 ) ;
2009-11-24 10:59:09 +01:00
start = timeval_current ( ) ;
2009-10-20 17:37:43 -07:00
2011-07-18 13:15:49 +02:00
status = cli_lock32 ( cli1 , fnum , 0 , 4 , - 1 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-10-20 17:37:43 -07:00
d_fprintf ( stderr , " Unable to apply write lock on range 0:4, error was "
2011-07-18 13:15:49 +02:00
" %s \n " , nt_errstr ( status ) ) ;
2009-10-20 17:37:43 -07:00
goto fail_nofd ;
}
alarm ( 0 ) ;
2009-11-24 10:59:09 +01:00
seconds = timeval_elapsed ( & start ) ;
2009-10-20 17:37:43 -07:00
printf ( " Parent got the lock after %.2f seconds. \n " ,
seconds ) ;
status = cli_close ( cli1 , fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-01-20 14:21:40 +01:00
d_fprintf ( stderr , " cli_close(fnum1) %s \n " , nt_errstr ( status ) ) ;
2009-10-20 17:37:43 -07:00
goto fail ;
}
correct = true ;
fail :
cli_close ( cli1 , fnum ) ;
torture_close_connection ( cli1 ) ;
fail_nofd :
printf ( " finished locktest9 \n " ) ;
return correct ;
}
2001-06-19 02:02:19 +00:00
/*
test whether fnums and tids open on one VC are available on another ( a major
security hole )
*/
2007-10-18 17:40:25 -07:00
static bool run_fdpasstest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ fdpass.tst " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2007-12-04 17:05:33 -08:00
char buf [ 1024 ] ;
2011-04-02 11:46:30 +02:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) | | ! torture_open_connection ( & cli2 , 1 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting fdpasstest \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-05-05 16:44:27 -07:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( const uint8_t * ) " hello world \n " , 0 ,
2011-04-02 11:46:30 +02:00
13 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli2 , cli_state_get_uid ( cli1 ) ) ;
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli2 , cli_state_get_tid ( cli1 ) ) ;
2011-07-19 12:56:51 +02:00
cli_setpid ( cli2 , cli_getpid ( cli1 ) ) ;
2001-06-19 02:02:19 +00:00
2011-07-22 12:12:42 +02:00
if ( test_cli_read ( cli2 , fnum1 , buf , 0 , 13 , NULL , 13 ) ) {
printf ( " read succeeded! nasty security hole [%s] \n " , buf ) ;
return false ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli1 ) ;
torture_close_connection ( cli2 ) ;
2001-06-19 02:02:19 +00:00
printf ( " finished fdpasstest \n " ) ;
2001-07-02 03:21:17 +00:00
return True ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_fdsesstest ( int dummy )
2003-04-18 03:35:39 +00:00
{
struct cli_state * cli ;
uint16 new_vuid ;
uint16 saved_vuid ;
uint16 new_cnum ;
uint16 saved_cnum ;
const char * fname = " \\ fdsess.tst " ;
const char * fname1 = " \\ fdsess1.tst " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
uint16_t fnum2 ;
2007-12-04 17:05:33 -08:00
char buf [ 1024 ] ;
2007-10-18 17:40:25 -07:00
bool ret = True ;
2011-04-02 11:46:30 +02:00
NTSTATUS status ;
2003-04-18 03:35:39 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) )
2003-04-18 03:35:39 +00:00
return False ;
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2003-04-18 03:35:39 +00:00
if ( ! torture_cli_session_setup2 ( cli , & new_vuid ) )
return False ;
2011-07-19 16:25:52 +02:00
saved_cnum = cli_state_get_tid ( cli ) ;
2011-10-31 17:49:29 +01:00
if ( ! NT_STATUS_IS_OK ( cli_tree_connect ( cli , share , " ????? " , " " , 1 ) ) )
2003-04-18 03:35:39 +00:00
return False ;
2011-07-19 16:25:52 +02:00
new_cnum = cli_state_get_tid ( cli ) ;
cli_state_set_tid ( cli , saved_cnum ) ;
2003-04-18 03:35:39 +00:00
printf ( " starting fdsesstest \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2011-05-05 16:44:27 -07:00
status = cli_writeall ( cli , fnum1 , 0 , ( const uint8_t * ) " hello world \n " , 0 , 13 ,
2011-04-02 11:46:30 +02:00
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2011-07-21 09:20:43 +02:00
saved_vuid = cli_state_get_uid ( cli ) ;
cli_state_set_uid ( cli , new_vuid ) ;
2003-04-18 03:35:39 +00:00
2011-07-22 12:19:34 +02:00
if ( test_cli_read ( cli , fnum1 , buf , 0 , 13 , NULL , 13 ) ) {
printf ( " read succeeded with different vuid! "
" nasty security hole [%s] \n " , buf ) ;
ret = false ;
2003-04-18 03:35:39 +00:00
}
/* Try to open a file with different vuid, samba cnum. */
2011-12-03 21:13:08 -08:00
if ( NT_STATUS_IS_OK ( cli_openx ( cli , fname1 , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum2 ) ) ) {
2003-04-18 03:35:39 +00:00
printf ( " create with different vuid, same cnum succeeded. \n " ) ;
cli_close ( cli , fnum2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
} else {
printf ( " create with different vuid, same cnum failed. \n " ) ;
printf ( " This will cause problems with service clients. \n " ) ;
ret = False ;
}
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , saved_vuid ) ;
2003-04-18 03:35:39 +00:00
/* Try with same vuid, different cnum. */
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , new_cnum ) ;
2003-04-18 03:35:39 +00:00
2011-07-22 12:19:34 +02:00
if ( test_cli_read ( cli , fnum1 , buf , 0 , 13 , NULL , 13 ) ) {
printf ( " read succeeded with different cnum![%s] \n " , buf ) ;
ret = false ;
2003-04-18 03:35:39 +00:00
}
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , saved_cnum ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum1 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli ) ;
printf ( " finished fdsesstest \n " ) ;
return ret ;
}
2001-06-19 02:02:19 +00:00
/*
This test checks that
1 ) the server does not allow an unlink on a file that is open
*/
2007-10-18 17:40:25 -07:00
static bool run_unlinktest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ unlink.tst " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
printf ( " starting unlink test \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
cli_setpid ( cli , 1 ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-07-07 17:56:19 +02:00
status = cli_unlink ( cli , fname ,
FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " error: server allowed unlink on an open file \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-08-23 23:16:42 +00:00
} else {
2011-07-27 21:51:45 +02:00
correct = check_error ( __LINE__ , status , ERRDOS , ERRbadshare ,
2001-08-23 23:16:42 +00:00
NT_STATUS_SHARING_VIOLATION ) ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " unlink test finished \n " ) ;
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
test how many open files this server supports on the one socket
*/
2007-10-18 17:40:25 -07:00
static bool run_maxfidtest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2001-06-19 02:02:19 +00:00
fstring fname ;
2009-04-30 15:26:43 -07:00
uint16_t fnums [ 0x11000 ] ;
int i ;
2001-06-19 02:02:19 +00:00
int retries = 4 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
cli = current_cli ;
if ( retries < = 0 ) {
printf ( " failed to connect \n " ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
2001-08-20 05:15:26 +00:00
for ( i = 0 ; i < 0x11000 ; i + + ) {
2011-05-05 16:44:27 -07:00
slprintf ( fname , sizeof ( fname ) - 1 , " \\ maxfid.%d.%d " , i , ( int ) getpid ( ) ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_TRUNC , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnums [ i ] ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " open of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
fname , nt_errstr ( status ) ) ;
2001-08-20 05:15:26 +00:00
printf ( " maximum fnum is %d \n " , i ) ;
2001-06-19 02:02:19 +00:00
break ;
}
2001-08-23 23:16:42 +00:00
printf ( " %6d \r " , i ) ;
2001-06-19 02:02:19 +00:00
}
2001-08-23 23:16:42 +00:00
printf ( " %6d \n " , i ) ;
2001-11-20 08:49:16 +00:00
i - - ;
2001-06-19 02:02:19 +00:00
printf ( " cleaning up \n " ) ;
2001-08-20 05:15:26 +00:00
for ( ; i > = 0 ; i - - ) {
2011-05-05 16:44:27 -07:00
slprintf ( fname , sizeof ( fname ) - 1 , " \\ maxfid.%d.%d " , i , ( int ) getpid ( ) ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnums [ i ] ) ;
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " unlink of %s failed (%s) \n " ,
2011-01-20 14:21:40 +01:00
fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2001-08-23 23:16:42 +00:00
printf ( " %6d \r " , i ) ;
2001-06-19 02:02:19 +00:00
}
2001-08-23 23:16:42 +00:00
printf ( " %6d \n " , 0 ) ;
2001-06-19 02:02:19 +00:00
printf ( " maxfid test finished \n " ) ;
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
return correct ;
2001-06-19 02:02:19 +00:00
}
/* generate a random buffer */
static void rand_buf ( char * buf , int len )
{
while ( len - - ) {
* buf = ( char ) sys_random ( ) ;
buf + + ;
}
}
/* send smb negprot commands, not reading the response */
2007-10-18 17:40:25 -07:00
static bool run_negprot_nowait ( int dummy )
2001-06-19 02:02:19 +00:00
{
2011-03-27 17:34:36 +02:00
struct tevent_context * ev ;
2001-06-19 02:02:19 +00:00
int i ;
2011-03-27 17:20:28 +02:00
struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-06-19 02:02:19 +00:00
printf ( " starting negprot nowait test \n " ) ;
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2011-03-27 17:34:36 +02:00
if ( ev = = NULL ) {
return false ;
}
2006-07-11 18:01:26 +00:00
if ( ! ( cli = open_nbt_connection ( ) ) ) {
2011-03-27 17:34:36 +02:00
TALLOC_FREE ( ev ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
for ( i = 0 ; i < 50000 ; i + + ) {
2011-03-27 17:34:36 +02:00
struct tevent_req * req ;
2012-05-20 17:54:29 +02:00
req = smbXcli_negprot_send ( ev , ev , cli - > conn , cli - > timeout ,
PROTOCOL_CORE , PROTOCOL_NT1 ) ;
2011-03-27 17:34:36 +02:00
if ( req = = NULL ) {
TALLOC_FREE ( ev ) ;
return false ;
}
if ( ! tevent_req_poll ( req , ev ) ) {
d_fprintf ( stderr , " tevent_req_poll failed: %s \n " ,
strerror ( errno ) ) ;
TALLOC_FREE ( ev ) ;
return false ;
}
TALLOC_FREE ( req ) ;
2001-06-19 02:02:19 +00:00
}
2011-03-27 17:34:36 +02:00
if ( torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished negprot nowait test \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2010-09-27 18:24:01 -07:00
/* send smb negprot commands, not reading the response */
static bool run_bad_nbt_session ( int dummy )
{
2011-05-29 18:43:31 +02:00
struct nmb_name called , calling ;
struct sockaddr_storage ss ;
NTSTATUS status ;
int fd ;
bool ret ;
2010-09-27 18:24:01 -07:00
printf ( " starting bad nbt session test \n " ) ;
2011-05-29 18:43:31 +02:00
make_nmb_name ( & calling , myname , 0x0 ) ;
make_nmb_name ( & called , host , 0x20 ) ;
if ( ! resolve_name ( host , & ss , 0x20 , true ) ) {
d_fprintf ( stderr , " Could not resolve name %s \n " , host ) ;
return false ;
}
2012-02-14 21:51:35 -06:00
status = open_socket_out ( & ss , NBT_SMB_PORT , 10000 , & fd ) ;
2011-05-29 18:43:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_fprintf ( stderr , " open_socket_out failed: %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
ret = cli_bad_session_request ( fd , & calling , & called ) ;
close ( fd ) ;
if ( ! ret ) {
d_fprintf ( stderr , " open_socket_out failed: %s \n " ,
nt_errstr ( status ) ) ;
return false ;
2010-09-27 18:24:01 -07:00
}
printf ( " finished bad nbt session test \n " ) ;
return true ;
}
2001-06-19 02:02:19 +00:00
/* send random IPC commands */
2007-10-18 17:40:25 -07:00
static bool run_randomipc ( int dummy )
2001-06-19 02:02:19 +00:00
{
char * rparam = NULL ;
char * rdata = NULL ;
2006-07-11 18:01:26 +00:00
unsigned int rdrcnt , rprcnt ;
2007-12-04 17:05:33 -08:00
char param [ 1024 ] ;
2001-06-19 02:02:19 +00:00
int api , param_len , i ;
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-08-23 23:16:42 +00:00
int count = 50000 ;
2001-06-19 02:02:19 +00:00
printf ( " starting random ipc test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2001-08-23 23:16:42 +00:00
for ( i = 0 ; i < count ; i + + ) {
2001-06-19 02:02:19 +00:00
api = sys_random ( ) % 500 ;
param_len = ( sys_random ( ) % 64 ) ;
rand_buf ( param , param_len ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
SSVAL ( param , 0 , api ) ;
2003-04-18 03:35:39 +00:00
cli_api ( cli ,
2001-06-19 02:02:19 +00:00
param , param_len , 8 ,
NULL , 0 , BUFFER_SIZE ,
& rparam , & rprcnt ,
& rdata , & rdrcnt ) ;
2001-08-23 23:16:42 +00:00
if ( i % 100 = = 0 ) {
printf ( " %d/%d \r " , i , count ) ;
}
2001-06-19 02:02:19 +00:00
}
2001-08-23 23:16:42 +00:00
printf ( " %d/%d \n " , i , count ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
2013-02-20 09:47:19 +01:00
SAFE_FREE ( rparam ) ;
SAFE_FREE ( rdata ) ;
2001-06-19 02:02:19 +00:00
printf ( " finished random ipc test \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
static void browse_callback ( const char * sname , uint32 stype ,
const char * comment , void * state )
{
printf ( " \t %20.20s %08x %s \n " , sname , stype , comment ) ;
}
/*
This test checks the browse list code
*/
2007-10-18 17:40:25 -07:00
static bool run_browsetest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-06-19 02:02:19 +00:00
printf ( " starting browse test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
printf ( " domain list: \n " ) ;
2003-04-18 03:35:39 +00:00
cli_NetServerEnum ( cli , cli - > server_domain ,
2001-06-19 02:02:19 +00:00
SV_TYPE_DOMAIN_ENUM ,
browse_callback , NULL ) ;
printf ( " machine list: \n " ) ;
2003-04-18 03:35:39 +00:00
cli_NetServerEnum ( cli , cli - > server_domain ,
2001-06-19 02:02:19 +00:00
SV_TYPE_ALL ,
browse_callback , NULL ) ;
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " browse test finished \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
This checks how the getatr calls works
*/
2007-10-18 17:40:25 -07:00
static bool run_attrtest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2001-06-19 02:02:19 +00:00
time_t t , t2 ;
2003-04-18 03:35:39 +00:00
const char * fname = " \\ attrib123456789.tst " ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
printf ( " starting attrib test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname ,
2009-04-30 15:26:43 -07:00
O_RDWR | O_CREAT | O_TRUNC , DENY_NONE , & fnum ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli , fname , NULL , NULL , & t ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " getatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2002-03-03 20:47:44 +00:00
if ( abs ( t - time ( NULL ) ) > 60 * 60 * 24 * 10 ) {
2001-06-19 02:02:19 +00:00
printf ( " ERROR: SMBgetatr bug. time is %s " ,
ctime ( & t ) ) ;
t = time ( NULL ) ;
2001-07-02 03:21:17 +00:00
correct = True ;
2001-06-19 02:02:19 +00:00
}
t2 = t - 60 * 60 * 24 ; /* 1 day ago */
2011-01-20 14:21:40 +01:00
status = cli_setatr ( cli , fname , 0 , t2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " setatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = True ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli , fname , NULL , NULL , & t ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " getatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = True ;
2001-06-19 02:02:19 +00:00
}
if ( t ! = t2 ) {
printf ( " ERROR: getatr/setatr bug. times are \n %s " ,
ctime ( & t ) ) ;
printf ( " %s " , ctime ( & t2 ) ) ;
2001-07-02 03:21:17 +00:00
correct = True ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " attrib test finished \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
This checks a couple of trans2 calls
*/
2007-10-18 17:40:25 -07:00
static bool run_trans2test ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2012-04-05 14:53:08 +10:00
off_t size ;
2006-08-27 16:50:10 +00:00
time_t c_time , a_time , m_time ;
2006-08-24 16:44:00 +00:00
struct timespec c_time_ts , a_time_ts , m_time_ts , w_time_ts , m_time2_ts ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ trans2.tst " ;
const char * dname = " \\ trans2 " ;
const char * fname2 = " \\ trans2 \\ trans2.tst " ;
2011-07-06 14:35:13 +02:00
char * pname ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2009-11-21 13:46:52 +01:00
NTSTATUS status ;
uint32_t fs_attr ;
2001-06-19 02:02:19 +00:00
printf ( " starting trans2 test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2009-11-21 13:46:52 +01:00
status = cli_get_fs_attr_info ( cli , & fs_attr ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: cli_get_fs_attr_info returned %s \n " ,
nt_errstr ( status ) ) ;
correct = false ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname , O_RDWR | O_CREAT | O_TRUNC , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
status = cli_qfileinfo_basic ( cli , fnum , NULL , & size , & c_time_ts ,
& a_time_ts , & w_time_ts , & m_time_ts , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qfileinfo failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2002-02-21 04:27:16 +00:00
2011-07-06 14:35:13 +02:00
status = cli_qfilename ( cli , fnum , talloc_tos ( ) , & pname ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qfilename failed (%s) \n " , nt_errstr ( status ) ) ;
2002-02-21 04:27:16 +00:00
correct = False ;
}
if ( strcmp ( pname , fname ) ) {
printf ( " qfilename gave different name? [%s] [%s] \n " ,
fname , pname ) ;
correct = False ;
}
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2001-06-19 02:02:19 +00:00
sleep ( 2 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_TRUNC , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-08-22 03:15:33 +00:00
return False ;
}
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2001-06-19 02:02:19 +00:00
2010-07-26 08:34:35 +02:00
status = cli_qpathinfo1 ( cli , fname , & c_time , & a_time , & m_time , & size ,
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qpathinfo failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
} else {
2011-09-07 10:32:53 +02:00
time_t t = time ( NULL ) ;
2001-06-19 02:02:19 +00:00
if ( c_time ! = m_time ) {
printf ( " create time=%s " , ctime ( & c_time ) ) ;
printf ( " modify time=%s " , ctime ( & m_time ) ) ;
printf ( " This system appears to have sticky create times \n " ) ;
}
2011-09-07 10:32:53 +02:00
if ( ( abs ( a_time - t ) > 60 ) & & ( a_time % ( 60 * 60 ) = = 0 ) ) {
2001-06-19 02:02:19 +00:00
printf ( " access time=%s " , ctime ( & a_time ) ) ;
printf ( " This system appears to set a midnight access time \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-09-07 10:32:53 +02:00
if ( abs ( m_time - t ) > 60 * 60 * 24 * 7 ) {
2001-08-23 23:16:42 +00:00
printf ( " ERROR: totally incorrect times - maybe word reversed? mtime=%s " , ctime ( & m_time ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname ,
2009-04-30 15:26:43 -07:00
O_RDWR | O_CREAT | O_TRUNC , DENY_NONE , & fnum ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2010-07-26 09:27:11 +02:00
status = cli_qpathinfo2 ( cli , fname , & c_time_ts , & a_time_ts , & w_time_ts ,
& m_time_ts , & size , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qpathinfo2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
} else {
2006-08-24 16:44:00 +00:00
if ( w_time_ts . tv_sec < 60 * 60 * 24 * 2 ) {
printf ( " write time=%s " , ctime ( & w_time_ts . tv_sec ) ) ;
2001-06-19 02:02:19 +00:00
printf ( " This system appears to set a initial 0 write time \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
/* check if the server updates the directory modification time
when creating a new file */
2011-01-20 14:21:40 +01:00
status = cli_mkdir ( cli , dname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: mkdir failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
sleep ( 3 ) ;
2010-07-26 09:27:11 +02:00
status = cli_qpathinfo2 ( cli , " \\ trans2 \\ " , & c_time_ts , & a_time_ts ,
& w_time_ts , & m_time_ts , & size , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qpathinfo2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname2 ,
2009-04-30 15:26:43 -07:00
O_RDWR | O_CREAT | O_TRUNC , DENY_NONE , & fnum ) ;
2011-04-02 11:46:30 +02:00
cli_writeall ( cli , fnum , 0 , ( uint8_t * ) & fnum , 0 , sizeof ( fnum ) , NULL ) ;
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2010-07-26 09:27:11 +02:00
status = cli_qpathinfo2 ( cli , " \\ trans2 \\ " , & c_time_ts , & a_time_ts ,
& w_time_ts , & m_time2_ts , & size , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qpathinfo2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
} else {
2006-08-27 16:50:10 +00:00
if ( memcmp ( & m_time_ts , & m_time2_ts , sizeof ( struct timespec ) )
= = 0 ) {
2001-06-19 02:02:19 +00:00
printf ( " This system does not update directory modification times \n " ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname2 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
cli_rmdir ( cli , dname ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " trans2 test finished \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
This checks new W2K calls .
*/
2010-10-24 11:21:56 +02:00
static NTSTATUS new_trans ( struct cli_state * pcli , int fnum , int level )
2001-06-19 02:02:19 +00:00
{
2010-10-24 11:21:56 +02:00
uint8_t * buf = NULL ;
2004-02-20 22:45:53 +00:00
uint32 len ;
2010-10-24 11:21:56 +02:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2010-10-24 11:21:56 +02:00
status = cli_qfileinfo ( talloc_tos ( ) , pcli , fnum , level , 0 ,
2011-09-13 13:12:09 +02:00
CLI_BUFFER_SIZE , NULL , & buf , & len ) ;
2010-10-24 11:21:56 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ERROR: qfileinfo (%d) failed (%s) \n " , level ,
nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
} else {
2004-02-20 22:45:53 +00:00
printf ( " qfileinfo: level %d, len = %u \n " , level , len ) ;
2007-03-28 13:34:59 +00:00
dump_data ( 0 , ( uint8 * ) buf , len ) ;
2001-06-19 02:02:19 +00:00
printf ( " \n " ) ;
}
2010-10-24 11:21:56 +02:00
TALLOC_FREE ( buf ) ;
return status ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_w2ktest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ w2ktest \\ w2k.tst " ;
2001-06-19 02:02:19 +00:00
int level ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-06-19 02:02:19 +00:00
printf ( " starting w2k test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-12-03 21:13:08 -08:00
cli_openx ( cli , fname ,
2009-04-30 15:26:43 -07:00
O_RDWR | O_CREAT , DENY_NONE , & fnum ) ;
2001-06-19 02:02:19 +00:00
2001-07-02 03:21:17 +00:00
for ( level = 1004 ; level < 1040 ; level + + ) {
2003-04-18 03:35:39 +00:00
new_trans ( cli , fnum , level ) ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " w2k test finished \n " ) ;
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
/*
this is a harness for some oplock tests
*/
2007-10-18 17:40:25 -07:00
static bool run_oplock1 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli1 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt1.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
printf ( " starting oplock test 1 \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
2003-04-18 03:35:39 +00:00
cli1 - > use_oplocks = True ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli1 - > use_oplocks = False ;
2001-06-19 02:02:19 +00:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished oplock test 1 \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2007-10-18 17:40:25 -07:00
static bool run_oplock2 ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli1 , * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ lockt2.lck " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 ;
2001-06-19 02:02:19 +00:00
int saved_use_oplocks = use_oplocks ;
char buf [ 4 ] ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
volatile bool * shared_correct ;
2011-07-22 12:29:59 +02:00
size_t nread ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2001-07-02 03:21:17 +00:00
2012-07-25 08:33:31 +02:00
shared_correct = ( volatile bool * ) anonymous_shared_allocate ( sizeof ( bool ) ) ;
2001-07-02 03:21:17 +00:00
* shared_correct = True ;
2001-06-19 02:02:19 +00:00
use_level_II_oplocks = True ;
use_oplocks = True ;
printf ( " starting oplock test 2 \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2001-06-19 02:02:19 +00:00
use_level_II_oplocks = False ;
use_oplocks = saved_use_oplocks ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli2 , 1 ) ) {
2001-06-19 02:02:19 +00:00
use_level_II_oplocks = False ;
use_oplocks = saved_use_oplocks ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
/* Don't need the globals any more. */
use_level_II_oplocks = False ;
use_oplocks = saved_use_oplocks ;
if ( fork ( ) = = 0 ) {
/* Child code */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli2 , fname , O_RDWR , DENY_NONE , & fnum2 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " second open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
* shared_correct = False ;
2001-06-19 02:02:19 +00:00
exit ( 0 ) ;
}
sleep ( 2 ) ;
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
* shared_correct = False ;
2001-06-19 02:02:19 +00:00
}
exit ( 0 ) ;
}
sleep ( 2 ) ;
2005-03-03 04:08:13 +00:00
/* Ensure cli1 processes the break. Empty file should always return 0
* bytes . */
2011-07-22 12:29:59 +02:00
status = cli_read ( cli1 , fnum1 , buf , 0 , 4 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " read on fnum1 failed (%s) \n " , nt_errstr ( status ) ) ;
correct = false ;
} else if ( nread ! = 0 ) {
printf ( " read on empty fnum1 failed. recv %ld expected %d \n " ,
( unsigned long ) nread , 0 ) ;
correct = false ;
2001-06-19 02:02:19 +00:00
}
/* Should now be at level II. */
/* Test if sending a write locks causes a break to none. */
2011-07-18 13:19:12 +02:00
status = cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , READ_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " lock failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_unlock ( cli1 , fnum1 , 0 , 4 ) ;
2001-06-19 02:02:19 +00:00
sleep ( 2 ) ;
2011-07-18 13:19:12 +02:00
status = cli_lock32 ( cli1 , fnum1 , 0 , 4 , 0 , WRITE_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " lock failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_unlock ( cli1 , fnum1 , 0 , 4 ) ;
2001-06-19 02:02:19 +00:00
sleep ( 2 ) ;
2011-07-22 12:29:59 +02:00
cli_read ( cli1 , fnum1 , buf , 0 , 4 , NULL ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
sleep ( 4 ) ;
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
if ( ! * shared_correct ) {
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished oplock test 2 \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2011-05-22 18:50:16 +02:00
struct oplock4_state {
struct tevent_context * ev ;
struct cli_state * cli ;
bool * got_break ;
uint16_t * fnum2 ;
} ;
2011-01-14 15:15:01 -08:00
2011-05-22 18:50:16 +02:00
static void oplock4_got_break ( struct tevent_req * req ) ;
static void oplock4_got_open ( struct tevent_req * req ) ;
2011-01-14 15:15:01 -08:00
static bool run_oplock4 ( int dummy )
{
2011-05-22 18:50:16 +02:00
struct tevent_context * ev ;
2011-01-14 15:15:01 -08:00
struct cli_state * cli1 , * cli2 ;
2011-05-22 18:50:16 +02:00
struct tevent_req * oplock_req , * open_req ;
2011-01-14 15:15:01 -08:00
const char * fname = " \\ lockt4.lck " ;
const char * fname_ln = " \\ lockt4_ln.lck " ;
uint16_t fnum1 , fnum2 ;
int saved_use_oplocks = use_oplocks ;
NTSTATUS status ;
bool correct = true ;
2011-05-22 18:50:16 +02:00
bool got_break ;
struct oplock4_state * state ;
2011-01-14 15:15:01 -08:00
printf ( " starting oplock test 4 \n " ) ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
use_level_II_oplocks = false ;
use_oplocks = saved_use_oplocks ;
return false ;
}
if ( ! torture_open_connection ( & cli2 , 1 ) ) {
use_level_II_oplocks = false ;
use_oplocks = saved_use_oplocks ;
return false ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname_ln , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-14 15:15:01 -08:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2011-01-14 15:15:01 -08:00
/* Create the file. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE ,
2011-01-20 14:21:40 +01:00
& fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
/* Now create a hardlink. */
2011-01-20 14:21:40 +01:00
status = cli_nt_hardlink ( cli1 , fname , fname_ln ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " nt hardlink failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
/* Prove that opening hardlinks cause deny modes to conflict. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_ALL , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname_ln , O_RDWR , DENY_NONE , & fnum2 ) ;
2011-01-14 15:15:01 -08:00
if ( NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s succeeded - should fail with sharing violation. \n " ,
fname_ln ) ;
return false ;
}
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_SHARING_VIOLATION ) ) {
printf ( " open of %s should fail with sharing violation. Got %s \n " ,
fname_ln , nt_errstr ( status ) ) ;
return false ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
cli1 - > use_oplocks = true ;
cli2 - > use_oplocks = true ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
return false ;
}
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2011-05-22 18:50:16 +02:00
if ( ev = = NULL ) {
2012-01-03 15:13:48 +01:00
printf ( " tevent_context_init failed \n " ) ;
2011-05-22 18:50:16 +02:00
return false ;
}
2011-01-14 15:15:01 -08:00
2011-05-22 18:50:16 +02:00
state = talloc ( ev , struct oplock4_state ) ;
if ( state = = NULL ) {
printf ( " talloc failed \n " ) ;
return false ;
}
state - > ev = ev ;
state - > cli = cli1 ;
state - > got_break = & got_break ;
state - > fnum2 = & fnum2 ;
2011-01-14 15:15:01 -08:00
2011-05-22 18:50:16 +02:00
oplock_req = cli_smb_oplock_break_waiter_send (
talloc_tos ( ) , ev , cli1 ) ;
if ( oplock_req = = NULL ) {
printf ( " cli_smb_oplock_break_waiter_send failed \n " ) ;
return false ;
2011-01-14 15:15:01 -08:00
}
2011-05-22 18:50:16 +02:00
tevent_req_set_callback ( oplock_req , oplock4_got_break , state ) ;
2011-01-14 15:15:01 -08:00
2011-12-03 21:13:08 -08:00
open_req = cli_openx_send (
2011-05-22 18:50:16 +02:00
talloc_tos ( ) , ev , cli2 , fname_ln , O_RDWR , DENY_NONE ) ;
2012-01-03 15:20:09 +01:00
if ( open_req = = NULL ) {
2011-12-03 21:13:08 -08:00
printf ( " cli_openx_send failed \n " ) ;
2011-05-22 18:50:16 +02:00
return false ;
}
tevent_req_set_callback ( open_req , oplock4_got_open , state ) ;
got_break = false ;
fnum2 = 0xffff ;
2011-01-14 15:15:01 -08:00
2011-05-22 18:50:16 +02:00
while ( ! got_break | | fnum2 = = 0xffff ) {
int ret ;
ret = tevent_loop_once ( ev ) ;
if ( ret = = - 1 ) {
printf ( " tevent_loop_once failed: %s \n " ,
strerror ( errno ) ) ;
return false ;
}
}
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
correct = false ;
}
2011-01-14 15:15:01 -08:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
correct = false ;
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
correct = false ;
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , fname_ln , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-14 15:15:01 -08:00
correct = false ;
}
if ( ! torture_close_connection ( cli1 ) ) {
correct = false ;
}
2011-05-22 18:50:16 +02:00
if ( ! got_break ) {
2011-01-14 15:15:01 -08:00
correct = false ;
}
printf ( " finished oplock test 4 \n " ) ;
return correct ;
}
2001-06-19 02:02:19 +00:00
2011-05-22 18:50:16 +02:00
static void oplock4_got_break ( struct tevent_req * req )
{
struct oplock4_state * state = tevent_req_callback_data (
req , struct oplock4_state ) ;
uint16_t fnum ;
uint8_t level ;
NTSTATUS status ;
status = cli_smb_oplock_break_waiter_recv ( req , & fnum , & level ) ;
TALLOC_FREE ( req ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_smb_oplock_break_waiter_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return ;
}
* state - > got_break = true ;
req = cli_oplock_ack_send ( state , state - > ev , state - > cli , fnum ,
NO_OPLOCK ) ;
if ( req = = NULL ) {
printf ( " cli_oplock_ack_send failed \n " ) ;
return ;
}
}
static void oplock4_got_open ( struct tevent_req * req )
{
struct oplock4_state * state = tevent_req_callback_data (
req , struct oplock4_state ) ;
NTSTATUS status ;
2011-12-03 21:13:08 -08:00
status = cli_openx_recv ( req , state - > fnum2 ) ;
2011-05-22 18:50:16 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
printf ( " cli_openx_recv returned %s \n " , nt_errstr ( status ) ) ;
2011-05-22 18:50:16 +02:00
* state - > fnum2 = 0xffff ;
}
}
2001-06-19 02:02:19 +00:00
/*
Test delete on close semantics .
*/
2007-10-18 17:40:25 -07:00
static bool run_deletetest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-12-19 01:43:44 +00:00
struct cli_state * cli1 = NULL ;
struct cli_state * cli2 = NULL ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ delete.file " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 = ( uint16_t ) - 1 ;
uint16_t fnum2 = ( uint16_t ) - 1 ;
2012-08-08 12:25:09 +02:00
bool correct = false ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
printf ( " starting delete test \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2001-09-06 01:21:09 +00:00
2003-04-18 03:35:39 +00:00
/* Test 1 - this should delete the file on close. */
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_ALL_ACCESS | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OVERWRITE_IF ,
FILE_DELETE_ON_CLOSE , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [1] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2004-02-20 22:45:53 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [1] close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2012-08-08 11:55:46 +02:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_NONE , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2003-04-18 03:35:39 +00:00
printf ( " [1] open of %s succeeded (should fail) \n " , fname ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
printf ( " first delete on close test succeeded. \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Test 2 - this should delete the file on close. */
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_ALL_ACCESS ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [2] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [2] setting delete_on_close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [2] close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2012-08-08 20:07:38 +02:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [2] open of %s succeeded should have been deleted on close ! \n " , fname ) ;
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [2] close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2012-08-08 12:14:36 +02:00
goto fail ;
2012-08-08 12:15:16 +02:00
}
printf ( " second delete on close test succeeded. \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Test 3 - ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_ALL_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [3] open - 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
/* This should fail with a sharing violation - open for delete is only compatible
with SHARE_DELETE . */
2012-08-08 11:24:29 +02:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [3] open - 2 of %s succeeded - should have failed. \n " , fname ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
/* This should succeed. */
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-08-08 11:24:55 +02:00
printf ( " [3] open - 3 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [3] setting delete_on_close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [3] close 1 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [3] close 2 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This should fail - file should no longer be there. */
2012-08-08 11:27:19 +02:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [3] open of %s succeeded should have been deleted on close ! \n " , fname ) ;
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [3] close failed (%s) \n " , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2012-08-08 11:27:55 +02:00
}
printf ( " third delete on close test succeeded. \n " ) ;
2001-06-19 02:02:19 +00:00
/* Test 4 ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [4] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
/* This should succeed. */
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [4] open - 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [4] close - 1 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [4] setting delete_on_close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This should fail - no more opens once delete on close set. */
2012-08-08 11:32:37 +02:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [4] open - 3 of %s succeeded ! Should have failed. \n " , fname ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2012-08-08 11:32:55 +02:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [4] close - 2 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2012-08-08 11:32:55 +02:00
printf ( " fourth delete on close test succeeded. \n " ) ;
2001-06-19 02:02:19 +00:00
/* Test 5 ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [5] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
/* This should fail - only allowed on NT opens with DELETE access. */
2012-08-08 11:56:17 +02:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " [5] setting delete_on_close on OpenX file succeeded - should fail ! \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-08-08 11:56:48 +02:00
printf ( " [5] close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
printf ( " fifth delete on close test succeeded. \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Test 6 ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_DATA | FILE_WRITE_DATA ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [6] open of %s failed (%s) \n " , fname ,
nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This should fail - only allowed on NT opens with DELETE access. */
2009-04-22 11:51:03 +02:00
2012-08-08 11:57:03 +02:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " [6] setting delete_on_close on file with no delete access succeeded - should fail ! \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-08-08 11:57:33 +02:00
printf ( " [6] close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
printf ( " sixth delete on close test succeeded. \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Test 7 ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OVERWRITE_IF ,
0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [7] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2012-08-08 11:58:01 +02:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " [7] setting delete_on_close on file failed ! \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2012-08-08 11:58:24 +02:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , false ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " [7] unsetting delete_on_close on file failed ! \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-08-08 12:05:38 +02:00
printf ( " [7] close - 1 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This next open should succeed - we reset the flag. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-08-08 12:05:53 +02:00
printf ( " [7] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [7] close - 2 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
printf ( " seventh delete on close test succeeded. \n " ) ;
2009-04-22 11:51:03 +02:00
2012-08-08 12:06:13 +02:00
/* Test 8 ... */
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli2 , 1 ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [8] failed to open second connection. \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [8] open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [8] open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-06-19 02:02:19 +00:00
}
2012-08-08 12:07:29 +02:00
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2001-07-02 03:21:17 +00:00
printf ( " [8] setting delete_on_close on file failed ! \n " ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [8] close - 1 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [8] close - 2 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2001-07-02 03:21:17 +00:00
}
2001-06-19 02:02:19 +00:00
/* This should fail.. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( NT_STATUS_IS_OK ( status ) ) {
2001-06-19 02:02:19 +00:00
printf ( " [8] open of %s succeeded should have been deleted on close ! \n " , fname ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
2012-08-08 12:17:29 +02:00
}
printf ( " eighth delete on close test succeeded. \n " ) ;
2001-06-19 02:02:19 +00:00
2012-08-08 12:17:53 +02:00
/* Test 9 ... */
2002-03-07 04:15:40 +00:00
/* This should fail - we need to set DELETE_ACCESS. */
2012-08-08 12:18:16 +02:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_DATA | FILE_WRITE_DATA ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_NONE ,
FILE_OVERWRITE_IF ,
FILE_DELETE_ON_CLOSE , 0 , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2002-03-07 04:15:40 +00:00
printf ( " [9] open of %s succeeded should have failed! \n " , fname ) ;
goto fail ;
}
printf ( " ninth delete on close test succeeded. \n " ) ;
2012-08-08 12:18:40 +02:00
/* Test 10 ... */
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , FILE_DELETE_ON_CLOSE ,
0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [10] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
}
/* This should delete the file. */
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [10] close failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-07 04:15:40 +00:00
goto fail ;
}
/* This should fail.. */
2012-08-08 12:18:55 +02:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_NONE , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2002-03-07 04:15:40 +00:00
printf ( " [10] open of %s succeeded should have been deleted on close ! \n " , fname ) ;
goto fail ;
2012-08-08 12:19:31 +02:00
}
printf ( " tenth delete on close test succeeded. \n " ) ;
2005-02-23 23:41:15 +00:00
2012-08-08 12:19:52 +02:00
/* Test 11 ... */
2005-02-23 23:41:15 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2005-02-23 23:41:15 +00:00
2012-08-09 16:11:08 +02:00
/* Can we open a read-only file with delete access? */
2005-02-23 23:41:15 +00:00
/* Create a readonly file. */
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_DATA | FILE_WRITE_DATA ,
FILE_ATTRIBUTE_READONLY , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [11] open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2005-02-23 23:41:15 +00:00
goto fail ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [11] close failed (%s) \n " , nt_errstr ( status ) ) ;
2005-02-23 23:41:15 +00:00
goto fail ;
}
/* Now try open for delete access. */
2011-11-16 16:21:13 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_ATTRIBUTES | DELETE_ACCESS ,
0 ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
2012-08-09 16:11:08 +02:00
FILE_OPEN , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [11] open of %s failed: %s \n " , fname , nt_errstr ( status ) ) ;
2012-08-08 12:20:24 +02:00
goto fail ;
2005-02-23 23:41:15 +00:00
}
2009-04-22 11:51:03 +02:00
2012-08-09 16:11:08 +02:00
cli_close ( cli1 , fnum1 ) ;
2012-08-08 12:20:24 +02:00
printf ( " eleventh delete on close test succeeded. \n " ) ;
2012-08-08 12:44:01 +02:00
/*
* Test 12
* like test 4 but with initial delete on close
*/
cli_setatr ( cli1 , fname , 0 , 0 ) ;
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OVERWRITE_IF ,
FILE_DELETE_ON_CLOSE , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] open 2 of %s failed(%s). \n " , fname , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_close ( cli1 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] close 1 failed (%s) \n " , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_nt_delete_on_close ( cli1 , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] setting delete_on_close failed (%s) \n " , nt_errstr ( status ) ) ;
goto fail ;
}
/* This should fail - no more opens once delete on close set. */
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] open 3 of %s succeeded - should fail). \n " , fname ) ;
goto fail ;
}
status = cli_nt_delete_on_close ( cli1 , fnum1 , false ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] unsetting delete_on_close failed (%s) \n " , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] open 4 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_close ( cli1 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] close 2 failed (%s) \n " , nt_errstr ( status ) ) ;
goto fail ;
}
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] close 3 failed (%s) \n " , nt_errstr ( status ) ) ;
goto fail ;
}
/*
* setting delete on close on the handle does
* not unset the initial delete on close . . .
*/
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
printf ( " [12] open 5 of %s succeeded - should fail). \n " , fname ) ;
goto fail ;
} else if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_OBJECT_NAME_NOT_FOUND ) ) {
printf ( " ntcreate returned %s, expected "
" NT_STATUS_OBJECT_NAME_NOT_FOUND \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
printf ( " twelfth delete on close test succeeded. \n " ) ;
2001-07-02 03:21:17 +00:00
printf ( " finished delete test \n " ) ;
2002-03-07 04:15:40 +00:00
2012-08-08 12:25:09 +02:00
correct = true ;
2002-03-07 04:15:40 +00:00
fail :
2003-04-18 03:35:39 +00:00
/* FIXME: This will crash if we aborted before cli2 got
* intialized , because these functions don ' t handle
* uninitialized connections . */
2009-04-22 11:51:03 +02:00
2009-05-03 22:45:42 +02:00
if ( fnum1 ! = ( uint16_t ) - 1 ) cli_close ( cli1 , fnum1 ) ;
if ( fnum2 ! = ( uint16_t ) - 1 ) cli_close ( cli1 , fnum2 ) ;
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
2003-12-19 01:43:44 +00:00
if ( cli1 & & ! torture_close_connection ( cli1 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2003-12-19 01:43:44 +00:00
if ( cli2 & & ! torture_close_connection ( cli2 ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
return correct ;
2001-06-19 02:02:19 +00:00
}
2011-01-18 16:57:25 -08:00
static bool run_deletetest_ln ( int dummy )
{
struct cli_state * cli ;
const char * fname = " \\ delete1 " ;
const char * fname_ln = " \\ delete1_ln " ;
uint16_t fnum ;
uint16_t fnum1 ;
NTSTATUS status ;
bool correct = true ;
time_t t ;
printf ( " starting deletetest-ln \n " ) ;
if ( ! torture_open_connection ( & cli , 0 ) ) {
return false ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli , fname_ln , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-18 16:57:25 -08:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2011-01-18 16:57:25 -08:00
/* Create the file. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-01-18 16:57:25 -08:00
return false ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli , fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-18 16:57:25 -08:00
return false ;
}
/* Now create a hardlink. */
2011-01-20 14:21:40 +01:00
status = cli_nt_hardlink ( cli , fname , fname_ln ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " nt hardlink failed (%s) \n " , nt_errstr ( status ) ) ;
2011-01-18 16:57:25 -08:00
return false ;
}
/* Open the original file. */
status = cli_ntcreate ( cli , fname , 0 , FILE_READ_DATA ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN_IF , 0 , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ntcreate of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
return false ;
}
/* Unlink the hard link path. */
status = cli_ntcreate ( cli , fname_ln , 0 , DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ntcreate of %s failed (%s) \n " , fname_ln , nt_errstr ( status ) ) ;
return false ;
}
status = cli_nt_delete_on_close ( cli , fnum1 , true ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " (%s) failed to set delete_on_close %s: %s \n " ,
__location__ , fname_ln , nt_errstr ( status ) ) ;
return false ;
}
status = cli_close ( cli , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close %s failed (%s) \n " ,
fname_ln , nt_errstr ( status ) ) ;
return false ;
}
status = cli_close ( cli , fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close %s failed (%s) \n " ,
fname , nt_errstr ( status ) ) ;
return false ;
}
/* Ensure the original file is still there. */
status = cli_getatr ( cli , fname , NULL , NULL , & t ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " %s getatr on file %s failed (%s) \n " ,
__location__ ,
fname ,
nt_errstr ( status ) ) ;
correct = False ;
}
/* Ensure the link path is gone. */
status = cli_getatr ( cli , fname_ln , NULL , NULL , & t ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_OBJECT_NAME_NOT_FOUND ) ) {
printf ( " %s, getatr for file %s returned wrong error code %s "
" - should have been deleted \n " ,
__location__ ,
fname_ln , nt_errstr ( status ) ) ;
correct = False ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli , fname_ln , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-18 16:57:25 -08:00
if ( ! torture_close_connection ( cli ) ) {
correct = false ;
}
printf ( " finished deletetest-ln \n " ) ;
return correct ;
}
2002-03-19 23:19:00 +00:00
/*
print out server properties
*/
2007-10-18 17:40:25 -07:00
static bool run_properties ( int dummy )
2002-03-19 23:19:00 +00:00
{
2009-04-22 11:54:13 +02:00
struct cli_state * cli ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2009-04-22 11:51:03 +02:00
2002-03-19 23:19:00 +00:00
printf ( " starting properties test \n " ) ;
2009-04-22 11:51:03 +02:00
2002-03-19 23:19:00 +00:00
ZERO_STRUCT ( cli ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2002-03-19 23:19:00 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2002-03-19 23:19:00 +00:00
2012-05-19 18:23:40 +02:00
d_printf ( " Capabilities 0x%08x \n " , smb1cli_conn_capabilities ( cli - > conn ) ) ;
2002-03-19 23:19:00 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2002-03-19 23:19:00 +00:00
correct = False ;
}
return correct ;
}
2002-03-07 02:16:25 +00:00
/* FIRST_DESIRED_ACCESS 0xf019f */
# define FIRST_DESIRED_ACCESS FILE_READ_DATA|FILE_WRITE_DATA|FILE_APPEND_DATA|\
FILE_READ_EA | /* 0xf */ \
FILE_WRITE_EA | FILE_READ_ATTRIBUTES | /* 0x90 */ \
FILE_WRITE_ATTRIBUTES | /* 0x100 */ \
DELETE_ACCESS | READ_CONTROL_ACCESS | \
WRITE_DAC_ACCESS | WRITE_OWNER_ACCESS /* 0xf0000 */
/* SECOND_DESIRED_ACCESS 0xe0080 */
# define SECOND_DESIRED_ACCESS FILE_READ_ATTRIBUTES| /* 0x80 */ \
READ_CONTROL_ACCESS | WRITE_DAC_ACCESS | \
WRITE_OWNER_ACCESS /* 0xe0000 */
#if 0
# define THIRD_DESIRED_ACCESS FILE_READ_ATTRIBUTES| /* 0x80 */ \
READ_CONTROL_ACCESS | WRITE_DAC_ACCESS | \
FILE_READ_DATA | \
WRITE_OWNER_ACCESS /* */
# endif
2002-02-24 08:38:11 +00:00
/*
Test ntcreate calls made by xcopy
*/
2007-10-18 17:40:25 -07:00
static bool run_xcopy ( int dummy )
2002-02-24 08:38:11 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ test.txt " ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2002-02-24 08:38:11 +00:00
printf ( " starting xcopy test \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2002-02-24 08:38:11 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FIRST_DESIRED_ACCESS ,
FILE_ATTRIBUTE_ARCHIVE , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0x4044 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " First open failed - %s \n " , nt_errstr ( status ) ) ;
2002-02-24 08:38:11 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , SECOND_DESIRED_ACCESS , 0 ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN , 0x200000 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " second open failed - %s \n " , nt_errstr ( status ) ) ;
2002-02-24 08:38:11 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2002-02-24 08:38:11 +00:00
correct = False ;
}
2009-04-22 11:51:03 +02:00
2002-02-24 08:38:11 +00:00
return correct ;
}
2002-03-05 19:45:16 +00:00
/*
Test rename on files open with share delete and no share delete .
*/
2007-10-18 17:40:25 -07:00
static bool run_rename ( int dummy )
2002-03-05 19:45:16 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ test.txt " ;
const char * fname1 = " \\ test1.txt " ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2010-04-01 15:01:43 -07:00
uint16_t attr ;
2009-05-02 19:11:52 +02:00
NTSTATUS status ;
2002-03-05 19:45:16 +00:00
printf ( " starting rename test \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2002-03-05 19:45:16 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_READ ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " First open failed - %s \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_rename ( cli1 , fname , fname1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " First rename failed (SHARE_READ) (this is correct) - %s \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
} else {
2004-02-26 01:33:35 +00:00
printf ( " First rename succeeded (SHARE_READ) - this should have failed ! \n " ) ;
2002-03-05 19:45:16 +00:00
correct = False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close - 1 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
return False ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-05-02 19:11:52 +02:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS , FILE_ATTRIBUTE_NORMAL ,
2002-03-23 02:57:44 +00:00
#if 0
2009-05-02 19:11:52 +02:00
FILE_SHARE_DELETE | FILE_SHARE_NONE ,
2002-03-23 02:57:44 +00:00
# else
2009-05-02 19:11:52 +02:00
FILE_SHARE_DELETE | FILE_SHARE_READ ,
2002-03-23 02:57:44 +00:00
# endif
2009-05-02 19:11:52 +02:00
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-01-20 14:21:40 +01:00
printf ( " Second open failed - %s \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_rename ( cli1 , fname , fname1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Second rename failed (SHARE_DELETE | SHARE_READ) - this should have succeeded - %s \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
correct = False ;
} else {
2004-02-26 01:33:35 +00:00
printf ( " Second rename succeeded (SHARE_DELETE | SHARE_READ) \n " ) ;
2002-03-05 19:45:16 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close - 2 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-23 02:57:44 +00:00
return False ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-23 02:57:44 +00:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , READ_CONTROL_ACCESS ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Third open failed - %s \n " , nt_errstr ( status ) ) ;
2002-03-23 02:57:44 +00:00
return False ;
}
2002-03-23 02:59:20 +00:00
#if 0
2002-03-23 02:57:44 +00:00
{
2009-04-30 15:26:43 -07:00
uint16_t fnum2 ;
2002-03-23 02:57:44 +00:00
2009-04-30 15:26:43 -07:00
if ( ! NT_STATUS_IS_OK ( cli_ntcreate ( cli1 , fname , 0 , DELETE_ACCESS , FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_NONE , FILE_OVERWRITE_IF , 0 , 0 , & fnum2 ) ) ) {
2003-04-18 03:35:39 +00:00
printf ( " Fourth open failed - %s \n " , cli_errstr ( cli1 ) ) ;
2002-03-23 02:57:44 +00:00
return False ;
}
2009-05-29 14:58:34 -07:00
if ( ! NT_STATUS_IS_OK ( cli_nt_delete_on_close ( cli1 , fnum2 , true ) ) ) {
2002-03-23 02:57:44 +00:00
printf ( " [8] setting delete_on_close on file failed ! \n " ) ;
return False ;
}
2009-04-22 11:51:03 +02:00
2009-04-30 16:57:42 -07:00
if ( ! NT_STATUS_IS_OK ( cli_close ( cli1 , fnum2 ) ) ) {
2003-04-18 03:35:39 +00:00
printf ( " close - 4 failed (%s) \n " , cli_errstr ( cli1 ) ) ;
2002-03-23 02:57:44 +00:00
return False ;
}
}
# endif
2011-01-20 14:21:40 +01:00
status = cli_rename ( cli1 , fname , fname1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Third rename failed (SHARE_NONE) - this should have succeeded - %s \n " , nt_errstr ( status ) ) ;
2002-03-23 02:57:44 +00:00
correct = False ;
} else {
2004-02-26 01:33:35 +00:00
printf ( " Third rename succeeded (SHARE_NONE) \n " ) ;
2002-03-23 02:57:44 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close - 3 failed (%s) \n " , nt_errstr ( status ) ) ;
2002-03-05 19:45:16 +00:00
return False ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-05 19:45:16 +00:00
2004-02-26 01:33:35 +00:00
/*----*/
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Fourth open failed - %s \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_rename ( cli1 , fname , fname1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Fourth rename failed (SHARE_READ | SHARE_WRITE) (this is correct) - %s \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
} else {
printf ( " Fourth rename succeeded (SHARE_READ | SHARE_WRITE) - this should have failed ! \n " ) ;
correct = False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close - 4 failed (%s) \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
return False ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2004-02-26 01:33:35 +00:00
/*--*/
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_READ_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Fifth open failed - %s \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_rename ( cli1 , fname , fname1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Fifth rename failed (SHARE_READ | SHARE_WRITE | SHARE_DELETE) - this should have succeeded - %s ! \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
correct = False ;
} else {
2011-01-20 14:21:40 +01:00
printf ( " Fifth rename succeeded (SHARE_READ | SHARE_WRITE | SHARE_DELETE) (this is correct) - %s \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
}
/*
* Now check if the first name still exists . . .
*/
2009-04-30 15:26:43 -07:00
/* if (!NT_STATUS_OP(cli_ntcreate(cli1, fname, 0, GENERIC_READ_ACCESS, FILE_ATTRIBUTE_NORMAL,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , FILE_OVERWRITE_IF , 0 , 0 , & fnum2 ) ) ) {
2004-02-26 01:33:35 +00:00
printf ( " Opening original file after rename of open file fails: %s \n " ,
cli_errstr ( cli1 ) ) ;
}
else {
printf ( " Opening original file after rename of open file works ... \n " ) ;
( void ) cli_close ( cli1 , fnum2 ) ;
} */
/*--*/
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close - 5 failed (%s) \n " , nt_errstr ( status ) ) ;
2004-02-26 01:33:35 +00:00
return False ;
}
2010-04-01 15:01:43 -07:00
/* Check that the renamed file has FILE_ATTRIBUTE_ARCHIVE. */
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli1 , fname1 , & attr , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2010-04-01 15:01:43 -07:00
printf ( " getatr on file %s failed - %s ! \n " ,
2011-01-20 14:21:40 +01:00
fname1 , nt_errstr ( status ) ) ;
2010-04-01 15:01:43 -07:00
correct = False ;
} else {
if ( attr ! = FILE_ATTRIBUTE_ARCHIVE ) {
printf ( " Renamed file %s has wrong attr 0x%x "
" (should be 0x%x) \n " ,
fname1 ,
attr ,
( unsigned int ) FILE_ATTRIBUTE_ARCHIVE ) ;
correct = False ;
} else {
printf ( " Renamed file %s has archive bit set \n " , fname1 ) ;
}
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
cli_unlink ( cli1 , fname1 , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2002-03-05 19:45:16 +00:00
correct = False ;
}
2009-04-22 11:51:03 +02:00
2002-03-05 19:45:16 +00:00
return correct ;
}
2007-10-18 17:40:25 -07:00
static bool run_pipe_number ( int dummy )
2002-07-15 10:35:28 +00:00
{
2003-04-18 03:35:39 +00:00
struct cli_state * cli1 ;
2003-01-03 08:28:12 +00:00
const char * pipe_name = " \\ SPOOLSS " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2002-07-15 10:35:28 +00:00
int num_pipes = 0 ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2002-07-15 10:35:28 +00:00
printf ( " starting pipenumber test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2002-07-15 10:35:28 +00:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2002-07-15 10:35:28 +00:00
while ( 1 ) {
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , pipe_name , 0 , FILE_READ_DATA ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE ,
FILE_OPEN_IF , 0 , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Open of pipe %s failed with error (%s) \n " , pipe_name , nt_errstr ( status ) ) ;
2002-07-15 10:35:28 +00:00
break ;
}
num_pipes + + ;
2006-09-05 10:37:18 +00:00
printf ( " \r %6d " , num_pipes ) ;
2002-07-15 10:35:28 +00:00
}
printf ( " pipe_number test - we can open %d %s pipes. \n " , num_pipes , pipe_name ) ;
2003-04-18 03:35:39 +00:00
torture_close_connection ( cli1 ) ;
2002-07-15 10:35:28 +00:00
return True ;
}
2002-02-24 08:38:11 +00:00
2001-06-19 02:02:19 +00:00
/*
Test open mode returns on read - only files .
*/
2007-10-18 17:40:25 -07:00
static bool run_opentest ( int dummy )
2001-06-19 02:02:19 +00:00
{
2003-04-18 03:35:39 +00:00
static struct cli_state * cli1 ;
static struct cli_state * cli2 ;
2003-01-03 08:28:12 +00:00
const char * fname = " \\ readonly.file " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 , fnum2 ;
2001-06-19 02:02:19 +00:00
char buf [ 20 ] ;
2012-04-05 14:53:08 +10:00
off_t fsize ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2001-09-17 04:23:48 +00:00
char * tmp_path ;
2011-02-22 16:40:23 -08:00
NTSTATUS status ;
2001-06-19 02:02:19 +00:00
2001-07-02 03:21:17 +00:00
printf ( " starting open test \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-04-22 11:51:03 +02:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_setatr ( cli1 , fname , FILE_ATTRIBUTE_READONLY , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_setatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_WRITE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This will fail - but the error should be ERRnoaccess, not ERRbadshare. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_ALL , & fnum2 ) ;
2009-04-22 11:51:03 +02:00
2011-07-27 21:51:45 +02:00
if ( check_error ( __LINE__ , status , ERRDOS , ERRnoaccess ,
2001-08-20 05:15:26 +00:00
NT_STATUS_ACCESS_DENIED ) ) {
2001-06-19 02:02:19 +00:00
printf ( " correct error code ERRDOS/ERRnoaccess returned \n " ) ;
}
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
printf ( " finished open test 1 \n " ) ;
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_close ( cli1 , fnum1 ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Now try not readonly and ensure ERRbadshare is returned. */
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2009-04-22 11:51:03 +02:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY , DENY_WRITE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* This will fail - but the error should be ERRshare. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR , DENY_ALL , & fnum2 ) ;
2009-04-22 11:51:03 +02:00
2011-07-27 21:51:45 +02:00
if ( check_error ( __LINE__ , status , ERRDOS , ERRbadshare ,
2001-08-20 05:15:26 +00:00
NT_STATUS_SHARING_VIOLATION ) ) {
2001-06-19 02:02:19 +00:00
printf ( " correct error code ERRDOS/ERRbadshare returned \n " ) ;
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2001-07-02 03:21:17 +00:00
printf ( " finished open test 2 \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Test truncate open disposition on file opened for read. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " (3) open (1) of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* write 20 bytes. */
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
memset ( buf , ' \0 ' , 20 ) ;
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( uint8_t * ) buf , 0 , 20 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " write failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
correct = False ;
2001-06-19 02:02:19 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " (3) close1 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
/* Ensure size == 20. */
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli1 , fname , NULL , & fsize , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " (3) getatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
if ( fsize ! = 20 ) {
printf ( " (3) file size != 20 \n " ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
/* Now test if we can truncate a file opened for readonly. */
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDONLY | O_TRUNC , DENY_NONE , & fnum1 ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " (3) open (2) of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close2 failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
}
2001-06-19 02:02:19 +00:00
/* Ensure size == 0. */
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli1 , fname , NULL , & fsize , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " (3) getatr failed (%s) \n " , nt_errstr ( status ) ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
if ( fsize ! = 0 ) {
printf ( " (3) file size != 0 \n " ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
printf ( " finished open test 3 \n " ) ;
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
2010-09-08 17:54:29 +02:00
printf ( " Do ctemp tests \n " ) ;
2011-01-20 14:21:40 +01:00
status = cli_ctemp ( cli1 , talloc_tos ( ) , " \\ " , & fnum1 , & tmp_path ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ctemp failed (%s) \n " , nt_errstr ( status ) ) ;
2001-09-17 04:23:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
2001-09-17 04:23:48 +00:00
printf ( " ctemp gave path %s \n " , tmp_path ) ;
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close of temp failed (%s) \n " , nt_errstr ( status ) ) ;
2001-09-17 04:23:48 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli1 , tmp_path , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink of temp failed (%s) \n " , nt_errstr ( status ) ) ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2002-03-26 00:07:48 +00:00
/* Test the non-io opens... */
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli2 , 1 ) ) {
2002-03-26 00:07:48 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
cli_setatr ( cli2 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli2 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-04-22 11:51:03 +02:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli2 - > conn , sockops ) ;
2002-03-26 00:07:48 +00:00
printf ( " TEST #1 testing 2 non-io opens (no delete) \n " ) ;
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #1 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 , FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #1 open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #1 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #1 close 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
printf ( " non-io open test #1 passed. \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:07:48 +00:00
printf ( " TEST #2 testing 2 non-io opens (first with delete) \n " ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #2 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 , FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #2 open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #2 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #2 close 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
printf ( " non-io open test #2 passed. \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:07:48 +00:00
printf ( " TEST #3 testing 2 non-io opens (second with delete) \n " ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #3 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #3 open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #3 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #3 close 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
printf ( " non-io open test #3 passed. \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:07:48 +00:00
printf ( " TEST #4 testing 2 non-io opens (both with delete) \n " ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #4 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #4 open 2 of %s SUCCEEDED - should have failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
printf ( " TEST #4 open 2 of %s gave %s (correct error should be %s) \n " , fname , nt_errstr ( status ) , " sharing violation " ) ;
2002-03-26 00:07:48 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #4 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
printf ( " non-io open test #4 passed. \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:07:48 +00:00
printf ( " TEST #5 testing 2 non-io opens (both with delete - both with file share delete) \n " ) ;
2009-04-22 11:51:03 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_DELETE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #5 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_DELETE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #5 open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #5 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #5 close 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:07:48 +00:00
return False ;
}
printf ( " non-io open test #5 passed. \n " ) ;
2002-03-26 00:40:18 +00:00
printf ( " TEST #6 testing 1 non-io open, one io open \n " ) ;
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:40:18 +00:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_DATA ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #6 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 , FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_READ ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #6 open 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #6 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #6 close 2 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
printf ( " non-io open test #6 passed. \n " ) ;
printf ( " TEST #7 testing 1 non-io open, one io open with delete \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-03-26 00:40:18 +00:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_READ_DATA ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #7 open 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli2 , fname , 0 ,
DELETE_ACCESS | FILE_READ_ATTRIBUTES ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_DELETE ,
FILE_OPEN_IF , 0 , 0 , & fnum2 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #7 open 2 of %s SUCCEEDED - should have failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
printf ( " TEST #7 open 2 of %s gave %s (correct error should be %s) \n " , fname , nt_errstr ( status ) , " sharing violation " ) ;
2002-03-26 00:40:18 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #7 close 1 of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2002-03-26 00:40:18 +00:00
return False ;
}
printf ( " non-io open test #7 passed. \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-09-25 15:19:00 +00:00
2011-02-22 16:40:23 -08:00
printf ( " TEST #8 testing open without WRITE_ATTRIBUTES, updating close write time. \n " ) ;
status = cli_ntcreate ( cli1 , fname , 0 , FILE_WRITE_DATA , FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #8 open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
correct = false ;
goto out ;
}
/* Write to ensure we have to update the file time. */
2011-05-05 16:44:27 -07:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( const uint8_t * ) " TEST DATA \n " , 0 , 10 ,
2011-04-02 11:46:30 +02:00
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #8 cli_write failed: %s \n " , nt_errstr ( status ) ) ;
2011-02-22 16:40:23 -08:00
correct = false ;
goto out ;
}
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " TEST #8 close of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
correct = false ;
}
out :
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
correct = False ;
2002-09-25 15:19:00 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli2 ) ) {
correct = False ;
2002-09-25 15:19:00 +00:00
}
2009-04-22 11:51:03 +02:00
2003-04-18 03:35:39 +00:00
return correct ;
}
2002-09-25 15:19:00 +00:00
2009-11-29 16:04:21 +01:00
NTSTATUS torture_setup_unix_extensions ( struct cli_state * cli )
{
uint16 major , minor ;
uint32 caplow , caphigh ;
NTSTATUS status ;
if ( ! SERVER_HAS_UNIX_CIFS ( cli ) ) {
printf ( " Server doesn't support UNIX CIFS extensions. \n " ) ;
return NT_STATUS_NOT_SUPPORTED ;
}
status = cli_unix_extensions_version ( cli , & major , & minor , & caplow ,
& caphigh ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Server didn't return UNIX CIFS extensions: %s \n " ,
nt_errstr ( status ) ) ;
return status ;
}
status = cli_set_unix_extensions_capabilities ( cli , major , minor ,
caplow , caphigh ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Server doesn't support setting UNIX CIFS extensions: "
" %s. \n " , nt_errstr ( status ) ) ;
return status ;
}
return NT_STATUS_OK ;
}
2009-03-11 14:28:47 -07:00
/*
Test POSIX open / mkdir calls .
*/
static bool run_simple_posix_open_test ( int dummy )
{
static struct cli_state * cli1 ;
2009-05-27 17:28:23 -07:00
const char * fname = " posix:file " ;
const char * hname = " posix:hlink " ;
const char * sname = " posix:symlink " ;
const char * dname = " posix:dir " ;
char buf [ 10 ] ;
2009-05-27 21:51:15 -07:00
char namebuf [ 11 ] ;
2009-05-20 18:31:36 -07:00
uint16_t fnum1 = ( uint16_t ) - 1 ;
2009-06-05 16:06:05 -07:00
SMB_STRUCT_STAT sbuf ;
2009-03-11 14:28:47 -07:00
bool correct = false ;
2009-11-12 23:07:21 +01:00
NTSTATUS status ;
2011-07-19 16:15:52 +02:00
size_t nread ;
2013-01-24 16:20:14 -08:00
const char * fname_windows = " windows_file " ;
uint16_t fnum2 = ( uint16_t ) - 1 ;
2009-03-11 14:28:47 -07:00
printf ( " Starting simple POSIX open test \n " ) ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
return false ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-03-11 14:28:47 -07:00
2009-11-29 16:04:21 +01:00
status = torture_setup_unix_extensions ( cli1 ) ;
2009-11-12 23:07:21 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-03-11 14:28:47 -07:00
return false ;
}
cli_setatr ( cli1 , fname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , fname ) ;
cli_setatr ( cli1 , dname , 0 , 0 ) ;
cli_posix_rmdir ( cli1 , dname ) ;
2009-05-27 17:28:23 -07:00
cli_setatr ( cli1 , hname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , hname ) ;
cli_setatr ( cli1 , sname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , sname ) ;
2013-01-24 16:20:14 -08:00
cli_setatr ( cli1 , fname_windows , 0 , 0 ) ;
cli_posix_unlink ( cli1 , fname_windows ) ;
2009-03-11 14:28:47 -07:00
/* Create a directory. */
2011-01-20 14:21:40 +01:00
status = cli_posix_mkdir ( cli1 , dname , 0777 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX mkdir of %s failed (%s) \n " , dname , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL ,
0600 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX create of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
2009-06-05 16:06:05 -07:00
/* Test ftruncate - set file size. */
2011-01-20 14:21:40 +01:00
status = cli_ftruncate ( cli1 , fnum1 , 1000 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ftruncate failed (%s) \n " , nt_errstr ( status ) ) ;
2009-06-05 16:06:05 -07:00
goto out ;
}
/* Ensure st_size == 1000 */
2011-01-20 14:21:40 +01:00
status = cli_posix_stat ( cli1 , fname , & sbuf ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " stat failed (%s) \n " , nt_errstr ( status ) ) ;
2009-06-05 16:06:05 -07:00
goto out ;
}
if ( sbuf . st_ex_size ! = 1000 ) {
printf ( " ftruncate - stat size (%u) != 1000 \n " , ( unsigned int ) sbuf . st_ex_size ) ;
goto out ;
}
2012-06-04 20:45:34 -07:00
/* Ensure st_mode == 0600 */
if ( ( sbuf . st_ex_mode & 07777 ) ! = 0600 ) {
printf ( " posix_open - bad permissions 0%o != 0600 \n " ,
( unsigned int ) ( sbuf . st_ex_mode & 07777 ) ) ;
goto out ;
}
2009-06-05 16:06:05 -07:00
/* Test ftruncate - set file size back to zero. */
2011-01-20 14:21:40 +01:00
status = cli_ftruncate ( cli1 , fnum1 , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ftruncate failed (%s) \n " , nt_errstr ( status ) ) ;
2009-06-05 16:06:05 -07:00
goto out ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
/* Now open the file again for read only. */
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , fname , O_RDONLY , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
/* Now unlink while open. */
2011-01-20 14:21:40 +01:00
status = cli_posix_unlink ( cli1 , fname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX unlink of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close(2) failed (%s) \n " , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
/* Ensure the file has gone. */
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , fname , O_RDONLY , 0 , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2009-03-11 14:28:47 -07:00
printf ( " POSIX open of %s succeeded, should have been deleted. \n " , fname ) ;
goto out ;
}
2011-04-29 14:27:45 -07:00
/* Create again to test open with O_TRUNC. */
2011-07-07 16:49:12 +02:00
status = cli_posix_open ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , 0600 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX create of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
/* Test ftruncate - set file size. */
2011-07-07 16:49:12 +02:00
status = cli_ftruncate ( cli1 , fnum1 , 1000 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ftruncate failed (%s) \n " , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
/* Ensure st_size == 1000 */
2011-07-07 16:49:12 +02:00
status = cli_posix_stat ( cli1 , fname , & sbuf ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " stat failed (%s) \n " , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
if ( sbuf . st_ex_size ! = 1000 ) {
printf ( " ftruncate - stat size (%u) != 1000 \n " , ( unsigned int ) sbuf . st_ex_size ) ;
goto out ;
}
2011-07-07 16:49:12 +02:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close(2) failed (%s) \n " , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
/* Re-open with O_TRUNC. */
2011-07-07 16:49:12 +02:00
status = cli_posix_open ( cli1 , fname , O_WRONLY | O_TRUNC , 0600 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX create of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
/* Ensure st_size == 0 */
2011-07-07 16:49:12 +02:00
status = cli_posix_stat ( cli1 , fname , & sbuf ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " stat failed (%s) \n " , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
if ( sbuf . st_ex_size ! = 0 ) {
printf ( " O_TRUNC - stat size (%u) != 0 \n " , ( unsigned int ) sbuf . st_ex_size ) ;
goto out ;
}
2011-07-07 16:49:12 +02:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close failed (%s) \n " , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
2011-07-07 16:49:12 +02:00
status = cli_posix_unlink ( cli1 , fname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX unlink of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2011-04-29 14:27:45 -07:00
goto out ;
}
2011-07-07 16:49:12 +02:00
status = cli_posix_open ( cli1 , dname , O_RDONLY , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-04-29 16:18:14 -07:00
printf ( " POSIX open directory O_RDONLY of %s failed (%s) \n " ,
2011-07-07 16:49:12 +02:00
dname , nt_errstr ( status ) ) ;
2011-04-29 16:18:14 -07:00
goto out ;
}
cli_close ( cli1 , fnum1 ) ;
/* What happens when we try and POSIX open a directory for write ? */
2011-07-07 16:49:12 +02:00
status = cli_posix_open ( cli1 , dname , O_RDWR , 0 , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2009-05-22 15:21:55 -07:00
printf ( " POSIX open of directory %s succeeded, should have failed. \n " , fname ) ;
goto out ;
} else {
2011-07-07 16:49:12 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , EISDIR ,
2009-05-22 15:21:55 -07:00
NT_STATUS_FILE_IS_A_DIRECTORY ) ) {
goto out ;
}
}
2009-05-27 17:28:23 -07:00
/* Create the file. */
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL ,
0600 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX create of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
/* Write some data into it. */
2011-05-05 16:44:27 -07:00
status = cli_writeall ( cli1 , fnum1 , 0 , ( const uint8_t * ) " TEST DATA \n " , 0 , 10 ,
2011-04-02 11:46:30 +02:00
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_write failed: %s \n " , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
cli_close ( cli1 , fnum1 ) ;
/* Now create a hardlink. */
2011-01-20 14:21:40 +01:00
status = cli_posix_hardlink ( cli1 , fname , hname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX hardlink of %s failed (%s) \n " , hname , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
/* Now create a symlink. */
2011-01-20 14:21:40 +01:00
status = cli_posix_symlink ( cli1 , fname , sname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX symlink of %s failed (%s) \n " , sname , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
/* Open the hardlink for read. */
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , hname , O_RDONLY , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX open of %s failed (%s) \n " , hname , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
2011-07-19 16:15:52 +02:00
status = cli_read ( cli1 , fnum1 , buf , 0 , 10 , & nread ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX read of %s failed (%s) \n " , hname ,
nt_errstr ( status ) ) ;
goto out ;
} else if ( nread ! = 10 ) {
printf ( " POSIX read of %s failed. Received %ld, expected %d \n " ,
hname , ( unsigned long ) nread , 10 ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
if ( memcmp ( buf , " TEST DATA \n " , 10 ) ) {
printf ( " invalid data read from hardlink \n " ) ;
goto out ;
}
2009-07-13 18:43:10 -07:00
/* Do a POSIX lock/unlock. */
2011-01-20 14:21:40 +01:00
status = cli_posix_lock ( cli1 , fnum1 , 0 , 100 , true , READ_LOCK ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX lock failed %s \n " , nt_errstr ( status ) ) ;
2009-07-13 18:43:10 -07:00
goto out ;
}
/* Punch a hole in the locked area. */
2011-01-20 14:21:40 +01:00
status = cli_posix_unlock ( cli1 , fnum1 , 10 , 80 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX unlock failed %s \n " , nt_errstr ( status ) ) ;
2009-07-13 18:43:10 -07:00
goto out ;
}
2009-05-27 17:28:23 -07:00
cli_close ( cli1 , fnum1 ) ;
/* Open the symlink for read - this should fail. A POSIX
client should not be doing opens on a symlink . */
2011-01-20 14:21:40 +01:00
status = cli_posix_open ( cli1 , sname , O_RDONLY , 0 , & fnum1 ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2009-05-27 17:28:23 -07:00
printf ( " POSIX open of %s succeeded (should have failed) \n " , sname ) ;
goto out ;
} else {
2011-07-07 16:49:12 +02:00
if ( ! check_both_error ( __LINE__ , status , ERRDOS , ERRbadpath ,
2009-05-27 17:28:23 -07:00
NT_STATUS_OBJECT_PATH_NOT_FOUND ) ) {
2009-05-27 21:51:15 -07:00
printf ( " POSIX open of %s should have failed "
" with NT_STATUS_OBJECT_PATH_NOT_FOUND, "
" failed with %s instead. \n " ,
2011-01-20 14:21:40 +01:00
sname , nt_errstr ( status ) ) ;
2009-05-27 17:28:23 -07:00
goto out ;
}
}
2011-01-20 14:21:40 +01:00
status = cli_posix_readlink ( cli1 , sname , namebuf , sizeof ( namebuf ) ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX readlink on %s failed (%s) \n " , sname , nt_errstr ( status ) ) ;
2009-05-27 21:51:15 -07:00
goto out ;
}
if ( strcmp ( namebuf , fname ) ! = 0 ) {
printf ( " POSIX readlink on %s failed to match name %s (read %s) \n " ,
sname , fname , namebuf ) ;
goto out ;
}
2009-05-27 17:28:23 -07:00
2011-01-20 14:21:40 +01:00
status = cli_posix_rmdir ( cli1 , dname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX rmdir failed (%s) \n " , nt_errstr ( status ) ) ;
2009-03-11 14:28:47 -07:00
goto out ;
}
2012-06-04 20:45:34 -07:00
/* Check directory opens with a specific permission. */
status = cli_posix_mkdir ( cli1 , dname , 0700 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " POSIX mkdir of %s failed (%s) \n " , dname , nt_errstr ( status ) ) ;
goto out ;
}
/* Ensure st_mode == 0700 */
status = cli_posix_stat ( cli1 , dname , & sbuf ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " stat failed (%s) \n " , nt_errstr ( status ) ) ;
goto out ;
}
if ( ( sbuf . st_ex_mode & 07777 ) ! = 0700 ) {
printf ( " posix_mkdir - bad permissions 0%o != 0700 \n " ,
( unsigned int ) ( sbuf . st_ex_mode & 07777 ) ) ;
goto out ;
}
2013-01-24 16:20:14 -08:00
/*
* Now create a Windows file , and attempt a POSIX unlink .
* This should fail with a sharing violation but due to :
*
* [ Bug 9571 ] Unlink after open causes smbd to panic
*
* ensure we ' ve fixed the lock ordering violation .
*/
status = cli_ntcreate ( cli1 , fname_windows , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA , 0 ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_CREATE ,
0x0 , 0x0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Windows create of %s failed (%s) \n " , fname_windows ,
nt_errstr ( status ) ) ;
goto out ;
}
/* Now try posix_unlink. */
status = cli_posix_unlink ( cli1 , fname_windows ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_SHARING_VIOLATION ) ) {
printf ( " POSIX unlink of %s should fail "
" with NT_STATUS_SHARING_VIOLATION "
" got %s instead ! \n " ,
fname_windows ,
nt_errstr ( status ) ) ;
goto out ;
}
cli_close ( cli1 , fnum2 ) ;
2009-03-11 14:28:47 -07:00
printf ( " Simple POSIX open test passed \n " ) ;
correct = true ;
out :
2009-05-21 12:17:53 -07:00
if ( fnum1 ! = ( uint16_t ) - 1 ) {
2009-03-11 14:28:47 -07:00
cli_close ( cli1 , fnum1 ) ;
2009-05-22 15:21:55 -07:00
fnum1 = ( uint16_t ) - 1 ;
2009-03-11 14:28:47 -07:00
}
2013-01-24 16:20:14 -08:00
if ( fnum2 ! = ( uint16_t ) - 1 ) {
cli_close ( cli1 , fnum2 ) ;
fnum2 = ( uint16_t ) - 1 ;
}
2009-05-27 17:28:23 -07:00
cli_setatr ( cli1 , sname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , sname ) ;
cli_setatr ( cli1 , hname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , hname ) ;
2009-03-11 14:28:47 -07:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
cli_posix_unlink ( cli1 , fname ) ;
cli_setatr ( cli1 , dname , 0 , 0 ) ;
cli_posix_rmdir ( cli1 , dname ) ;
2013-01-24 16:20:14 -08:00
cli_setatr ( cli1 , fname_windows , 0 , 0 ) ;
cli_posix_unlink ( cli1 , fname_windows ) ;
2009-03-11 14:28:47 -07:00
if ( ! torture_close_connection ( cli1 ) ) {
correct = false ;
}
return correct ;
}
2003-04-18 03:35:39 +00:00
static uint32 open_attrs_table [ ] = {
FILE_ATTRIBUTE_NORMAL ,
FILE_ATTRIBUTE_ARCHIVE ,
FILE_ATTRIBUTE_READONLY ,
FILE_ATTRIBUTE_HIDDEN ,
FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN ,
FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM ,
FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_SYSTEM ,
} ;
struct trunc_open_results {
unsigned int num ;
uint32 init_attr ;
uint32 trunc_attr ;
uint32 result_attr ;
} ;
static struct trunc_open_results attr_results [ ] = {
{ 0 , FILE_ATTRIBUTE_NORMAL , FILE_ATTRIBUTE_NORMAL , FILE_ATTRIBUTE_ARCHIVE } ,
{ 1 , FILE_ATTRIBUTE_NORMAL , FILE_ATTRIBUTE_ARCHIVE , FILE_ATTRIBUTE_ARCHIVE } ,
{ 2 , FILE_ATTRIBUTE_NORMAL , FILE_ATTRIBUTE_READONLY , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY } ,
{ 16 , FILE_ATTRIBUTE_ARCHIVE , FILE_ATTRIBUTE_NORMAL , FILE_ATTRIBUTE_ARCHIVE } ,
{ 17 , FILE_ATTRIBUTE_ARCHIVE , FILE_ATTRIBUTE_ARCHIVE , FILE_ATTRIBUTE_ARCHIVE } ,
{ 18 , FILE_ATTRIBUTE_ARCHIVE , FILE_ATTRIBUTE_READONLY , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY } ,
{ 51 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 54 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 56 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN } ,
{ 68 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 71 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 73 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM } ,
{ 99 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 102 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 104 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN } ,
{ 116 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 119 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 121 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM } ,
{ 170 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN } ,
{ 173 , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN | FILE_ATTRIBUTE_SYSTEM } ,
{ 227 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 230 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN } ,
{ 232 , FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_HIDDEN } ,
{ 244 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 247 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_SYSTEM } ,
{ 249 , FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM , FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY | FILE_ATTRIBUTE_SYSTEM }
} ;
2007-10-18 17:40:25 -07:00
static bool run_openattrtest ( int dummy )
2003-04-18 03:35:39 +00:00
{
static struct cli_state * cli1 ;
const char * fname = " \\ openattr.file " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum1 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2003-04-18 03:35:39 +00:00
uint16 attr ;
unsigned int i , j , k , l ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2002-09-25 15:19:00 +00:00
2003-04-18 03:35:39 +00:00
printf ( " starting open attr test \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
2002-09-25 15:19:00 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2002-09-25 15:19:00 +00:00
2003-04-18 03:35:39 +00:00
for ( k = 0 , i = 0 ; i < sizeof ( open_attrs_table ) / sizeof ( uint32 ) ; i + + ) {
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 , FILE_WRITE_DATA ,
open_attrs_table [ i ] , FILE_SHARE_NONE ,
FILE_OVERWRITE_IF , 0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open %d (1) of %s failed (%s) \n " , i , fname , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
2002-09-25 15:19:00 +00:00
}
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close %d (1) of %s failed (%s) \n " , i , fname , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2002-11-18 23:13:25 +00:00
2003-04-18 03:35:39 +00:00
for ( j = 0 ; j < sizeof ( open_attrs_table ) / sizeof ( uint32 ) ; j + + ) {
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli1 , fname , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA ,
open_attrs_table [ j ] ,
FILE_SHARE_NONE , FILE_OVERWRITE ,
0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2003-04-18 03:35:39 +00:00
for ( l = 0 ; l < sizeof ( attr_results ) / sizeof ( struct trunc_open_results ) ; l + + ) {
if ( attr_results [ l ] . num = = k ) {
printf ( " [%d] trunc open 0x%x -> 0x%x of %s failed - should have succeeded !(0x%x:%s) \n " ,
k , open_attrs_table [ i ] ,
open_attrs_table [ j ] ,
2011-01-20 14:21:40 +01:00
fname , NT_STATUS_V ( status ) , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
correct = False ;
}
}
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_ACCESS_DENIED ) ) {
2003-04-18 03:35:39 +00:00
printf ( " [%d] trunc open 0x%x -> 0x%x failed with wrong error code %s \n " ,
k , open_attrs_table [ i ] , open_attrs_table [ j ] ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
correct = False ;
}
#if 0
printf ( " [%d] trunc open 0x%x -> 0x%x failed \n " , k , open_attrs_table [ i ] , open_attrs_table [ j ] ) ;
# endif
k + + ;
continue ;
}
2002-11-18 23:13:25 +00:00
2011-01-20 14:21:40 +01:00
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " close %d (2) of %s failed (%s) \n " , j , fname , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2002-11-18 23:13:25 +00:00
2011-01-20 14:21:40 +01:00
status = cli_getatr ( cli1 , fname , & attr , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " getatr(2) failed (%s) \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2002-11-18 23:13:25 +00:00
2003-04-18 03:35:39 +00:00
#if 0
printf ( " [%d] getatr check [0x%x] trunc [0x%x] got attr 0x%x \n " ,
k , open_attrs_table [ i ] , open_attrs_table [ j ] , attr ) ;
# endif
2002-11-18 23:13:25 +00:00
2003-04-18 03:35:39 +00:00
for ( l = 0 ; l < sizeof ( attr_results ) / sizeof ( struct trunc_open_results ) ; l + + ) {
if ( attr_results [ l ] . num = = k ) {
if ( attr ! = attr_results [ l ] . result_attr | |
open_attrs_table [ i ] ! = attr_results [ l ] . init_attr | |
open_attrs_table [ j ] ! = attr_results [ l ] . trunc_attr ) {
printf ( " getatr check failed. [0x%x] trunc [0x%x] got attr 0x%x, should be 0x%x \n " ,
open_attrs_table [ i ] ,
open_attrs_table [ j ] ,
( unsigned int ) attr ,
attr_results [ l ] . result_attr ) ;
correct = False ;
}
break ;
}
}
k + + ;
}
2002-11-18 23:13:25 +00:00
}
2003-04-18 03:35:39 +00:00
cli_setatr ( cli1 , fname , 0 , 0 ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2002-11-18 23:13:25 +00:00
2003-04-18 03:35:39 +00:00
printf ( " open attr test %s. \n " , correct ? " passed " : " failed " ) ;
2002-09-25 15:19:00 +00:00
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli1 ) ) {
2002-03-26 00:07:48 +00:00
correct = False ;
}
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2010-10-29 11:56:51 -07:00
static NTSTATUS list_fn ( const char * mnt , struct file_info * finfo ,
2010-07-27 10:59:55 +02:00
const char * name , void * state )
2001-06-19 02:02:19 +00:00
{
2010-08-02 19:22:22 +02:00
int * matched = ( int * ) state ;
if ( matched ! = NULL ) {
* matched + = 1 ;
}
2010-10-29 11:56:51 -07:00
return NT_STATUS_OK ;
2001-06-19 02:02:19 +00:00
}
/*
test directory listing speed
*/
2007-10-18 17:40:25 -07:00
static bool run_dirtest ( int dummy )
2001-06-19 02:02:19 +00:00
{
int i ;
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2009-11-24 10:59:09 +01:00
struct timeval core_start ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2010-08-02 19:22:22 +02:00
int matched ;
2001-06-19 02:02:19 +00:00
printf ( " starting directory test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2001-06-19 02:02:19 +00:00
srandom ( 0 ) ;
2002-04-12 10:18:46 +00:00
for ( i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
fstring fname ;
2002-03-03 20:47:44 +00:00
slprintf ( fname , sizeof ( fname ) , " \\ %x " , ( int ) random ( ) ) ;
2011-12-03 21:13:08 -08:00
if ( ! NT_STATUS_IS_OK ( cli_openx ( cli , fname , O_RDWR | O_CREAT , DENY_NONE , & fnum ) ) ) {
2001-06-19 02:02:19 +00:00
fprintf ( stderr , " Failed to open %s \n " , fname ) ;
2001-07-02 03:21:17 +00:00
return False ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2001-06-19 02:02:19 +00:00
}
2009-11-24 10:59:09 +01:00
core_start = timeval_current ( ) ;
2001-06-19 02:02:19 +00:00
2010-08-02 19:22:22 +02:00
matched = 0 ;
cli_list ( cli , " a*.* " , 0 , list_fn , & matched ) ;
printf ( " Matched %d \n " , matched ) ;
matched = 0 ;
cli_list ( cli , " b*.* " , 0 , list_fn , & matched ) ;
printf ( " Matched %d \n " , matched ) ;
matched = 0 ;
cli_list ( cli , " xyzabc " , 0 , list_fn , & matched ) ;
printf ( " Matched %d \n " , matched ) ;
2001-06-19 02:02:19 +00:00
2009-11-24 10:59:09 +01:00
printf ( " dirtest core %g seconds \n " , timeval_elapsed ( & core_start ) ) ;
2001-06-19 02:02:19 +00:00
srandom ( 0 ) ;
2002-04-12 10:18:46 +00:00
for ( i = 0 ; i < torture_numops ; i + + ) {
2001-06-19 02:02:19 +00:00
fstring fname ;
2002-03-03 20:47:44 +00:00
slprintf ( fname , sizeof ( fname ) , " \\ %x " , ( int ) random ( ) ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2001-06-19 02:02:19 +00:00
}
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2001-07-02 03:21:17 +00:00
correct = False ;
}
2001-06-19 02:02:19 +00:00
printf ( " finished dirtest \n " ) ;
2001-07-02 03:21:17 +00:00
return correct ;
2001-06-19 02:02:19 +00:00
}
2010-10-29 11:56:51 -07:00
static NTSTATUS del_fn ( const char * mnt , struct file_info * finfo , const char * mask ,
2010-07-27 10:59:55 +02:00
void * state )
2002-09-25 15:19:00 +00:00
{
struct cli_state * pcli = ( struct cli_state * ) state ;
fstring fname ;
slprintf ( fname , sizeof ( fname ) , " \\ LISTDIR \\ %s " , finfo - > name ) ;
if ( strcmp ( finfo - > name , " . " ) = = 0 | | strcmp ( finfo - > name , " .. " ) = = 0 )
2010-10-29 11:56:51 -07:00
return NT_STATUS_OK ;
2002-09-25 15:19:00 +00:00
2011-04-29 11:57:02 +10:00
if ( finfo - > mode & FILE_ATTRIBUTE_DIRECTORY ) {
2009-04-21 06:52:54 -07:00
if ( ! NT_STATUS_IS_OK ( cli_rmdir ( pcli , fname ) ) )
2002-09-25 15:19:00 +00:00
printf ( " del_fn: failed to rmdir %s \n , " , fname ) ;
} else {
2011-04-29 13:23:14 +10:00
if ( ! NT_STATUS_IS_OK ( cli_unlink ( pcli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ) )
2002-09-25 15:19:00 +00:00
printf ( " del_fn: failed to unlink %s \n , " , fname ) ;
}
2010-10-29 11:56:51 -07:00
return NT_STATUS_OK ;
2002-09-25 15:19:00 +00:00
}
2003-04-18 03:35:39 +00:00
2003-04-23 08:12:34 +00:00
/*
sees what IOCTLs are supported
*/
2007-10-18 17:40:25 -07:00
bool torture_ioctl_test ( int dummy )
2003-04-23 08:12:34 +00:00
{
static struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t device , function ;
uint16_t fnum ;
2003-04-23 08:12:34 +00:00
const char * fname = " \\ ioctl.dat " ;
DATA_BLOB blob ;
NTSTATUS status ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2003-04-23 08:12:34 +00:00
return False ;
}
printf ( " starting ioctl test \n " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-23 08:12:34 +00:00
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open of %s failed (%s) \n " , fname , nt_errstr ( status ) ) ;
2003-04-23 08:12:34 +00:00
return False ;
}
status = cli_raw_ioctl ( cli , fnum , 0x2d0000 | ( 0x0420 < < 2 ) , & blob ) ;
2010-02-21 11:41:54 +01:00
printf ( " ioctl device info: %s \n " , nt_errstr ( status ) ) ;
2003-04-23 08:12:34 +00:00
status = cli_raw_ioctl ( cli , fnum , IOCTL_QUERY_JOB_INFO , & blob ) ;
2010-02-21 11:41:54 +01:00
printf ( " ioctl job info: %s \n " , nt_errstr ( status ) ) ;
2003-04-23 08:12:34 +00:00
for ( device = 0 ; device < 0x100 ; device + + ) {
2010-08-16 13:30:00 +02:00
printf ( " ioctl test with device = 0x%x \n " , device ) ;
2003-04-23 08:12:34 +00:00
for ( function = 0 ; function < 0x100 ; function + + ) {
uint32 code = ( device < < 16 ) | function ;
status = cli_raw_ioctl ( cli , fnum , code , & blob ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2006-07-11 21:23:44 +00:00
printf ( " ioctl 0x%x OK : %d bytes \n " , ( int ) code ,
2006-07-22 19:29:02 +00:00
( int ) blob . length ) ;
2003-04-23 08:12:34 +00:00
data_blob_free ( & blob ) ;
}
}
}
if ( ! torture_close_connection ( cli ) ) {
return False ;
}
return True ;
}
2003-04-18 03:35:39 +00:00
/*
tries varients of chkpath
*/
2007-10-18 17:40:25 -07:00
bool torture_chkpath_test ( int dummy )
2003-04-18 03:35:39 +00:00
{
static struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2007-10-18 17:40:25 -07:00
bool ret ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2003-04-18 03:35:39 +00:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2003-04-18 03:35:39 +00:00
return False ;
}
printf ( " starting chkpath test \n " ) ;
/* cleanup from an old run */
cli_rmdir ( cli , " \\ chkpath.dir \\ dir2 " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , " \\ chkpath.dir \\ * " , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
cli_rmdir ( cli , " \\ chkpath.dir " ) ;
2011-01-20 14:21:40 +01:00
status = cli_mkdir ( cli , " \\ chkpath.dir " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " mkdir1 failed : %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_mkdir ( cli , " \\ chkpath.dir \\ dir2 " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " mkdir2 failed : %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , " \\ chkpath.dir \\ foo.txt " , O_RDWR | O_CREAT | O_EXCL ,
2011-01-20 14:21:40 +01:00
DENY_NONE , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open1 failed (%s) \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
return False ;
}
cli_close ( cli , fnum ) ;
2011-01-20 14:21:40 +01:00
status = cli_chkpath ( cli , " \\ chkpath.dir " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " chkpath1 failed: %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
ret = False ;
}
2011-01-20 14:21:40 +01:00
status = cli_chkpath ( cli , " \\ chkpath.dir \\ dir2 " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " chkpath2 failed: %s \n " , nt_errstr ( status ) ) ;
2003-04-18 03:35:39 +00:00
ret = False ;
}
2011-01-20 14:21:40 +01:00
status = cli_chkpath ( cli , " \\ chkpath.dir \\ foo.txt " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-07-27 21:51:45 +02:00
ret = check_error ( __LINE__ , status , ERRDOS , ERRbadpath ,
2003-04-18 03:35:39 +00:00
NT_STATUS_NOT_A_DIRECTORY ) ;
} else {
printf ( " * chkpath on a file should fail \n " ) ;
ret = False ;
}
2011-07-27 21:51:45 +02:00
status = cli_chkpath ( cli , " \\ chkpath.dir \\ bar.txt " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
ret = check_error ( __LINE__ , status , ERRDOS , ERRbadfile ,
2003-04-18 03:35:39 +00:00
NT_STATUS_OBJECT_NAME_NOT_FOUND ) ;
} else {
2012-06-11 17:49:15 +02:00
printf ( " * chkpath on a non existent file should fail \n " ) ;
2003-04-18 03:35:39 +00:00
ret = False ;
}
2011-07-27 21:51:45 +02:00
status = cli_chkpath ( cli , " \\ chkpath.dir \\ dirxx \\ bar.txt " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
ret = check_error ( __LINE__ , status , ERRDOS , ERRbadpath ,
2003-04-18 03:35:39 +00:00
NT_STATUS_OBJECT_PATH_NOT_FOUND ) ;
} else {
printf ( " * chkpath on a non existent component should fail \n " ) ;
ret = False ;
}
cli_rmdir ( cli , " \\ chkpath.dir \\ dir2 " ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , " \\ chkpath.dir \\ * " , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2003-04-18 03:35:39 +00:00
cli_rmdir ( cli , " \\ chkpath.dir " ) ;
if ( ! torture_close_connection ( cli ) ) {
return False ;
}
return ret ;
}
2007-10-18 17:40:25 -07:00
static bool run_eatest ( int dummy )
2004-03-27 02:13:58 +00:00
{
static struct cli_state * cli ;
const char * fname = " \\ eatest.txt " ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
int i ;
2004-03-29 22:21:47 +00:00
size_t num_eas ;
struct ea_struct * ea_list = NULL ;
TALLOC_CTX * mem_ctx = talloc_init ( " eatest " ) ;
2010-07-25 21:32:13 +02:00
NTSTATUS status ;
2004-03-27 02:13:58 +00:00
printf ( " starting eatest \n " ) ;
2009-04-22 11:51:03 +02:00
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2007-03-01 02:43:33 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-27 02:13:58 +00:00
return False ;
}
2009-04-22 11:51:03 +02:00
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli , fname , 0 ,
FIRST_DESIRED_ACCESS , FILE_ATTRIBUTE_ARCHIVE ,
FILE_SHARE_NONE , FILE_OVERWRITE_IF ,
0x4044 , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open failed - %s \n " , nt_errstr ( status ) ) ;
2007-03-01 02:43:33 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-27 02:13:58 +00:00
return False ;
}
2003-04-18 03:35:39 +00:00
2004-03-27 02:13:58 +00:00
for ( i = 0 ; i < 10 ; i + + ) {
fstring ea_name , ea_val ;
2003-04-18 03:35:39 +00:00
2004-03-27 02:13:58 +00:00
slprintf ( ea_name , sizeof ( ea_name ) , " EA_%d " , i ) ;
memset ( ea_val , ( char ) i + 1 , i + 1 ) ;
2010-11-11 15:58:34 +01:00
status = cli_set_ea_fnum ( cli , fnum , ea_name , ea_val , i + 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ea_set of name %s failed - %s \n " , ea_name ,
nt_errstr ( status ) ) ;
2007-03-01 02:43:33 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-27 02:13:58 +00:00
return False ;
}
}
2009-04-22 11:51:03 +02:00
2004-03-27 02:13:58 +00:00
cli_close ( cli , fnum ) ;
for ( i = 0 ; i < 10 ; i + + ) {
fstring ea_name , ea_val ;
2004-03-29 22:21:47 +00:00
slprintf ( ea_name , sizeof ( ea_name ) , " EA_%d " , i + 10 ) ;
2004-03-27 02:13:58 +00:00
memset ( ea_val , ( char ) i + 1 , i + 1 ) ;
2010-11-11 15:51:46 +01:00
status = cli_set_ea_path ( cli , fname , ea_name , ea_val , i + 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ea_set of name %s failed - %s \n " , ea_name ,
nt_errstr ( status ) ) ;
2007-03-01 02:43:33 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-27 02:13:58 +00:00
return False ;
}
}
2009-04-22 11:51:03 +02:00
2010-07-25 21:32:13 +02:00
status = cli_get_ea_list_path ( cli , fname , mem_ctx , & num_eas , & ea_list ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ea_get list failed - %s \n " , nt_errstr ( status ) ) ;
2004-03-29 22:21:47 +00:00
correct = False ;
}
2006-07-11 21:23:44 +00:00
printf ( " num_eas = %d \n " , ( int ) num_eas ) ;
2004-03-30 18:38:21 +00:00
if ( num_eas ! = 20 ) {
printf ( " Should be 20 EA's stored... failing. \n " ) ;
correct = False ;
}
2004-03-29 22:21:47 +00:00
for ( i = 0 ; i < num_eas ; i + + ) {
printf ( " %d: ea_name = %s. Val = " , i , ea_list [ i ] . name ) ;
2007-03-28 13:34:59 +00:00
dump_data ( 0 , ea_list [ i ] . value . data ,
2006-07-11 18:01:26 +00:00
ea_list [ i ] . value . length ) ;
2004-03-29 22:21:47 +00:00
}
2004-03-27 02:13:58 +00:00
2004-03-29 23:39:13 +00:00
/* Setting EA's to zero length deletes them. Test this */
2004-04-06 14:24:13 +00:00
printf ( " Now deleting all EA's - case indepenent.... \n " ) ;
2004-03-29 23:39:13 +00:00
2005-10-31 20:11:58 +00:00
# if 1
cli_set_ea_path ( cli , fname , " " , " " , 0 ) ;
# else
2004-03-29 23:39:13 +00:00
for ( i = 0 ; i < 20 ; i + + ) {
fstring ea_name ;
2004-04-06 14:24:13 +00:00
slprintf ( ea_name , sizeof ( ea_name ) , " ea_%d " , i ) ;
2010-11-11 15:51:46 +01:00
status = cli_set_ea_path ( cli , fname , ea_name , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ea_set of name %s failed - %s \n " , ea_name ,
nt_errstr ( status ) ) ;
2007-03-01 02:43:33 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-29 23:39:13 +00:00
return False ;
}
}
2005-10-31 20:11:58 +00:00
# endif
2010-07-25 21:32:13 +02:00
status = cli_get_ea_list_path ( cli , fname , mem_ctx , & num_eas , & ea_list ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " ea_get list failed - %s \n " , nt_errstr ( status ) ) ;
2004-03-29 23:39:13 +00:00
correct = False ;
}
2006-07-11 21:23:44 +00:00
printf ( " num_eas = %d \n " , ( int ) num_eas ) ;
2004-03-29 23:39:13 +00:00
for ( i = 0 ; i < num_eas ; i + + ) {
printf ( " %d: ea_name = %s. Val = " , i , ea_list [ i ] . name ) ;
2007-03-28 13:34:59 +00:00
dump_data ( 0 , ea_list [ i ] . value . data ,
2006-07-11 18:01:26 +00:00
ea_list [ i ] . value . length ) ;
2004-03-29 23:39:13 +00:00
}
if ( num_eas ! = 0 ) {
printf ( " deleting EA's failed. \n " ) ;
correct = False ;
}
2012-06-11 17:49:15 +02:00
/* Try and delete a non existent EA. */
2010-11-11 15:51:46 +01:00
status = cli_set_ea_path ( cli , fname , " foo " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-06-11 17:49:15 +02:00
printf ( " deleting non-existent EA 'foo' should succeed. %s \n " ,
2010-11-11 15:51:46 +01:00
nt_errstr ( status ) ) ;
2004-03-30 18:38:21 +00:00
correct = False ;
}
2004-03-29 22:21:47 +00:00
talloc_destroy ( mem_ctx ) ;
2004-03-27 02:13:58 +00:00
if ( ! torture_close_connection ( cli ) ) {
correct = False ;
}
2009-04-22 11:51:03 +02:00
2004-03-27 02:13:58 +00:00
return correct ;
}
2003-04-18 03:35:39 +00:00
2007-10-18 17:40:25 -07:00
static bool run_dirtest1 ( int dummy )
2002-09-25 15:19:00 +00:00
{
int i ;
2003-04-18 03:35:39 +00:00
static struct cli_state * cli ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
int num_seen ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2002-09-25 15:19:00 +00:00
printf ( " starting directory test \n " ) ;
2006-07-31 09:41:25 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2002-09-25 15:19:00 +00:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2002-09-25 15:19:00 +00:00
2003-04-18 03:35:39 +00:00
cli_list ( cli , " \\ LISTDIR \\ * " , 0 , del_fn , cli ) ;
2011-04-29 11:57:02 +10:00
cli_list ( cli , " \\ LISTDIR \\ * " , FILE_ATTRIBUTE_DIRECTORY , del_fn , cli ) ;
2003-04-18 03:35:39 +00:00
cli_rmdir ( cli , " \\ LISTDIR " ) ;
cli_mkdir ( cli , " \\ LISTDIR " ) ;
2002-09-25 15:19:00 +00:00
/* Create 1000 files and 1000 directories. */
for ( i = 0 ; i < 1000 ; i + + ) {
fstring fname ;
slprintf ( fname , sizeof ( fname ) , " \\ LISTDIR \\ f%d " , i ) ;
2009-04-30 15:26:43 -07:00
if ( ! NT_STATUS_IS_OK ( cli_ntcreate ( cli , fname , 0 , GENERIC_ALL_ACCESS , FILE_ATTRIBUTE_ARCHIVE ,
FILE_SHARE_READ | FILE_SHARE_WRITE , FILE_OVERWRITE_IF , 0 , 0 , & fnum ) ) ) {
2002-09-25 15:19:00 +00:00
fprintf ( stderr , " Failed to open %s \n " , fname ) ;
return False ;
}
2003-04-18 03:35:39 +00:00
cli_close ( cli , fnum ) ;
2002-09-25 15:19:00 +00:00
}
for ( i = 0 ; i < 1000 ; i + + ) {
fstring fname ;
slprintf ( fname , sizeof ( fname ) , " \\ LISTDIR \\ d%d " , i ) ;
2009-04-21 05:52:34 -07:00
if ( ! NT_STATUS_IS_OK ( cli_mkdir ( cli , fname ) ) ) {
2002-09-25 15:19:00 +00:00
fprintf ( stderr , " Failed to open %s \n " , fname ) ;
return False ;
}
}
/* Now ensure that doing an old list sees both files and directories. */
2010-08-10 07:44:15 +02:00
num_seen = 0 ;
2011-04-29 11:57:02 +10:00
cli_list_old ( cli , " \\ LISTDIR \\ * " , FILE_ATTRIBUTE_DIRECTORY , list_fn , & num_seen ) ;
2002-09-25 15:19:00 +00:00
printf ( " num_seen = %d \n " , num_seen ) ;
/* We should see 100 files + 1000 directories + . and .. */
if ( num_seen ! = 2002 )
correct = False ;
/* Ensure if we have the "must have" bits we only see the
* relevent entries .
*/
2010-08-10 07:44:15 +02:00
num_seen = 0 ;
2011-04-29 11:57:02 +10:00
cli_list_old ( cli , " \\ LISTDIR \\ * " , ( FILE_ATTRIBUTE_DIRECTORY < < 8 ) | FILE_ATTRIBUTE_DIRECTORY , list_fn , & num_seen ) ;
2002-09-25 15:19:00 +00:00
printf ( " num_seen = %d \n " , num_seen ) ;
if ( num_seen ! = 1002 )
correct = False ;
2010-08-10 07:44:15 +02:00
num_seen = 0 ;
2011-04-29 12:00:57 +10:00
cli_list_old ( cli , " \\ LISTDIR \\ * " , ( FILE_ATTRIBUTE_ARCHIVE < < 8 ) | FILE_ATTRIBUTE_DIRECTORY , list_fn , & num_seen ) ;
2002-09-25 15:19:00 +00:00
printf ( " num_seen = %d \n " , num_seen ) ;
if ( num_seen ! = 1000 )
correct = False ;
/* Delete everything. */
2003-04-18 03:35:39 +00:00
cli_list ( cli , " \\ LISTDIR \\ * " , 0 , del_fn , cli ) ;
2011-04-29 11:57:02 +10:00
cli_list ( cli , " \\ LISTDIR \\ * " , FILE_ATTRIBUTE_DIRECTORY , del_fn , cli ) ;
2003-04-18 03:35:39 +00:00
cli_rmdir ( cli , " \\ LISTDIR " ) ;
2002-09-25 15:19:00 +00:00
#if 0
2003-04-18 03:35:39 +00:00
printf ( " Matched %d \n " , cli_list ( cli , " a*.* " , 0 , list_fn , NULL ) ) ;
printf ( " Matched %d \n " , cli_list ( cli , " b*.* " , 0 , list_fn , NULL ) ) ;
printf ( " Matched %d \n " , cli_list ( cli , " xyzabc " , 0 , list_fn , NULL ) ) ;
2002-09-25 15:19:00 +00:00
# endif
2003-04-18 03:35:39 +00:00
if ( ! torture_close_connection ( cli ) ) {
2002-09-25 15:19:00 +00:00
correct = False ;
}
printf ( " finished dirtest1 \n " ) ;
return correct ;
}
2007-10-18 17:40:25 -07:00
static bool run_error_map_extract ( int dummy ) {
2009-04-22 11:51:03 +02:00
2006-07-11 18:01:26 +00:00
static struct cli_state * c_dos ;
static struct cli_state * c_nt ;
2008-09-11 18:57:49 +02:00
NTSTATUS status ;
2001-11-25 02:35:37 +00:00
uint32 error ;
2011-07-08 13:34:38 +02:00
uint32 errnum ;
2001-11-25 02:35:37 +00:00
uint8 errclass ;
NTSTATUS nt_status ;
fstring user ;
2002-01-03 07:00:18 +00:00
/* NT-Error connection */
2011-09-08 09:56:16 +02:00
disable_spnego = true ;
2006-07-11 18:01:26 +00:00
if ( ! ( c_nt = open_nbt_connection ( ) ) ) {
2011-09-08 09:56:16 +02:00
disable_spnego = false ;
2002-01-03 06:10:25 +00:00
return False ;
}
2011-09-08 09:56:16 +02:00
disable_spnego = false ;
2002-01-03 07:00:18 +00:00
2012-05-20 17:54:29 +02:00
status = smbXcli_negprot ( c_nt - > conn , c_nt - > timeout , PROTOCOL_CORE ,
PROTOCOL_NT1 ) ;
2008-09-11 18:57:49 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " %s rejected the NT-error negprot (%s) \n " , host ,
nt_errstr ( status ) ) ;
2006-07-11 18:01:26 +00:00
cli_shutdown ( c_nt ) ;
2002-01-02 03:54:40 +00:00
return False ;
}
2001-11-25 02:35:37 +00:00
2011-01-20 14:21:40 +01:00
status = cli_session_setup ( c_nt , " " , " " , 0 , " " , 0 , workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " %s rejected the NT-error initial session setup (%s) \n " , host , nt_errstr ( status ) ) ;
2002-01-03 07:00:18 +00:00
return False ;
}
/* DOS-Error connection */
2011-09-08 09:56:16 +02:00
disable_spnego = true ;
2011-09-08 09:24:11 +02:00
force_dos_errors = true ;
2006-07-11 18:01:26 +00:00
if ( ! ( c_dos = open_nbt_connection ( ) ) ) {
2011-09-08 09:56:16 +02:00
disable_spnego = false ;
2011-09-08 09:24:11 +02:00
force_dos_errors = false ;
2002-01-03 06:10:25 +00:00
return False ;
}
2011-09-08 09:56:16 +02:00
disable_spnego = false ;
2011-09-08 09:24:11 +02:00
force_dos_errors = false ;
2002-01-03 06:10:25 +00:00
2012-05-20 17:54:29 +02:00
status = smbXcli_negprot ( c_dos - > conn , c_dos - > timeout , PROTOCOL_CORE ,
PROTOCOL_NT1 ) ;
2008-09-11 18:57:49 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " %s rejected the DOS-error negprot (%s) \n " , host ,
nt_errstr ( status ) ) ;
2006-07-11 18:01:26 +00:00
cli_shutdown ( c_dos ) ;
2001-11-25 02:35:37 +00:00
return False ;
}
2011-01-20 14:21:40 +01:00
status = cli_session_setup ( c_dos , " " , " " , 0 , " " , 0 , workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " %s rejected the DOS-error initial session setup (%s) \n " ,
host , nt_errstr ( status ) ) ;
2002-01-03 07:00:18 +00:00
return False ;
}
2011-11-16 15:03:49 +01:00
c_nt - > map_dos_errors = false ;
c_dos - > map_dos_errors = false ;
2001-11-25 02:35:37 +00:00
for ( error = ( 0xc0000000 | 0x1 ) ; error < ( 0xc0000000 | 0xFFF ) ; error + + ) {
2003-07-23 12:33:59 +00:00
fstr_sprintf ( user , " %X " , error ) ;
2001-06-19 02:02:19 +00:00
2011-01-20 14:21:40 +01:00
status = cli_session_setup ( c_nt , user ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2002-01-03 07:36:26 +00:00
printf ( " /** Session setup succeeded. This shouldn't happen...*/ \n " ) ;
}
2009-04-22 11:51:03 +02:00
2002-01-03 07:36:26 +00:00
/* Case #1: 32-bit NT errors */
2011-11-16 15:03:49 +01:00
if ( ! NT_STATUS_IS_DOS ( status ) ) {
nt_status = status ;
2001-11-25 02:35:37 +00:00
} else {
2002-01-03 08:36:47 +00:00
printf ( " /** Dos error on NT connection! (%s) */ \n " ,
2011-11-16 15:03:49 +01:00
nt_errstr ( status ) ) ;
2002-01-03 07:36:26 +00:00
nt_status = NT_STATUS ( 0xc0000000 ) ;
2001-11-25 02:35:37 +00:00
}
2011-07-08 13:34:38 +02:00
status = cli_session_setup ( c_dos , user ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2002-01-03 07:36:26 +00:00
printf ( " /** Session setup succeeded. This shouldn't happen...*/ \n " ) ;
2001-11-25 02:35:37 +00:00
}
2009-04-22 11:51:03 +02:00
2002-01-03 07:36:26 +00:00
/* Case #1: 32-bit NT errors */
2011-11-16 15:03:49 +01:00
if ( NT_STATUS_IS_DOS ( status ) ) {
2002-01-03 08:36:47 +00:00
printf ( " /** NT error on DOS connection! (%s) */ \n " ,
2011-11-16 15:03:49 +01:00
nt_errstr ( status ) ) ;
2002-01-03 07:36:26 +00:00
errnum = errclass = 0 ;
2001-11-25 02:35:37 +00:00
} else {
2011-11-16 15:03:49 +01:00
errclass = NT_STATUS_DOS_CLASS ( status ) ;
errnum = NT_STATUS_DOS_CODE ( status ) ;
2001-11-25 02:35:37 +00:00
}
2002-01-03 07:36:26 +00:00
if ( NT_STATUS_V ( nt_status ) ! = error ) {
printf ( " /* \t { This NT error code was 'sqashed' \n \t from %s to %s \n \t during the session setup } \n */ \n " ,
2011-05-04 15:30:01 +10:00
get_nt_error_c_code ( talloc_tos ( ) , NT_STATUS ( error ) ) ,
get_nt_error_c_code ( talloc_tos ( ) , nt_status ) ) ;
2002-01-03 07:36:26 +00:00
}
2009-04-22 11:51:03 +02:00
2002-01-03 07:36:26 +00:00
printf ( " \t {%s, \t %s, \t %s}, \n " ,
smb_dos_err_class ( errclass ) ,
smb_dos_err_name ( errclass , errnum ) ,
2011-05-04 15:30:01 +10:00
get_nt_error_c_code ( talloc_tos ( ) , NT_STATUS ( error ) ) ) ;
2001-11-25 02:35:37 +00:00
}
return True ;
}
2001-06-19 02:02:19 +00:00
2007-12-04 11:38:57 +01:00
static bool run_sesssetup_bench ( int dummy )
{
static struct cli_state * c ;
2008-12-29 17:08:38 +01:00
const char * fname = " \\ file.dat " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2007-12-04 11:38:57 +01:00
NTSTATUS status ;
int i ;
2008-12-29 17:08:38 +01:00
if ( ! torture_open_connection ( & c , 0 ) ) {
2007-12-04 11:38:57 +01:00
return false ;
}
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( c , fname , 0 , GENERIC_ALL_ACCESS | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OVERWRITE_IF ,
FILE_DELETE_ON_CLOSE , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " open %s failed: %s \n " , fname , nt_errstr ( status ) ) ;
2007-12-04 11:38:57 +01:00
return false ;
}
for ( i = 0 ; i < torture_numops ; i + + ) {
status = cli_session_setup (
c , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " (%s) cli_session_setup failed: %s \n " ,
__location__ , nt_errstr ( status ) ) ;
return false ;
}
2011-07-21 09:20:43 +02:00
d_printf ( " \r %d " , ( int ) cli_state_get_uid ( c ) ) ;
2008-12-29 22:07:56 +01:00
2010-01-03 13:03:42 +01:00
status = cli_ulogoff ( c ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2007-12-04 11:38:57 +01:00
d_printf ( " (%s) cli_ulogoff failed: %s \n " ,
2010-01-03 13:03:42 +01:00
__location__ , nt_errstr ( status ) ) ;
2007-12-04 11:38:57 +01:00
return false ;
}
}
return true ;
}
2007-10-07 13:36:56 +00:00
static bool subst_test ( const char * str , const char * user , const char * domain ,
uid_t uid , gid_t gid , const char * expected )
{
char * subst ;
bool result = true ;
2013-11-18 14:58:04 +01:00
subst = talloc_sub_specified ( talloc_tos ( ) , str , user , NULL , domain , uid , gid ) ;
2007-10-07 13:36:56 +00:00
if ( strcmp ( subst , expected ) ! = 0 ) {
printf ( " sub_specified(%s, %s, %s, %d, %d) returned [%s], expected "
" [%s] \n " , str , user , domain , ( int ) uid , ( int ) gid , subst ,
expected ) ;
result = false ;
}
TALLOC_FREE ( subst ) ;
return result ;
}
2009-04-05 23:20:45 +02:00
static void chain1_open_completion ( struct tevent_req * req )
{
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2009-04-05 23:20:45 +02:00
NTSTATUS status ;
2011-12-03 21:13:08 -08:00
status = cli_openx_recv ( req , & fnum ) ;
2009-04-05 23:20:45 +02:00
TALLOC_FREE ( req ) ;
2011-12-03 21:13:08 -08:00
d_printf ( " cli_openx_recv returned %s: %d \n " ,
2009-04-05 23:20:45 +02:00
nt_errstr ( status ) ,
NT_STATUS_IS_OK ( status ) ? fnum : - 1 ) ;
}
static void chain1_write_completion ( struct tevent_req * req )
{
size_t written ;
NTSTATUS status ;
status = cli_write_andx_recv ( req , & written ) ;
TALLOC_FREE ( req ) ;
d_printf ( " cli_write_andx_recv returned %s: %d \n " ,
nt_errstr ( status ) ,
NT_STATUS_IS_OK ( status ) ? ( int ) written : - 1 ) ;
}
static void chain1_close_completion ( struct tevent_req * req )
{
NTSTATUS status ;
bool * done = ( bool * ) tevent_req_callback_data_void ( req ) ;
status = cli_close_recv ( req ) ;
* done = true ;
TALLOC_FREE ( req ) ;
d_printf ( " cli_close returned %s \n " , nt_errstr ( status ) ) ;
}
static bool run_chain1 ( int dummy )
{
struct cli_state * cli1 ;
2013-02-18 09:55:58 +01:00
struct tevent_context * evt = samba_tevent_context_init ( NULL ) ;
2009-04-05 23:20:45 +02:00
struct tevent_req * reqs [ 3 ] , * smbreqs [ 3 ] ;
bool done = false ;
const char * str = " foobar " ;
2009-05-12 14:47:02 +02:00
NTSTATUS status ;
2009-04-05 23:20:45 +02:00
printf ( " starting chain1 test \n " ) ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-04-05 23:20:45 +02:00
2011-12-03 21:13:08 -08:00
reqs [ 0 ] = cli_openx_create ( talloc_tos ( ) , evt , cli1 , " \\ test " ,
2009-04-05 23:20:45 +02:00
O_CREAT | O_RDWR , 0 , & smbreqs [ 0 ] ) ;
if ( reqs [ 0 ] = = NULL ) return false ;
tevent_req_set_callback ( reqs [ 0 ] , chain1_open_completion , NULL ) ;
reqs [ 1 ] = cli_write_andx_create ( talloc_tos ( ) , evt , cli1 , 0 , 0 ,
2011-05-05 16:44:27 -07:00
( const uint8_t * ) str , 0 , strlen ( str ) + 1 ,
2009-04-05 23:20:45 +02:00
smbreqs , 1 , & smbreqs [ 1 ] ) ;
if ( reqs [ 1 ] = = NULL ) return false ;
tevent_req_set_callback ( reqs [ 1 ] , chain1_write_completion , NULL ) ;
reqs [ 2 ] = cli_close_create ( talloc_tos ( ) , evt , cli1 , 0 , & smbreqs [ 2 ] ) ;
if ( reqs [ 2 ] = = NULL ) return false ;
tevent_req_set_callback ( reqs [ 2 ] , chain1_close_completion , & done ) ;
2012-05-26 11:58:34 +02:00
status = smb1cli_req_chain_submit ( smbreqs , ARRAY_SIZE ( smbreqs ) ) ;
2009-05-12 14:47:02 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-04-05 23:20:45 +02:00
return false ;
}
while ( ! done ) {
2010-05-25 15:23:55 -04:00
tevent_loop_once ( evt ) ;
2009-04-05 23:20:45 +02:00
}
torture_close_connection ( cli1 ) ;
return True ;
}
2009-05-07 16:24:46 +02:00
static void chain2_sesssetup_completion ( struct tevent_req * req )
{
NTSTATUS status ;
status = cli_session_setup_guest_recv ( req ) ;
d_printf ( " sesssetup returned %s \n " , nt_errstr ( status ) ) ;
}
static void chain2_tcon_completion ( struct tevent_req * req )
{
bool * done = ( bool * ) tevent_req_callback_data_void ( req ) ;
NTSTATUS status ;
status = cli_tcon_andx_recv ( req ) ;
d_printf ( " tcon_and_x returned %s \n " , nt_errstr ( status ) ) ;
* done = true ;
}
static bool run_chain2 ( int dummy )
{
struct cli_state * cli1 ;
2013-02-18 09:55:58 +01:00
struct tevent_context * evt = samba_tevent_context_init ( NULL ) ;
2009-05-07 16:24:46 +02:00
struct tevent_req * reqs [ 2 ] , * smbreqs [ 2 ] ;
bool done = false ;
2009-05-12 14:47:02 +02:00
NTSTATUS status ;
2009-05-07 16:24:46 +02:00
printf ( " starting chain2 test \n " ) ;
2011-06-09 15:31:03 +10:00
status = cli_start_connection ( & cli1 , lp_netbios_name ( ) , host , NULL ,
2011-11-02 18:41:50 +01:00
port_to_use , SMB_SIGNING_DEFAULT , 0 ) ;
2009-07-19 14:53:11 -04:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-07 16:24:46 +02:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2009-05-07 16:24:46 +02:00
reqs [ 0 ] = cli_session_setup_guest_create ( talloc_tos ( ) , evt , cli1 ,
& smbreqs [ 0 ] ) ;
if ( reqs [ 0 ] = = NULL ) return false ;
tevent_req_set_callback ( reqs [ 0 ] , chain2_sesssetup_completion , NULL ) ;
reqs [ 1 ] = cli_tcon_andx_create ( talloc_tos ( ) , evt , cli1 , " IPC$ " ,
" ????? " , NULL , 0 , & smbreqs [ 1 ] ) ;
if ( reqs [ 1 ] = = NULL ) return false ;
tevent_req_set_callback ( reqs [ 1 ] , chain2_tcon_completion , & done ) ;
2012-05-26 11:58:34 +02:00
status = smb1cli_req_chain_submit ( smbreqs , ARRAY_SIZE ( smbreqs ) ) ;
2009-05-12 14:47:02 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-07 16:24:46 +02:00
return false ;
}
while ( ! done ) {
2010-05-25 15:23:55 -04:00
tevent_loop_once ( evt ) ;
2009-05-07 16:24:46 +02:00
}
torture_close_connection ( cli1 ) ;
return True ;
}
2009-10-12 17:29:45 +02:00
struct torture_createdel_state {
struct tevent_context * ev ;
struct cli_state * cli ;
} ;
static void torture_createdel_created ( struct tevent_req * subreq ) ;
static void torture_createdel_closed ( struct tevent_req * subreq ) ;
static struct tevent_req * torture_createdel_send ( TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct cli_state * cli ,
const char * name )
{
struct tevent_req * req , * subreq ;
struct torture_createdel_state * state ;
req = tevent_req_create ( mem_ctx , & state ,
struct torture_createdel_state ) ;
if ( req = = NULL ) {
return NULL ;
}
state - > ev = ev ;
state - > cli = cli ;
subreq = cli_ntcreate_send (
state , ev , cli , name , 0 ,
FILE_READ_DATA | FILE_WRITE_DATA | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE ,
FILE_OPEN_IF , FILE_DELETE_ON_CLOSE , 0 ) ;
if ( tevent_req_nomem ( subreq , req ) ) {
return tevent_req_post ( req , ev ) ;
}
tevent_req_set_callback ( subreq , torture_createdel_created , req ) ;
return req ;
}
static void torture_createdel_created ( struct tevent_req * subreq )
{
struct tevent_req * req = tevent_req_callback_data (
subreq , struct tevent_req ) ;
struct torture_createdel_state * state = tevent_req_data (
req , struct torture_createdel_state ) ;
NTSTATUS status ;
uint16_t fnum ;
status = cli_ntcreate_recv ( subreq , & fnum ) ;
TALLOC_FREE ( subreq ) ;
2013-11-15 13:17:21 +00:00
if ( tevent_req_nterror ( req , status ) ) {
2009-10-12 17:29:45 +02:00
DEBUG ( 10 , ( " cli_ntcreate_recv returned %s \n " ,
nt_errstr ( status ) ) ) ;
return ;
}
subreq = cli_close_send ( state , state - > ev , state - > cli , fnum ) ;
if ( tevent_req_nomem ( subreq , req ) ) {
return ;
}
tevent_req_set_callback ( subreq , torture_createdel_closed , req ) ;
}
static void torture_createdel_closed ( struct tevent_req * subreq )
{
struct tevent_req * req = tevent_req_callback_data (
subreq , struct tevent_req ) ;
NTSTATUS status ;
status = cli_close_recv ( subreq ) ;
2013-11-15 13:17:21 +00:00
if ( tevent_req_nterror ( req , status ) ) {
2009-10-12 17:29:45 +02:00
DEBUG ( 10 , ( " cli_close_recv returned %s \n " , nt_errstr ( status ) ) ) ;
return ;
}
tevent_req_done ( req ) ;
}
static NTSTATUS torture_createdel_recv ( struct tevent_req * req )
{
return tevent_req_simple_recv_ntstatus ( req ) ;
}
struct torture_createdels_state {
struct tevent_context * ev ;
struct cli_state * cli ;
const char * base_name ;
int sent ;
int received ;
int num_files ;
struct tevent_req * * reqs ;
} ;
static void torture_createdels_done ( struct tevent_req * subreq ) ;
static struct tevent_req * torture_createdels_send ( TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct cli_state * cli ,
const char * base_name ,
int num_parallel ,
int num_files )
{
struct tevent_req * req ;
struct torture_createdels_state * state ;
int i ;
req = tevent_req_create ( mem_ctx , & state ,
struct torture_createdels_state ) ;
if ( req = = NULL ) {
return NULL ;
}
state - > ev = ev ;
state - > cli = cli ;
state - > base_name = talloc_strdup ( state , base_name ) ;
if ( tevent_req_nomem ( state - > base_name , req ) ) {
return tevent_req_post ( req , ev ) ;
}
state - > num_files = MAX ( num_parallel , num_files ) ;
state - > sent = 0 ;
state - > received = 0 ;
state - > reqs = talloc_array ( state , struct tevent_req * , num_parallel ) ;
if ( tevent_req_nomem ( state - > reqs , req ) ) {
return tevent_req_post ( req , ev ) ;
}
for ( i = 0 ; i < num_parallel ; i + + ) {
char * name ;
name = talloc_asprintf ( state , " %s%8.8d " , state - > base_name ,
state - > sent ) ;
if ( tevent_req_nomem ( name , req ) ) {
return tevent_req_post ( req , ev ) ;
}
state - > reqs [ i ] = torture_createdel_send (
state - > reqs , state - > ev , state - > cli , name ) ;
if ( tevent_req_nomem ( state - > reqs [ i ] , req ) ) {
return tevent_req_post ( req , ev ) ;
}
name = talloc_move ( state - > reqs [ i ] , & name ) ;
tevent_req_set_callback ( state - > reqs [ i ] ,
torture_createdels_done , req ) ;
state - > sent + = 1 ;
}
return req ;
}
static void torture_createdels_done ( struct tevent_req * subreq )
{
struct tevent_req * req = tevent_req_callback_data (
subreq , struct tevent_req ) ;
struct torture_createdels_state * state = tevent_req_data (
req , struct torture_createdels_state ) ;
size_t num_parallel = talloc_array_length ( state - > reqs ) ;
NTSTATUS status ;
char * name ;
int i ;
status = torture_createdel_recv ( subreq ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
DEBUG ( 10 , ( " torture_createdel_recv returned %s \n " ,
nt_errstr ( status ) ) ) ;
TALLOC_FREE ( subreq ) ;
tevent_req_nterror ( req , status ) ;
return ;
}
for ( i = 0 ; i < num_parallel ; i + + ) {
if ( subreq = = state - > reqs [ i ] ) {
break ;
}
}
if ( i = = num_parallel ) {
DEBUG ( 10 , ( " received something we did not send \n " ) ) ;
tevent_req_nterror ( req , NT_STATUS_INTERNAL_ERROR ) ;
return ;
}
TALLOC_FREE ( state - > reqs [ i ] ) ;
if ( state - > sent > = state - > num_files ) {
tevent_req_done ( req ) ;
return ;
}
name = talloc_asprintf ( state , " %s%8.8d " , state - > base_name ,
state - > sent ) ;
if ( tevent_req_nomem ( name , req ) ) {
return ;
}
state - > reqs [ i ] = torture_createdel_send ( state - > reqs , state - > ev ,
state - > cli , name ) ;
if ( tevent_req_nomem ( state - > reqs [ i ] , req ) ) {
return ;
}
name = talloc_move ( state - > reqs [ i ] , & name ) ;
tevent_req_set_callback ( state - > reqs [ i ] , torture_createdels_done , req ) ;
state - > sent + = 1 ;
}
static NTSTATUS torture_createdels_recv ( struct tevent_req * req )
{
return tevent_req_simple_recv_ntstatus ( req ) ;
}
struct swallow_notify_state {
struct tevent_context * ev ;
struct cli_state * cli ;
uint16_t fnum ;
uint32_t completion_filter ;
bool recursive ;
bool ( * fn ) ( uint32_t action , const char * name , void * priv ) ;
void * priv ;
} ;
static void swallow_notify_done ( struct tevent_req * subreq ) ;
static struct tevent_req * swallow_notify_send ( TALLOC_CTX * mem_ctx ,
struct tevent_context * ev ,
struct cli_state * cli ,
uint16_t fnum ,
uint32_t completion_filter ,
bool recursive ,
bool ( * fn ) ( uint32_t action ,
const char * name ,
void * priv ) ,
void * priv )
{
struct tevent_req * req , * subreq ;
struct swallow_notify_state * state ;
req = tevent_req_create ( mem_ctx , & state ,
struct swallow_notify_state ) ;
if ( req = = NULL ) {
return NULL ;
}
state - > ev = ev ;
state - > cli = cli ;
state - > fnum = fnum ;
state - > completion_filter = completion_filter ;
state - > recursive = recursive ;
state - > fn = fn ;
state - > priv = priv ;
subreq = cli_notify_send ( state , state - > ev , state - > cli , state - > fnum ,
0xffff , state - > completion_filter ,
state - > recursive ) ;
if ( tevent_req_nomem ( subreq , req ) ) {
return tevent_req_post ( req , ev ) ;
}
tevent_req_set_callback ( subreq , swallow_notify_done , req ) ;
return req ;
}
static void swallow_notify_done ( struct tevent_req * subreq )
{
struct tevent_req * req = tevent_req_callback_data (
subreq , struct tevent_req ) ;
struct swallow_notify_state * state = tevent_req_data (
req , struct swallow_notify_state ) ;
NTSTATUS status ;
uint32_t i , num_changes ;
struct notify_change * changes ;
status = cli_notify_recv ( subreq , state , & num_changes , & changes ) ;
TALLOC_FREE ( subreq ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
DEBUG ( 10 , ( " cli_notify_recv returned %s \n " ,
nt_errstr ( status ) ) ) ;
tevent_req_nterror ( req , status ) ;
return ;
}
for ( i = 0 ; i < num_changes ; i + + ) {
state - > fn ( changes [ i ] . action , changes [ i ] . name , state - > priv ) ;
}
TALLOC_FREE ( changes ) ;
subreq = cli_notify_send ( state , state - > ev , state - > cli , state - > fnum ,
0xffff , state - > completion_filter ,
state - > recursive ) ;
if ( tevent_req_nomem ( subreq , req ) ) {
return ;
}
tevent_req_set_callback ( subreq , swallow_notify_done , req ) ;
}
static bool print_notifies ( uint32_t action , const char * name , void * priv )
{
if ( DEBUGLEVEL > 5 ) {
d_printf ( " %d %s \n " , ( int ) action , name ) ;
}
return true ;
}
static void notify_bench_done ( struct tevent_req * req )
{
int * num_finished = ( int * ) tevent_req_callback_data_void ( req ) ;
* num_finished + = 1 ;
}
static bool run_notify_bench ( int dummy )
{
const char * dname = " \\ notify-bench " ;
struct tevent_context * ev ;
NTSTATUS status ;
uint16_t dnum ;
2010-01-03 12:58:01 +01:00
struct tevent_req * req1 ;
struct tevent_req * req2 = NULL ;
2009-10-12 17:29:45 +02:00
int i , num_unc_names ;
int num_finished = 0 ;
printf ( " starting notify-bench test \n " ) ;
if ( use_multishare_conn ) {
char * * unc_list ;
unc_list = file_lines_load ( multishare_conn_fname ,
& num_unc_names , 0 , NULL ) ;
if ( ! unc_list | | num_unc_names < = 0 ) {
d_printf ( " Failed to load unc names list from '%s' \n " ,
multishare_conn_fname ) ;
return false ;
}
TALLOC_FREE ( unc_list ) ;
} else {
num_unc_names = 1 ;
}
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2009-10-12 17:29:45 +02:00
if ( ev = = NULL ) {
d_printf ( " tevent_context_init failed \n " ) ;
return false ;
}
for ( i = 0 ; i < num_unc_names ; i + + ) {
struct cli_state * cli ;
char * base_fname ;
base_fname = talloc_asprintf ( talloc_tos ( ) , " %s \\ file%3.3d. " ,
dname , i ) ;
if ( base_fname = = NULL ) {
return false ;
}
if ( ! torture_open_connection ( & cli , i ) ) {
return false ;
}
status = cli_ntcreate ( cli , dname , 0 ,
MAXIMUM_ALLOWED_ACCESS ,
0 , FILE_SHARE_READ | FILE_SHARE_WRITE |
FILE_SHARE_DELETE ,
FILE_OPEN_IF , FILE_DIRECTORY_FILE , 0 ,
& dnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " Could not create %s: %s \n " , dname ,
nt_errstr ( status ) ) ;
return false ;
}
req1 = swallow_notify_send ( talloc_tos ( ) , ev , cli , dnum ,
FILE_NOTIFY_CHANGE_FILE_NAME |
FILE_NOTIFY_CHANGE_DIR_NAME |
FILE_NOTIFY_CHANGE_ATTRIBUTES |
FILE_NOTIFY_CHANGE_LAST_WRITE ,
false , print_notifies , NULL ) ;
if ( req1 = = NULL ) {
d_printf ( " Could not create notify request \n " ) ;
return false ;
}
req2 = torture_createdels_send ( talloc_tos ( ) , ev , cli ,
base_fname , 10 , torture_numops ) ;
if ( req2 = = NULL ) {
d_printf ( " Could not create createdels request \n " ) ;
return false ;
}
TALLOC_FREE ( base_fname ) ;
tevent_req_set_callback ( req2 , notify_bench_done ,
& num_finished ) ;
}
while ( num_finished < num_unc_names ) {
int ret ;
ret = tevent_loop_once ( ev ) ;
if ( ret ! = 0 ) {
d_printf ( " tevent_loop_once failed \n " ) ;
return false ;
}
}
if ( ! tevent_req_poll ( req2 , ev ) ) {
d_printf ( " tevent_req_poll failed \n " ) ;
}
status = torture_createdels_recv ( req2 ) ;
d_printf ( " torture_createdels_recv returned %s \n " , nt_errstr ( status ) ) ;
return true ;
}
2009-04-17 15:08:40 +02:00
static bool run_mangle1 ( int dummy )
{
struct cli_state * cli ;
const char * fname = " this_is_a_long_fname_to_be_mangled.txt " ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2009-04-17 15:08:40 +02:00
fstring alt_name ;
NTSTATUS status ;
2009-04-22 11:17:38 +02:00
time_t change_time , access_time , write_time ;
2012-04-05 14:53:08 +10:00
off_t size ;
2009-04-17 15:08:40 +02:00
uint16_t mode ;
2009-05-07 16:24:54 +02:00
printf ( " starting mangle1 test \n " ) ;
2009-04-17 15:08:40 +02:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2009-04-17 15:08:40 +02:00
2011-01-20 14:21:40 +01:00
status = cli_ntcreate ( cli , fname , 0 , GENERIC_ALL_ACCESS | DELETE_ACCESS ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OVERWRITE_IF ,
0 , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " open %s failed: %s \n " , fname , nt_errstr ( status ) ) ;
2009-04-17 15:08:40 +02:00
return false ;
}
cli_close ( cli , fnum ) ;
status = cli_qpathinfo_alt_name ( cli , fname , alt_name ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_qpathinfo_alt_name failed: %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
d_printf ( " alt_name: %s \n " , alt_name ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , alt_name , O_RDONLY , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
d_printf ( " cli_openx(%s) failed: %s \n " , alt_name ,
2011-01-20 14:21:40 +01:00
nt_errstr ( status ) ) ;
2009-04-17 15:08:40 +02:00
return false ;
}
cli_close ( cli , fnum ) ;
2010-07-26 08:34:35 +02:00
status = cli_qpathinfo1 ( cli , alt_name , & change_time , & access_time ,
& write_time , & size , & mode ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2010-07-25 13:19:34 +02:00
d_printf ( " cli_qpathinfo1(%s) failed: %s \n " , alt_name ,
2010-07-26 08:34:35 +02:00
nt_errstr ( status ) ) ;
2009-04-17 15:08:40 +02:00
return false ;
}
return true ;
}
2009-03-12 09:02:02 +01:00
static size_t null_source ( uint8_t * buf , size_t n , void * priv )
2008-12-19 23:41:19 +01:00
{
size_t * to_pull = ( size_t * ) priv ;
size_t thistime = * to_pull ;
thistime = MIN ( thistime , n ) ;
if ( thistime = = 0 ) {
return 0 ;
}
2009-03-12 09:02:02 +01:00
memset ( buf , 0 , thistime ) ;
2008-12-19 23:41:19 +01:00
* to_pull - = thistime ;
return thistime ;
}
static bool run_windows_write ( int dummy )
{
struct cli_state * cli1 ;
2009-04-30 15:26:43 -07:00
uint16_t fnum ;
2008-12-19 23:41:19 +01:00
int i ;
bool ret = false ;
const char * fname = " \\ writetest.txt " ;
2010-01-03 12:58:31 +01:00
struct timeval start_time ;
2008-12-19 23:41:19 +01:00
double seconds ;
double kbytes ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2008-12-19 23:41:19 +01:00
printf ( " starting windows_write test \n " ) ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
return False ;
}
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli1 , fname , O_RDWR | O_CREAT | O_EXCL , DENY_NONE , & fnum ) ;
2011-01-20 14:21:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " open failed (%s) \n " , nt_errstr ( status ) ) ;
2008-12-19 23:41:19 +01:00
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli1 - > conn , sockops ) ;
2008-12-19 23:41:19 +01:00
2010-01-03 12:58:31 +01:00
start_time = timeval_current ( ) ;
2008-12-19 23:41:19 +01:00
for ( i = 0 ; i < torture_numops ; i + + ) {
2011-04-02 11:46:30 +02:00
uint8_t c = 0 ;
2008-12-19 23:41:19 +01:00
off_t start = i * torture_blocksize ;
size_t to_pull = torture_blocksize - 1 ;
2011-04-02 11:46:30 +02:00
status = cli_writeall ( cli1 , fnum , 0 , & c ,
start + torture_blocksize - 1 , 1 , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_write failed: %s \n " , nt_errstr ( status ) ) ;
2008-12-19 23:41:19 +01:00
goto fail ;
}
status = cli_push ( cli1 , fnum , 0 , i * torture_blocksize , torture_blocksize ,
2009-03-12 09:02:02 +01:00
null_source , & to_pull ) ;
2008-12-19 23:41:19 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_push returned: %s \n " , nt_errstr ( status ) ) ;
goto fail ;
}
}
2010-01-03 12:58:31 +01:00
seconds = timeval_elapsed ( & start_time ) ;
2008-12-19 23:41:19 +01:00
kbytes = ( double ) torture_blocksize * torture_numops ;
kbytes / = 1024 ;
printf ( " Wrote %d kbytes in %.2f seconds: %d kb/sec \n " , ( int ) kbytes ,
( double ) seconds , ( int ) ( kbytes / seconds ) ) ;
ret = true ;
fail :
cli_close ( cli1 , fnum ) ;
2011-04-29 13:23:14 +10:00
cli_unlink ( cli1 , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2008-12-19 23:41:19 +01:00
torture_close_connection ( cli1 ) ;
return ret ;
}
2013-03-13 15:43:21 -07:00
static size_t calc_expected_return ( struct cli_state * cli , size_t len_requested )
{
size_t max_pdu = 0x1FFFF ;
if ( cli - > server_posix_capabilities & CIFS_UNIX_LARGE_READ_CAP ) {
max_pdu = 0xFFFFFF ;
}
if ( smb1cli_conn_signing_is_active ( cli - > conn ) ) {
max_pdu = 0x1FFFF ;
}
if ( smb1cli_conn_encryption_on ( cli - > conn ) ) {
max_pdu = CLI_BUFFER_SIZE ;
}
if ( ( len_requested & 0xFFFF0000 ) = = 0xFFFF0000 ) {
len_requested & = 0xFFFF ;
}
return MIN ( len_requested , max_pdu - ( MIN_SMB_SIZE + VWV ( 12 ) ) ) ;
}
static bool check_read_call ( struct cli_state * cli ,
uint16_t fnum ,
uint8_t * buf ,
size_t len_requested )
{
NTSTATUS status ;
struct tevent_req * subreq = NULL ;
ssize_t len_read = 0 ;
size_t len_expected = 0 ;
struct tevent_context * ev = NULL ;
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
if ( ev = = NULL ) {
return false ;
}
subreq = cli_read_andx_send ( talloc_tos ( ) ,
ev ,
cli ,
fnum ,
0 ,
len_requested ) ;
if ( ! tevent_req_poll_ntstatus ( subreq , ev , & status ) ) {
return false ;
}
status = cli_read_andx_recv ( subreq , & len_read , & buf ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_read_andx_recv failed: %s \n " , nt_errstr ( status ) ) ;
return false ;
}
TALLOC_FREE ( subreq ) ;
TALLOC_FREE ( ev ) ;
len_expected = calc_expected_return ( cli , len_requested ) ;
if ( len_expected > 0x10000 & & len_read = = 0x10000 ) {
/* Windows servers only return a max of 0x10000,
doesn ' t matter if you set CAP_LARGE_READX in
the client sessionsetupX call or not . */
d_printf ( " Windows server - returned 0x10000 on a read of 0x%x \n " ,
( unsigned int ) len_requested ) ;
} else if ( len_read ! = len_expected ) {
d_printf ( " read of 0x%x failed: got 0x%x, expected 0x%x \n " ,
( unsigned int ) len_requested ,
( unsigned int ) len_read ,
( unsigned int ) len_expected ) ;
return false ;
} else {
d_printf ( " Correct read reply. \n " ) ;
}
return true ;
}
/* Test large readX variants. */
static bool large_readx_tests ( struct cli_state * cli ,
uint16_t fnum ,
uint8_t * buf )
{
/* A read of 0xFFFF0001 should *always* return 1 byte. */
if ( check_read_call ( cli , fnum , buf , 0xFFFF0001 ) = = false ) {
return false ;
}
/* A read of 0x10000 should return 0x10000 bytes. */
if ( check_read_call ( cli , fnum , buf , 0x10000 ) = = false ) {
return false ;
}
/* A read of 0x10000 should return 0x10001 bytes. */
if ( check_read_call ( cli , fnum , buf , 0x10001 ) = = false ) {
return false ;
}
/* A read of 0x1FFFF - (MIN_SMB_SIZE + VWV(12) should return
the requested number of bytes . */
if ( check_read_call ( cli , fnum , buf , 0x1FFFF - ( MIN_SMB_SIZE + VWV ( 12 ) ) ) = = false ) {
return false ;
}
/* A read of 1MB should return 1MB bytes (on Samba). */
if ( check_read_call ( cli , fnum , buf , 0x100000 ) = = false ) {
return false ;
}
if ( check_read_call ( cli , fnum , buf , 0x20001 ) = = false ) {
return false ;
}
if ( check_read_call ( cli , fnum , buf , 0x22000001 ) = = false ) {
return false ;
}
if ( check_read_call ( cli , fnum , buf , 0xFFFE0001 ) = = false ) {
return false ;
}
return true ;
}
static bool run_large_readx ( int dummy )
{
uint8_t * buf = NULL ;
struct cli_state * cli1 = NULL ;
struct cli_state * cli2 = NULL ;
bool correct = false ;
const char * fname = " \\ large_readx.dat " ;
NTSTATUS status ;
uint16_t fnum1 = UINT16_MAX ;
uint32_t normal_caps = 0 ;
size_t file_size = 20 * 1024 * 1024 ;
TALLOC_CTX * frame = talloc_stackframe ( ) ;
size_t i ;
struct {
const char * name ;
enum smb_signing_setting signing_setting ;
enum protocol_types protocol ;
} runs [ ] = {
{
. name = " NT1 " ,
. signing_setting = SMB_SIGNING_IF_REQUIRED ,
. protocol = PROTOCOL_NT1 ,
} , {
. name = " NT1 - SIGNING_REQUIRED " ,
. signing_setting = SMB_SIGNING_REQUIRED ,
. protocol = PROTOCOL_NT1 ,
} ,
} ;
printf ( " starting large_readx test \n " ) ;
if ( ! torture_open_connection ( & cli1 , 0 ) ) {
goto out ;
}
normal_caps = smb1cli_conn_capabilities ( cli1 - > conn ) ;
if ( ! ( normal_caps & CAP_LARGE_READX ) ) {
d_printf ( " Server doesn't have CAP_LARGE_READX 0x%x \n " ,
( unsigned int ) normal_caps ) ;
goto out ;
}
/* Create a file of size 4MB. */
status = cli_ntcreate ( cli1 , fname , 0 , GENERIC_ALL_ACCESS ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OVERWRITE_IF ,
0 , 0 , & fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " open %s failed: %s \n " , fname , nt_errstr ( status ) ) ;
goto out ;
}
/* Write file_size bytes. */
buf = talloc_zero_array ( frame , uint8_t , file_size ) ;
if ( buf = = NULL ) {
goto out ;
}
status = cli_writeall ( cli1 ,
fnum1 ,
0 ,
buf ,
0 ,
file_size ,
NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_writeall failed: %s \n " , nt_errstr ( status ) ) ;
goto out ;
}
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_close failed: %s \n " , nt_errstr ( status ) ) ;
goto out ;
}
fnum1 = UINT16_MAX ;
for ( i = 0 ; i < ARRAY_SIZE ( runs ) ; i + + ) {
enum smb_signing_setting saved_signing_setting = signing_state ;
uint16_t fnum2 = - 1 ;
if ( do_encrypt & &
( runs [ i ] . signing_setting = = SMB_SIGNING_REQUIRED ) )
{
d_printf ( " skip[%u] - %s \n " , ( unsigned ) i , runs [ i ] . name ) ;
continue ;
}
d_printf ( " run[%u] - %s \n " , ( unsigned ) i , runs [ i ] . name ) ;
signing_state = runs [ i ] . signing_setting ;
cli2 = open_nbt_connection ( ) ;
signing_state = saved_signing_setting ;
if ( cli2 = = NULL ) {
goto out ;
}
status = smbXcli_negprot ( cli2 - > conn ,
cli2 - > timeout ,
runs [ i ] . protocol ,
runs [ i ] . protocol ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto out ;
}
status = cli_session_setup ( cli2 ,
username ,
password ,
strlen ( password ) + 1 ,
password ,
strlen ( password ) + 1 ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto out ;
}
status = cli_tree_connect ( cli2 ,
share ,
" ????? " ,
password ,
strlen ( password ) + 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto out ;
}
cli_set_timeout ( cli2 , 120000 ) ; /* set a really long timeout (2 minutes) */
normal_caps = smb1cli_conn_capabilities ( cli2 - > conn ) ;
if ( ! ( normal_caps & CAP_LARGE_READX ) ) {
d_printf ( " Server doesn't have CAP_LARGE_READX 0x%x \n " ,
( unsigned int ) normal_caps ) ;
goto out ;
}
if ( do_encrypt ) {
if ( force_cli_encryption ( cli2 , share ) = = false ) {
goto out ;
}
} else if ( SERVER_HAS_UNIX_CIFS ( cli2 ) ) {
uint16_t major , minor ;
uint32_t caplow , caphigh ;
status = cli_unix_extensions_version ( cli2 ,
& major , & minor ,
& caplow , & caphigh ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto out ;
}
}
status = cli_ntcreate ( cli2 , fname , 0 , FILE_READ_DATA ,
FILE_ATTRIBUTE_NORMAL , 0 , FILE_OPEN ,
0 , 0 , & fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " Second open %s failed: %s \n " , fname , nt_errstr ( status ) ) ;
goto out ;
}
/* All reads must return less than file_size bytes. */
if ( ! large_readx_tests ( cli2 , fnum2 , buf ) ) {
goto out ;
}
status = cli_close ( cli2 , fnum2 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_close failed: %s \n " , nt_errstr ( status ) ) ;
goto out ;
}
fnum2 = - 1 ;
if ( ! torture_close_connection ( cli2 ) ) {
goto out ;
}
cli2 = NULL ;
}
correct = true ;
printf ( " Success on large_readx test \n " ) ;
out :
if ( cli2 ) {
if ( ! torture_close_connection ( cli2 ) ) {
correct = false ;
}
}
if ( cli1 ) {
if ( fnum1 ! = UINT16_MAX ) {
status = cli_close ( cli1 , fnum1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " cli_close failed: %s \n " , nt_errstr ( status ) ) ;
}
fnum1 = UINT16_MAX ;
}
status = cli_unlink ( cli1 , fname ,
FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " unlink failed (%s) \n " , nt_errstr ( status ) ) ;
}
if ( ! torture_close_connection ( cli1 ) ) {
correct = false ;
}
}
TALLOC_FREE ( frame ) ;
printf ( " finished large_readx test \n " ) ;
return correct ;
}
2008-08-27 19:30:57 +02:00
static bool run_cli_echo ( int dummy )
{
struct cli_state * cli ;
NTSTATUS status ;
2009-03-29 00:52:22 +01:00
printf ( " starting cli_echo test \n " ) ;
2008-08-27 19:30:57 +02:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
return false ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2008-08-27 19:30:57 +02:00
2009-04-05 20:48:16 +02:00
status = cli_echo ( cli , 5 , data_blob_const ( " hello " , 5 ) ) ;
2008-08-27 19:30:57 +02:00
d_printf ( " cli_echo returned %s \n " , nt_errstr ( status ) ) ;
torture_close_connection ( cli ) ;
return NT_STATUS_IS_OK ( status ) ;
}
2009-04-16 16:21:31 -07:00
static bool run_uid_regression_test ( int dummy )
{
static struct cli_state * cli ;
int16_t old_vuid ;
2009-05-04 10:40:57 -07:00
int16_t old_cnum ;
2009-04-16 16:21:31 -07:00
bool correct = True ;
2010-01-03 13:03:42 +01:00
NTSTATUS status ;
2009-04-16 16:21:31 -07:00
printf ( " starting uid regression test \n " ) ;
if ( ! torture_open_connection ( & cli , 0 ) ) {
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2009-04-16 16:21:31 -07:00
/* Ok - now save then logoff our current user. */
2011-07-21 09:20:43 +02:00
old_vuid = cli_state_get_uid ( cli ) ;
2009-04-16 16:21:31 -07:00
2010-01-03 13:03:42 +01:00
status = cli_ulogoff ( cli ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-04-16 16:21:31 -07:00
d_printf ( " (%s) cli_ulogoff failed: %s \n " ,
2010-01-03 13:03:42 +01:00
__location__ , nt_errstr ( status ) ) ;
2009-04-16 16:21:31 -07:00
correct = false ;
goto out ;
}
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , old_vuid ) ;
2009-04-16 16:21:31 -07:00
/* Try an operation. */
2010-09-08 17:55:12 +02:00
status = cli_mkdir ( cli , " \\ uid_reg_test " ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
d_printf ( " (%s) cli_mkdir succeeded \n " ,
__location__ ) ;
correct = false ;
goto out ;
} else {
/* Should be bad uid. */
2011-07-27 21:51:45 +02:00
if ( ! check_error ( __LINE__ , status , ERRSRV , ERRbaduid ,
NT_STATUS_USER_SESSION_DELETED ) ) {
2010-09-08 17:55:12 +02:00
correct = false ;
goto out ;
2009-04-16 16:21:31 -07:00
}
2009-05-04 10:40:57 -07:00
}
2011-07-19 16:25:52 +02:00
old_cnum = cli_state_get_tid ( cli ) ;
2009-05-04 10:40:57 -07:00
/* Now try a SMBtdis with the invald vuid set to zero. */
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , 0 ) ;
2009-05-04 10:40:57 -07:00
/* This should succeed. */
2010-01-03 18:46:57 +01:00
status = cli_tdis ( cli ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2010-09-08 17:55:12 +02:00
d_printf ( " First tdis with invalid vuid should succeed. \n " ) ;
2009-05-04 10:40:57 -07:00
} else {
2010-09-08 17:55:12 +02:00
d_printf ( " First tdis failed (%s) \n " , nt_errstr ( status ) ) ;
correct = false ;
goto out ;
2009-05-04 10:40:57 -07:00
}
2011-07-21 09:20:43 +02:00
cli_state_set_uid ( cli , old_vuid ) ;
2011-07-19 16:25:52 +02:00
cli_state_set_tid ( cli , old_cnum ) ;
2009-05-04 10:40:57 -07:00
/* This should fail. */
2010-01-03 18:46:57 +01:00
status = cli_tdis ( cli ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
2010-09-08 17:55:12 +02:00
d_printf ( " Second tdis with invalid vuid should fail - succeeded instead !. \n " ) ;
correct = false ;
goto out ;
2009-05-04 10:40:57 -07:00
} else {
/* Should be bad tid. */
2011-07-27 21:51:45 +02:00
if ( ! check_error ( __LINE__ , status , ERRSRV , ERRinvnid ,
2009-05-04 10:40:57 -07:00
NT_STATUS_NETWORK_NAME_DELETED ) ) {
2010-09-08 17:55:12 +02:00
correct = false ;
goto out ;
2009-05-04 10:40:57 -07:00
}
2009-04-16 16:21:31 -07:00
}
cli_rmdir ( cli , " \\ uid_reg_test " ) ;
out :
2009-05-04 10:40:57 -07:00
cli_shutdown ( cli ) ;
2009-04-16 16:21:31 -07:00
return correct ;
}
2009-05-14 16:03:31 -07:00
static const char * illegal_chars = " * \\ /?<>| \" : " ;
static char force_shortname_chars [ ] = " +,.[];= \177 " ;
2010-10-29 11:56:51 -07:00
static NTSTATUS shortname_del_fn ( const char * mnt , struct file_info * finfo ,
2010-07-27 10:59:55 +02:00
const char * mask , void * state )
2009-05-14 16:03:31 -07:00
{
struct cli_state * pcli = ( struct cli_state * ) state ;
fstring fname ;
2010-10-29 11:56:51 -07:00
NTSTATUS status = NT_STATUS_OK ;
2009-05-14 16:03:31 -07:00
slprintf ( fname , sizeof ( fname ) , " \\ shortname \\ %s " , finfo - > name ) ;
if ( strcmp ( finfo - > name , " . " ) = = 0 | | strcmp ( finfo - > name , " .. " ) = = 0 )
2010-10-29 11:56:51 -07:00
return NT_STATUS_OK ;
2009-05-14 16:03:31 -07:00
2011-04-29 11:57:02 +10:00
if ( finfo - > mode & FILE_ATTRIBUTE_DIRECTORY ) {
2010-10-29 11:56:51 -07:00
status = cli_rmdir ( pcli , fname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-14 16:03:31 -07:00
printf ( " del_fn: failed to rmdir %s \n , " , fname ) ;
2010-10-29 11:56:51 -07:00
}
2009-05-14 16:03:31 -07:00
} else {
2011-04-29 13:23:14 +10:00
status = cli_unlink ( pcli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2010-10-29 11:56:51 -07:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-14 16:03:31 -07:00
printf ( " del_fn: failed to unlink %s \n , " , fname ) ;
2010-10-29 11:56:51 -07:00
}
2009-05-14 16:03:31 -07:00
}
2010-10-29 11:56:51 -07:00
return status ;
2009-05-14 16:03:31 -07:00
}
struct sn_state {
2010-08-02 19:22:22 +02:00
int matched ;
2009-05-14 16:03:31 -07:00
int i ;
bool val ;
} ;
2010-10-29 11:56:51 -07:00
static NTSTATUS shortname_list_fn ( const char * mnt , struct file_info * finfo ,
2010-07-27 10:59:55 +02:00
const char * name , void * state )
2009-05-14 16:03:31 -07:00
{
struct sn_state * s = ( struct sn_state * ) state ;
int i = s - > i ;
#if 0
printf ( " shortname list: i = %d, name = |%s|, shortname = |%s| \n " ,
i , finfo - > name , finfo - > short_name ) ;
# endif
if ( strchr ( force_shortname_chars , i ) ) {
2011-07-06 18:57:27 +02:00
if ( ! finfo - > short_name ) {
2009-05-14 16:03:31 -07:00
/* Shortname not created when it should be. */
2009-05-14 16:30:11 -07:00
d_printf ( " (%s) ERROR: Shortname was not created for file %s containing %d \n " ,
__location__ , finfo - > name , i ) ;
2009-05-14 16:03:31 -07:00
s - > val = true ;
}
2011-07-06 18:57:27 +02:00
} else if ( finfo - > short_name ) {
2009-05-14 16:03:31 -07:00
/* Shortname created when it should not be. */
d_printf ( " (%s) ERROR: Shortname %s was created for file %s \n " ,
__location__ , finfo - > short_name , finfo - > name ) ;
s - > val = true ;
}
2010-08-02 19:22:22 +02:00
s - > matched + = 1 ;
2010-10-29 11:56:51 -07:00
return NT_STATUS_OK ;
2009-05-14 16:03:31 -07:00
}
static bool run_shortname_test ( int dummy )
{
static struct cli_state * cli ;
bool correct = True ;
int i ;
struct sn_state s ;
2012-03-30 10:57:51 -07:00
char fname [ 40 ] ;
2011-01-20 14:21:40 +01:00
NTSTATUS status ;
2009-05-14 16:03:31 -07:00
printf ( " starting shortname test \n " ) ;
if ( ! torture_open_connection ( & cli , 0 ) ) {
return False ;
}
2012-05-19 16:58:28 +02:00
smbXcli_conn_set_sockopt ( cli - > conn , sockops ) ;
2009-05-14 16:03:31 -07:00
cli_list ( cli , " \\ shortname \\ * " , 0 , shortname_del_fn , cli ) ;
2011-04-29 11:57:02 +10:00
cli_list ( cli , " \\ shortname \\ * " , FILE_ATTRIBUTE_DIRECTORY , shortname_del_fn , cli ) ;
2009-05-14 16:03:31 -07:00
cli_rmdir ( cli , " \\ shortname " ) ;
2011-01-20 14:21:40 +01:00
status = cli_mkdir ( cli , " \\ shortname " ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-14 16:03:31 -07:00
d_printf ( " (%s) cli_mkdir of \\ shortname failed: %s \n " ,
2011-01-20 14:21:40 +01:00
__location__ , nt_errstr ( status ) ) ;
2009-05-14 16:03:31 -07:00
correct = false ;
goto out ;
}
2012-03-29 17:13:07 -07:00
if ( strlcpy ( fname , " \\ shortname \\ " , sizeof ( fname ) ) > = sizeof ( fname ) ) {
correct = false ;
goto out ;
}
if ( strlcat ( fname , " test .txt " , sizeof ( fname ) ) > = sizeof ( fname ) ) {
correct = false ;
goto out ;
}
2009-05-14 16:03:31 -07:00
s . val = false ;
for ( i = 32 ; i < 128 ; i + + ) {
uint16_t fnum = ( uint16_t ) - 1 ;
s . i = i ;
if ( strchr ( illegal_chars , i ) ) {
continue ;
}
fname [ 15 ] = i ;
status = cli_ntcreate ( cli , fname , 0 , GENERIC_ALL_ACCESS , FILE_ATTRIBUTE_NORMAL ,
FILE_SHARE_READ | FILE_SHARE_WRITE , FILE_OVERWRITE_IF , 0 , 0 , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " (%s) cli_nt_create of %s failed: %s \n " ,
2011-01-20 14:21:40 +01:00
__location__ , fname , nt_errstr ( status ) ) ;
2009-05-14 16:03:31 -07:00
correct = false ;
goto out ;
}
cli_close ( cli , fnum ) ;
2010-08-02 19:22:22 +02:00
s . matched = 0 ;
2011-07-07 16:56:05 +02:00
status = cli_list ( cli , " \\ shortname \\ test*.* " , 0 ,
shortname_list_fn , & s ) ;
2010-08-02 19:22:22 +02:00
if ( s . matched ! = 1 ) {
2009-05-14 16:03:31 -07:00
d_printf ( " (%s) failed to list %s: %s \n " ,
2011-07-07 16:56:05 +02:00
__location__ , fname , nt_errstr ( status ) ) ;
2009-05-14 16:03:31 -07:00
correct = false ;
goto out ;
}
2011-01-20 14:21:40 +01:00
status = cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2009-05-14 16:03:31 -07:00
d_printf ( " (%s) failed to delete %s: %s \n " ,
2011-01-20 14:21:40 +01:00
__location__ , fname , nt_errstr ( status ) ) ;
2009-05-14 16:03:31 -07:00
correct = false ;
goto out ;
}
if ( s . val ) {
correct = false ;
goto out ;
}
}
out :
cli_list ( cli , " \\ shortname \\ * " , 0 , shortname_del_fn , cli ) ;
2011-04-29 11:57:02 +10:00
cli_list ( cli , " \\ shortname \\ * " , FILE_ATTRIBUTE_DIRECTORY , shortname_del_fn , cli ) ;
2009-05-14 16:03:31 -07:00
cli_rmdir ( cli , " \\ shortname " ) ;
torture_close_connection ( cli ) ;
return correct ;
}
2009-06-20 18:43:58 +02:00
static void pagedsearch_cb ( struct tevent_req * req )
{
int rc ;
struct tldap_message * msg ;
char * dn ;
rc = tldap_search_paged_recv ( req , talloc_tos ( ) , & msg ) ;
if ( rc ! = TLDAP_SUCCESS ) {
d_printf ( " tldap_search_paged_recv failed: %s \n " ,
tldap_err2string ( rc ) ) ;
return ;
}
if ( tldap_msg_type ( msg ) ! = TLDAP_RES_SEARCH_ENTRY ) {
TALLOC_FREE ( msg ) ;
return ;
}
if ( ! tldap_entry_dn ( msg , & dn ) ) {
d_printf ( " tldap_entry_dn failed \n " ) ;
return ;
}
d_printf ( " %s \n " , dn ) ;
TALLOC_FREE ( msg ) ;
}
2009-06-19 13:06:02 +02:00
static bool run_tldap ( int dummy )
{
struct tldap_context * ld ;
int fd , rc ;
NTSTATUS status ;
struct sockaddr_storage addr ;
2009-06-20 18:43:58 +02:00
struct tevent_context * ev ;
struct tevent_req * req ;
char * basedn ;
2010-03-07 20:20:02 -05:00
const char * filter ;
2009-06-19 13:06:02 +02:00
2009-07-28 11:51:58 -07:00
if ( ! resolve_name ( host , & addr , 0 , false ) ) {
2009-06-19 13:06:02 +02:00
d_printf ( " could not find host %s \n " , host ) ;
return false ;
}
status = open_socket_out ( & addr , 389 , 9999 , & fd ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_printf ( " open_socket_out failed: %s \n " , nt_errstr ( status ) ) ;
return false ;
}
ld = tldap_context_create ( talloc_tos ( ) , fd ) ;
if ( ld = = NULL ) {
close ( fd ) ;
d_printf ( " tldap_context_create failed \n " ) ;
return false ;
}
rc = tldap_fetch_rootdse ( ld ) ;
if ( rc ! = TLDAP_SUCCESS ) {
d_printf ( " tldap_fetch_rootdse failed: %s \n " ,
tldap_errstr ( talloc_tos ( ) , ld , rc ) ) ;
return false ;
}
2009-06-20 18:43:58 +02:00
basedn = tldap_talloc_single_attribute (
tldap_rootdse ( ld ) , " defaultNamingContext " , talloc_tos ( ) ) ;
if ( basedn = = NULL ) {
d_printf ( " no defaultNamingContext \n " ) ;
return false ;
}
d_printf ( " defaultNamingContext: %s \n " , basedn ) ;
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2009-06-20 18:43:58 +02:00
if ( ev = = NULL ) {
d_printf ( " tevent_context_init failed \n " ) ;
return false ;
}
req = tldap_search_paged_send ( talloc_tos ( ) , ev , ld , basedn ,
TLDAP_SCOPE_SUB , " (objectclass=*) " ,
NULL , 0 , 0 ,
NULL , 0 , NULL , 0 , 0 , 0 , 0 , 5 ) ;
if ( req = = NULL ) {
d_printf ( " tldap_search_paged_send failed \n " ) ;
return false ;
}
tevent_req_set_callback ( req , pagedsearch_cb , NULL ) ;
tevent_req_poll ( req , ev ) ;
TALLOC_FREE ( req ) ;
2010-03-07 20:20:02 -05:00
/* test search filters against rootDSE */
filter = " (&(|(name=samba)(nextRid<=10000000)(usnChanged>=10)(samba~=ambas)(!(name=s*m*a))) "
" (|(name:=samba)(name:dn:2.5.13.5:=samba)(:dn:2.5.13.5:=samba)(!(name=*samba)))) " ;
rc = tldap_search ( ld , " " , TLDAP_SCOPE_BASE , filter ,
NULL , 0 , 0 , NULL , 0 , NULL , 0 , 0 , 0 , 0 ,
talloc_tos ( ) , NULL , NULL ) ;
if ( rc ! = TLDAP_SUCCESS ) {
d_printf ( " tldap_search with complex filter failed: %s \n " ,
tldap_errstr ( talloc_tos ( ) , ld , rc ) ) ;
return false ;
}
2009-06-19 13:06:02 +02:00
TALLOC_FREE ( ld ) ;
return true ;
}
2010-02-01 18:49:50 -08:00
/* Torture test to ensure no regression of :
https : //bugzilla.samba.org/show_bug.cgi?id=7084
*/
static bool run_dir_createtime ( int dummy )
{
struct cli_state * cli ;
const char * dname = " \\ testdir " ;
const char * fname = " \\ testdir \\ testfile " ;
NTSTATUS status ;
struct timespec create_time ;
struct timespec create_time1 ;
uint16_t fnum ;
bool ret = false ;
if ( ! torture_open_connection ( & cli , 0 ) ) {
return false ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2010-02-01 18:49:50 -08:00
cli_rmdir ( cli , dname ) ;
status = cli_mkdir ( cli , dname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " mkdir failed: %s \n " , nt_errstr ( status ) ) ;
goto out ;
}
2010-07-26 09:27:11 +02:00
status = cli_qpathinfo2 ( cli , dname , & create_time , NULL , NULL , NULL ,
NULL , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2010-02-01 18:49:50 -08:00
printf ( " cli_qpathinfo2 returned %s \n " ,
nt_errstr ( status ) ) ;
goto out ;
}
/* Sleep 3 seconds, then create a file. */
sleep ( 3 ) ;
2011-12-03 21:13:08 -08:00
status = cli_openx ( cli , fname , O_RDWR | O_CREAT | O_EXCL ,
2010-02-01 18:49:50 -08:00
DENY_NONE , & fnum ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-03 21:13:08 -08:00
printf ( " cli_openx failed: %s \n " , nt_errstr ( status ) ) ;
2010-02-01 18:49:50 -08:00
goto out ;
}
2010-07-26 09:27:11 +02:00
status = cli_qpathinfo2 ( cli , dname , & create_time1 , NULL , NULL , NULL ,
NULL , NULL , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
2010-02-01 18:49:50 -08:00
printf ( " cli_qpathinfo2 (2) returned %s \n " ,
nt_errstr ( status ) ) ;
goto out ;
}
if ( timespec_compare ( & create_time1 , & create_time ) ) {
printf ( " run_dir_createtime: create time was updated (error) \n " ) ;
} else {
printf ( " run_dir_createtime: create time was not updated (correct) \n " ) ;
ret = true ;
}
out :
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , fname , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2010-02-01 18:49:50 -08:00
cli_rmdir ( cli , dname ) ;
if ( ! torture_close_connection ( cli ) ) {
ret = false ;
}
return ret ;
}
2009-07-02 11:56:33 +02:00
static bool run_streamerror ( int dummy )
{
struct cli_state * cli ;
const char * dname = " \\ testdir " ;
const char * streamname =
" testdir:{4c8cc155-6c1e-11d1-8e41-00c04fb9386d}:$DATA " ;
NTSTATUS status ;
time_t change_time , access_time , write_time ;
2012-04-05 14:53:08 +10:00
off_t size ;
2009-07-02 11:56:33 +02:00
uint16_t mode , fnum ;
bool ret = true ;
if ( ! torture_open_connection ( & cli , 0 ) ) {
return false ;
}
2011-04-29 13:23:14 +10:00
cli_unlink ( cli , " \\ testdir \\ * " , FILE_ATTRIBUTE_SYSTEM | FILE_ATTRIBUTE_HIDDEN ) ;
2009-07-02 11:56:33 +02:00
cli_rmdir ( cli , dname ) ;
status = cli_mkdir ( cli , dname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " mkdir failed: %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-11-16 16:21:13 +01:00
status = cli_qpathinfo1 ( cli , streamname , & change_time , & access_time ,
& write_time , & size , & mode ) ;
2009-07-02 11:56:33 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_OBJECT_NAME_NOT_FOUND ) ) {
printf ( " pathinfo returned %s, expected "
" NT_STATUS_OBJECT_NAME_NOT_FOUND \n " ,
nt_errstr ( status ) ) ;
ret = false ;
}
status = cli_ntcreate ( cli , streamname , 0x16 ,
FILE_READ_DATA | FILE_READ_EA |
FILE_READ_ATTRIBUTES | READ_CONTROL_ACCESS ,
FILE_ATTRIBUTE_NORMAL , FILE_SHARE_READ ,
FILE_OPEN , 0 , 0 , & fnum ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_OBJECT_NAME_NOT_FOUND ) ) {
printf ( " ntcreate returned %s, expected "
" NT_STATUS_OBJECT_NAME_NOT_FOUND \n " ,
nt_errstr ( status ) ) ;
ret = false ;
}
cli_rmdir ( cli , dname ) ;
return ret ;
}
2007-10-18 17:40:25 -07:00
static bool run_local_substitute ( int dummy )
2006-07-11 18:01:26 +00:00
{
2007-10-07 13:36:56 +00:00
bool ok = true ;
ok & = subst_test ( " %U " , " bla " , " " , - 1 , - 1 , " bla " ) ;
ok & = subst_test ( " %u%U " , " bla " , " " , - 1 , - 1 , " blabla " ) ;
ok & = subst_test ( " %g " , " " , " " , - 1 , - 1 , " NO_GROUP " ) ;
ok & = subst_test ( " %G " , " " , " " , - 1 , - 1 , " NO_GROUP " ) ;
ok & = subst_test ( " %g " , " " , " " , - 1 , 0 , gidtoname ( 0 ) ) ;
ok & = subst_test ( " %G " , " " , " " , - 1 , 0 , gidtoname ( 0 ) ) ;
ok & = subst_test ( " %D%u " , " u " , " dom " , - 1 , 0 , " domu " ) ;
ok & = subst_test ( " %i %I " , " " , " " , - 1 , - 1 , " 0.0.0.0 0.0.0.0 " ) ;
2006-07-11 18:01:26 +00:00
/* Different captialization rules in sub_basic... */
2007-10-07 13:36:56 +00:00
ok & = ( strcmp ( talloc_sub_basic ( talloc_tos ( ) , " BLA " , " dom " , " %U%D " ) ,
" blaDOM " ) = = 0 ) ;
2006-07-11 18:01:26 +00:00
2007-10-07 13:36:56 +00:00
return ok ;
2006-07-11 18:01:26 +00:00
}
2009-07-10 17:29:22 +02:00
static bool run_local_base64 ( int dummy )
{
int i ;
bool ret = true ;
for ( i = 1 ; i < 2000 ; i + + ) {
DATA_BLOB blob1 , blob2 ;
char * b64 ;
blob1 . data = talloc_array ( talloc_tos ( ) , uint8_t , i ) ;
blob1 . length = i ;
generate_random_buffer ( blob1 . data , blob1 . length ) ;
b64 = base64_encode_data_blob ( talloc_tos ( ) , blob1 ) ;
if ( b64 = = NULL ) {
d_fprintf ( stderr , " base64_encode_data_blob failed "
" for %d bytes \n " , i ) ;
ret = false ;
}
blob2 = base64_decode_data_blob ( b64 ) ;
TALLOC_FREE ( b64 ) ;
if ( data_blob_cmp ( & blob1 , & blob2 ) ) {
d_fprintf ( stderr , " data_blob_cmp failed for %d "
" bytes \n " , i ) ;
ret = false ;
}
TALLOC_FREE ( blob1 . data ) ;
data_blob_free ( & blob2 ) ;
}
return ret ;
}
2007-10-18 17:40:25 -07:00
static bool run_local_gencache ( int dummy )
2006-09-09 21:05:51 +00:00
{
char * val ;
time_t tm ;
2007-08-28 12:40:01 +00:00
DATA_BLOB blob ;
2013-09-04 08:44:50 +02:00
char v ;
2006-09-09 21:05:51 +00:00
if ( ! gencache_set ( " foo " , " bar " , time ( NULL ) + 1000 ) ) {
d_printf ( " %s: gencache_set() failed \n " , __location__ ) ;
return False ;
}
2013-09-04 08:56:23 +02:00
if ( ! gencache_get ( " foo " , NULL , NULL , NULL ) ) {
2009-11-02 13:01:58 +01:00
d_printf ( " %s: gencache_get() failed \n " , __location__ ) ;
return False ;
}
2013-09-04 08:57:59 +02:00
if ( ! gencache_get ( " foo " , talloc_tos ( ) , & val , & tm ) ) {
2006-09-09 21:05:51 +00:00
d_printf ( " %s: gencache_get() failed \n " , __location__ ) ;
return False ;
}
if ( strcmp ( val , " bar " ) ! = 0 ) {
d_printf ( " %s: gencache_get() returned %s, expected %s \n " ,
__location__ , val , " bar " ) ;
2013-09-04 08:57:59 +02:00
TALLOC_FREE ( val ) ;
2006-09-09 21:05:51 +00:00
return False ;
}
2013-09-04 08:57:59 +02:00
TALLOC_FREE ( val ) ;
2006-09-09 21:05:51 +00:00
if ( ! gencache_del ( " foo " ) ) {
d_printf ( " %s: gencache_del() failed \n " , __location__ ) ;
return False ;
}
if ( gencache_del ( " foo " ) ) {
d_printf ( " %s: second gencache_del() succeeded \n " ,
__location__ ) ;
return False ;
}
2009-04-22 11:51:03 +02:00
2013-09-04 08:57:59 +02:00
if ( gencache_get ( " foo " , talloc_tos ( ) , & val , & tm ) ) {
2006-09-09 21:05:51 +00:00
d_printf ( " %s: gencache_get() on deleted entry "
" succeeded \n " , __location__ ) ;
return False ;
}
2008-10-13 05:20:26 +02:00
blob = data_blob_string_const_null ( " bar " ) ;
2009-07-10 17:36:18 +02:00
tm = time ( NULL ) + 60 ;
2007-08-28 12:40:01 +00:00
if ( ! gencache_set_data_blob ( " foo " , & blob , tm ) ) {
d_printf ( " %s: gencache_set_data_blob() failed \n " , __location__ ) ;
return False ;
}
2013-09-04 08:57:59 +02:00
if ( ! gencache_get_data_blob ( " foo " , talloc_tos ( ) , & blob , NULL , NULL ) ) {
2007-08-28 12:40:01 +00:00
d_printf ( " %s: gencache_get_data_blob() failed \n " , __location__ ) ;
return False ;
}
if ( strcmp ( ( const char * ) blob . data , " bar " ) ! = 0 ) {
d_printf ( " %s: gencache_get_data_blob() returned %s, expected %s \n " ,
__location__ , ( const char * ) blob . data , " bar " ) ;
data_blob_free ( & blob ) ;
return False ;
}
data_blob_free ( & blob ) ;
if ( ! gencache_del ( " foo " ) ) {
d_printf ( " %s: gencache_del() failed \n " , __location__ ) ;
return False ;
}
if ( gencache_del ( " foo " ) ) {
d_printf ( " %s: second gencache_del() succeeded \n " ,
__location__ ) ;
return False ;
}
2013-09-04 08:57:59 +02:00
if ( gencache_get_data_blob ( " foo " , talloc_tos ( ) , & blob , NULL , NULL ) ) {
2007-08-28 12:40:01 +00:00
d_printf ( " %s: gencache_get_data_blob() on deleted entry "
" succeeded \n " , __location__ ) ;
return False ;
}
2013-09-04 08:44:50 +02:00
v = 1 ;
blob . data = ( uint8_t * ) & v ;
blob . length = sizeof ( v ) ;
if ( ! gencache_set_data_blob ( " blob " , & blob , tm ) ) {
d_printf ( " %s: gencache_set_data_blob() failed \n " ,
__location__ ) ;
return false ;
}
2013-09-04 08:57:59 +02:00
if ( gencache_get ( " blob " , talloc_tos ( ) , & val , & tm ) ) {
2013-09-04 08:44:50 +02:00
d_printf ( " %s: gencache_get succeeded \n " , __location__ ) ;
return false ;
}
2006-09-09 21:05:51 +00:00
return True ;
}
2007-11-09 23:43:24 +01:00
static bool rbt_testval ( struct db_context * db , const char * key ,
const char * value )
{
struct db_record * rec ;
TDB_DATA data = string_tdb_data ( value ) ;
bool ret = false ;
NTSTATUS status ;
2011-08-25 10:59:06 +02:00
TDB_DATA dbvalue ;
2007-11-09 23:43:24 +01:00
2011-08-25 10:59:06 +02:00
rec = dbwrap_fetch_locked ( db , db , string_tdb_data ( key ) ) ;
2007-11-09 23:43:24 +01:00
if ( rec = = NULL ) {
d_fprintf ( stderr , " fetch_locked failed \n " ) ;
goto done ;
}
2011-08-25 10:59:06 +02:00
status = dbwrap_record_store ( rec , data , 0 ) ;
2007-11-09 23:43:24 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
d_fprintf ( stderr , " store failed: %s \n " , nt_errstr ( status ) ) ;
goto done ;
}
TALLOC_FREE ( rec ) ;
2011-08-25 10:59:06 +02:00
rec = dbwrap_fetch_locked ( db , db , string_tdb_data ( key ) ) ;
2007-11-09 23:43:24 +01:00
if ( rec = = NULL ) {
d_fprintf ( stderr , " second fetch_locked failed \n " ) ;
goto done ;
}
2011-08-25 10:59:06 +02:00
dbvalue = dbwrap_record_get_value ( rec ) ;
if ( ( dbvalue . dsize ! = data . dsize )
| | ( memcmp ( dbvalue . dptr , data . dptr , data . dsize ) ! = 0 ) ) {
2007-11-09 23:43:24 +01:00
d_fprintf ( stderr , " Got wrong data back \n " ) ;
goto done ;
}
ret = true ;
done :
TALLOC_FREE ( rec ) ;
return ret ;
}
static bool run_local_rbtree ( int dummy )
{
struct db_context * db ;
bool ret = false ;
int i ;
db = db_open_rbt ( NULL ) ;
if ( db = = NULL ) {
d_fprintf ( stderr , " db_open_rbt failed \n " ) ;
return false ;
}
for ( i = 0 ; i < 1000 ; i + + ) {
char * key , * value ;
2009-01-02 11:38:24 -08:00
if ( asprintf ( & key , " key%ld " , random ( ) ) = = - 1 ) {
goto done ;
}
if ( asprintf ( & value , " value%ld " , random ( ) ) = = - 1 ) {
SAFE_FREE ( key ) ;
goto done ;
}
2007-11-09 23:43:24 +01:00
if ( ! rbt_testval ( db , key , value ) ) {
SAFE_FREE ( key ) ;
SAFE_FREE ( value ) ;
goto done ;
}
SAFE_FREE ( value ) ;
2009-01-02 11:38:24 -08:00
if ( asprintf ( & value , " value%ld " , random ( ) ) = = - 1 ) {
SAFE_FREE ( key ) ;
goto done ;
}
2007-11-09 23:43:24 +01:00
if ( ! rbt_testval ( db , key , value ) ) {
SAFE_FREE ( key ) ;
SAFE_FREE ( value ) ;
goto done ;
}
SAFE_FREE ( key ) ;
SAFE_FREE ( value ) ;
}
ret = true ;
done :
TALLOC_FREE ( db ) ;
return ret ;
}
2011-03-30 17:30:08 +11:00
/*
local test for character set functions
This is a very simple test for the functionality in convert_string_error ( )
*/
static bool run_local_convert_string ( int dummy )
{
TALLOC_CTX * tmp_ctx = talloc_new ( NULL ) ;
const char * test_strings [ 2 ] = { " March " , " M \303 \244 rz " } ;
char dst [ 7 ] ;
int i ;
for ( i = 0 ; i < 2 ; i + + ) {
const char * str = test_strings [ i ] ;
int len = strlen ( str ) ;
size_t converted_size ;
bool ret ;
memset ( dst , ' X ' , sizeof ( dst ) ) ;
/* first try with real source length */
ret = convert_string_error ( CH_UNIX , CH_UTF8 ,
str , len ,
dst , sizeof ( dst ) ,
& converted_size ) ;
if ( ret ! = true ) {
d_fprintf ( stderr , " Failed to convert '%s' to CH_DISPLAY \n " , str ) ;
goto failed ;
}
if ( converted_size ! = len ) {
d_fprintf ( stderr , " Converted size of '%s' should be %d - got %d \n " ,
str , len , ( int ) converted_size ) ;
goto failed ;
}
if ( strncmp ( str , dst , converted_size ) ! = 0 ) {
d_fprintf ( stderr , " Expected '%s' to match '%s' \n " , str , dst ) ;
goto failed ;
}
if ( strlen ( str ) ! = converted_size ) {
d_fprintf ( stderr , " Expected '%s' length %d - got %d \n " , str ,
( int ) strlen ( str ) , ( int ) converted_size ) ;
goto failed ;
}
if ( dst [ converted_size ] ! = ' X ' ) {
d_fprintf ( stderr , " Expected no termination of '%s' \n " , dst ) ;
goto failed ;
}
/* now with srclen==-1, this causes the nul to be
* converted too */
ret = convert_string_error ( CH_UNIX , CH_UTF8 ,
str , - 1 ,
dst , sizeof ( dst ) ,
& converted_size ) ;
if ( ret ! = true ) {
d_fprintf ( stderr , " Failed to convert '%s' to CH_DISPLAY \n " , str ) ;
goto failed ;
}
if ( converted_size ! = len + 1 ) {
d_fprintf ( stderr , " Converted size of '%s' should be %d - got %d \n " ,
str , len , ( int ) converted_size ) ;
goto failed ;
}
if ( strncmp ( str , dst , converted_size ) ! = 0 ) {
d_fprintf ( stderr , " Expected '%s' to match '%s' \n " , str , dst ) ;
goto failed ;
}
if ( len + 1 ! = converted_size ) {
d_fprintf ( stderr , " Expected '%s' length %d - got %d \n " , str ,
len + 1 , ( int ) converted_size ) ;
goto failed ;
}
if ( dst [ converted_size ] ! = ' X ' ) {
d_fprintf ( stderr , " Expected no termination of '%s' \n " , dst ) ;
goto failed ;
}
}
TALLOC_FREE ( tmp_ctx ) ;
return true ;
failed :
TALLOC_FREE ( tmp_ctx ) ;
return false ;
}
2009-08-16 10:44:06 +02:00
struct talloc_dict_test {
int content ;
} ;
static int talloc_dict_traverse_fn ( DATA_BLOB key , void * data , void * priv )
{
int * count = ( int * ) priv ;
* count + = 1 ;
return 0 ;
}
static bool run_local_talloc_dict ( int dummy )
{
struct talloc_dict * dict ;
struct talloc_dict_test * t ;
2012-03-13 08:21:15 +01:00
int key , count , res ;
2012-03-13 08:22:03 +01:00
bool ok ;
2009-08-16 10:44:06 +02:00
dict = talloc_dict_init ( talloc_tos ( ) ) ;
if ( dict = = NULL ) {
return false ;
}
t = talloc ( talloc_tos ( ) , struct talloc_dict_test ) ;
if ( t = = NULL ) {
return false ;
}
key = 1 ;
t - > content = 1 ;
2012-03-13 08:22:03 +01:00
ok = talloc_dict_set ( dict , data_blob_const ( & key , sizeof ( key ) ) , & t ) ;
if ( ! ok ) {
2009-08-16 10:44:06 +02:00
return false ;
}
count = 0 ;
2012-03-13 08:21:15 +01:00
res = talloc_dict_traverse ( dict , talloc_dict_traverse_fn , & count ) ;
if ( res = = - 1 ) {
2009-08-16 10:44:06 +02:00
return false ;
}
if ( count ! = 1 ) {
return false ;
}
2012-03-13 08:21:15 +01:00
if ( count ! = res ) {
return false ;
}
2009-08-16 10:44:06 +02:00
TALLOC_FREE ( dict ) ;
return true ;
}
2010-02-20 21:31:16 +01:00
static bool run_local_string_to_sid ( int dummy ) {
2010-01-23 14:55:11 +01:00
struct dom_sid sid ;
2010-02-20 21:31:16 +01:00
if ( string_to_sid ( & sid , " S--1-5-32-545 " ) ) {
2010-02-20 21:07:08 +01:00
printf ( " allowing S--1-5-32-545 \n " ) ;
2010-01-23 14:55:11 +01:00
return false ;
}
2010-02-20 21:31:16 +01:00
if ( string_to_sid ( & sid , " S-1-5-32-+545 " ) ) {
2010-02-20 21:07:08 +01:00
printf ( " allowing S-1-5-32-+545 \n " ) ;
2010-01-23 14:55:11 +01:00
return false ;
}
2010-02-20 21:31:16 +01:00
if ( string_to_sid ( & sid , " S-1-2-3-4-5-6-7-8-9-0-1-2-3-4-5-6-7-8-9-0 " ) ) {
2010-02-20 21:07:08 +01:00
printf ( " allowing S-1-2-3-4-5-6-7-8-9-0-1-2-3-4-5-6-7-8-9-0 \n " ) ;
2010-01-23 14:55:11 +01:00
return false ;
}
2010-02-20 21:31:16 +01:00
if ( string_to_sid ( & sid , " S-1-5-32-545-abc " ) ) {
printf ( " allowing S-1-5-32-545-abc \n " ) ;
return false ;
}
2013-07-31 10:38:22 -04:00
if ( string_to_sid ( & sid , " S-300-5-32-545 " ) ) {
printf ( " allowing S-300-5-32-545 \n " ) ;
return false ;
}
if ( string_to_sid ( & sid , " S-1-0xfffffffffffffe-32-545 " ) ) {
printf ( " allowing S-1-0xfffffffffffffe-32-545 \n " ) ;
return false ;
}
if ( string_to_sid ( & sid , " S-1-0xffffffffffff-5294967297-545 " ) ) {
printf ( " allowing S-1-0xffffffffffff-5294967297-545 \n " ) ;
return false ;
}
if ( ! string_to_sid ( & sid , " S-1-0xfffffffffffe-32-545 " ) ) {
printf ( " could not parse S-1-0xfffffffffffe-32-545 \n " ) ;
return false ;
}
2010-02-20 21:31:16 +01:00
if ( ! string_to_sid ( & sid , " S-1-5-32-545 " ) ) {
printf ( " could not parse S-1-5-32-545 \n " ) ;
return false ;
}
2010-08-26 15:48:50 +02:00
if ( ! dom_sid_equal ( & sid , & global_sid_Builtin_Users ) ) {
2010-02-20 21:31:16 +01:00
printf ( " mis-parsed S-1-5-32-545 as %s \n " ,
sid_string_tos ( & sid ) ) ;
return false ;
}
2010-01-23 14:55:11 +01:00
return true ;
}
2013-09-04 08:22:08 +02:00
static bool sid_to_string_test ( const char * expected ) {
2013-07-31 10:38:23 -04:00
char * str ;
bool res = true ;
struct dom_sid sid ;
if ( ! string_to_sid ( & sid , expected ) ) {
printf ( " could not parse %s \n " , expected ) ;
return false ;
}
str = dom_sid_string ( NULL , & sid ) ;
if ( strcmp ( str , expected ) ) {
printf ( " Comparison failed (%s != %s) \n " , str , expected ) ;
res = false ;
}
TALLOC_FREE ( str ) ;
return res ;
}
static bool run_local_sid_to_string ( int dummy ) {
if ( ! sid_to_string_test ( " S-1-0xffffffffffff-1-1-1-1-1-1-1-1-1-1-1-1 " ) )
return false ;
if ( ! sid_to_string_test ( " S-1-545 " ) )
return false ;
if ( ! sid_to_string_test ( " S-255-3840-1-1-1-1 " ) )
return false ;
return true ;
}
2010-09-04 14:13:31 +10:00
static bool run_local_binary_to_sid ( int dummy ) {
struct dom_sid * sid = talloc ( NULL , struct dom_sid ) ;
static const char good_binary_sid [ ] = {
0x1 , /* revision number */
15 , /* num auths */
0x1 , 0x1 , 0x1 , 0x1 , 0x1 , 0x1 , /* id_auth */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[0] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[1] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[2] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[3] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[4] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[5] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[6] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[7] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[8] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[9] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[10] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[11] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[12] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[13] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[14] */
} ;
static const char long_binary_sid [ ] = {
0x1 , /* revision number */
15 , /* num auths */
0x1 , 0x1 , 0x1 , 0x1 , 0x1 , 0x1 , /* id_auth */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[0] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[1] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[2] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[3] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[4] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[5] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[6] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[7] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[8] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[9] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[10] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[11] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[12] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[13] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[14] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[15] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[16] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[17] */
} ;
static const char long_binary_sid2 [ ] = {
0x1 , /* revision number */
32 , /* num auths */
0x1 , 0x1 , 0x1 , 0x1 , 0x1 , 0x1 , /* id_auth */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[0] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[1] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[2] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[3] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[4] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[5] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[6] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[7] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[8] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[9] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[10] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[11] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[12] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[13] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[14] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[15] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[16] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[17] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[18] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[19] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[20] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[21] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[22] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[23] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[24] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[25] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[26] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[27] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[28] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[29] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[30] */
0x1 , 0x1 , 0x1 , 0x1 , /* auth[31] */
} ;
if ( ! sid_parse ( good_binary_sid , sizeof ( good_binary_sid ) , sid ) ) {
return false ;
}
if ( sid_parse ( long_binary_sid2 , sizeof ( long_binary_sid2 ) , sid ) ) {
return false ;
}
if ( sid_parse ( long_binary_sid , sizeof ( long_binary_sid ) , sid ) ) {
return false ;
}
return true ;
}
2009-07-08 14:08:04 -07:00
/* Split a path name into filename and stream name components. Canonicalise
* such that an implicit $ DATA token is always explicit .
*
* The " specification " of this function can be found in the
* run_local_stream_name ( ) function in torture . c , I ' ve tried those
* combinations against a W2k3 server .
*/
static NTSTATUS split_ntfs_stream_name ( TALLOC_CTX * mem_ctx , const char * fname ,
char * * pbase , char * * pstream )
{
char * base = NULL ;
char * stream = NULL ;
char * sname ; /* stream name */
const char * stype ; /* stream type */
DEBUG ( 10 , ( " split_ntfs_stream_name called for [%s] \n " , fname ) ) ;
sname = strchr_m ( fname , ' : ' ) ;
if ( lp_posix_pathnames ( ) | | ( sname = = NULL ) ) {
if ( pbase ! = NULL ) {
base = talloc_strdup ( mem_ctx , fname ) ;
NT_STATUS_HAVE_NO_MEMORY ( base ) ;
}
goto done ;
}
if ( pbase ! = NULL ) {
base = talloc_strndup ( mem_ctx , fname , PTR_DIFF ( sname , fname ) ) ;
NT_STATUS_HAVE_NO_MEMORY ( base ) ;
}
sname + = 1 ;
stype = strchr_m ( sname , ' : ' ) ;
if ( stype = = NULL ) {
sname = talloc_strdup ( mem_ctx , sname ) ;
stype = " $DATA " ;
}
else {
2011-05-13 20:21:30 +02:00
if ( strcasecmp_m ( stype , " :$DATA " ) ! = 0 ) {
2009-07-08 14:08:04 -07:00
/*
* If there is an explicit stream type , so far we only
* allow $ DATA . Is there anything else allowed ? - - vl
*/
DEBUG ( 10 , ( " [%s] is an invalid stream type \n " , stype ) ) ;
TALLOC_FREE ( base ) ;
return NT_STATUS_OBJECT_NAME_INVALID ;
}
sname = talloc_strndup ( mem_ctx , sname , PTR_DIFF ( stype , sname ) ) ;
stype + = 1 ;
}
if ( sname = = NULL ) {
TALLOC_FREE ( base ) ;
return NT_STATUS_NO_MEMORY ;
}
if ( sname [ 0 ] = = ' \0 ' ) {
/*
* no stream name , so no stream
*/
goto done ;
}
if ( pstream ! = NULL ) {
stream = talloc_asprintf ( mem_ctx , " %s:%s " , sname , stype ) ;
if ( stream = = NULL ) {
TALLOC_FREE ( sname ) ;
TALLOC_FREE ( base ) ;
return NT_STATUS_NO_MEMORY ;
}
/*
* upper - case the type field
*/
2012-08-08 15:35:28 -07:00
( void ) strupper_m ( strchr_m ( stream , ' : ' ) + 1 ) ;
2009-07-08 14:08:04 -07:00
}
done :
if ( pbase ! = NULL ) {
* pbase = base ;
}
if ( pstream ! = NULL ) {
* pstream = stream ;
}
return NT_STATUS_OK ;
}
2008-01-19 23:10:09 +01:00
static bool test_stream_name ( const char * fname , const char * expected_base ,
const char * expected_stream ,
NTSTATUS expected_status )
{
NTSTATUS status ;
char * base = NULL ;
char * stream = NULL ;
status = split_ntfs_stream_name ( talloc_tos ( ) , fname , & base , & stream ) ;
if ( ! NT_STATUS_EQUAL ( status , expected_status ) ) {
goto error ;
}
if ( ! NT_STATUS_IS_OK ( status ) ) {
return true ;
}
if ( base = = NULL ) goto error ;
if ( strcmp ( expected_base , base ) ! = 0 ) goto error ;
if ( ( expected_stream ! = NULL ) & & ( stream = = NULL ) ) goto error ;
if ( ( expected_stream = = NULL ) & & ( stream ! = NULL ) ) goto error ;
if ( ( stream ! = NULL ) & & ( strcmp ( expected_stream , stream ) ! = 0 ) )
goto error ;
TALLOC_FREE ( base ) ;
TALLOC_FREE ( stream ) ;
return true ;
error :
2010-09-08 17:54:29 +02:00
d_fprintf ( stderr , " Do test_stream(%s, %s, %s, %s) \n " ,
2008-01-19 23:10:09 +01:00
fname , expected_base ? expected_base : " <NULL> " ,
expected_stream ? expected_stream : " <NULL> " ,
nt_errstr ( expected_status ) ) ;
d_fprintf ( stderr , " -> base=%s, stream=%s, status=%s \n " ,
base ? base : " <NULL> " , stream ? stream : " <NULL> " ,
nt_errstr ( status ) ) ;
TALLOC_FREE ( base ) ;
TALLOC_FREE ( stream ) ;
return false ;
}
static bool run_local_stream_name ( int dummy )
{
bool ret = true ;
ret & = test_stream_name (
" bla " , " bla " , NULL , NT_STATUS_OK ) ;
ret & = test_stream_name (
" bla::$DATA " , " bla " , NULL , NT_STATUS_OK ) ;
ret & = test_stream_name (
" bla:blub: " , " bla " , NULL , NT_STATUS_OBJECT_NAME_INVALID ) ;
ret & = test_stream_name (
" bla:: " , NULL , NULL , NT_STATUS_OBJECT_NAME_INVALID ) ;
ret & = test_stream_name (
" bla::123 " , " bla " , NULL , NT_STATUS_OBJECT_NAME_INVALID ) ;
ret & = test_stream_name (
" bla:$DATA " , " bla " , " $DATA:$DATA " , NT_STATUS_OK ) ;
ret & = test_stream_name (
" bla:x:$DATA " , " bla " , " x:$DATA " , NT_STATUS_OK ) ;
ret & = test_stream_name (
" bla:x " , " bla " , " x:$DATA " , NT_STATUS_OK ) ;
return ret ;
}
2007-12-18 09:41:03 +01:00
static bool data_blob_equal ( DATA_BLOB a , DATA_BLOB b )
{
if ( a . length ! = b . length ) {
printf ( " a.length=%d != b.length=%d \n " ,
( int ) a . length , ( int ) b . length ) ;
return false ;
}
if ( memcmp ( a . data , b . data , a . length ) ! = 0 ) {
printf ( " a.data and b.data differ \n " ) ;
return false ;
}
return true ;
}
static bool run_local_memcache ( int dummy )
{
struct memcache * cache ;
DATA_BLOB k1 , k2 ;
DATA_BLOB d1 , d2 , d3 ;
DATA_BLOB v1 , v2 , v3 ;
2008-11-13 23:50:19 +01:00
TALLOC_CTX * mem_ctx ;
char * str1 , * str2 ;
size_t size1 , size2 ;
bool ret = false ;
2012-01-05 13:12:26 +01:00
cache = memcache_init ( NULL , sizeof ( void * ) = = 8 ? 200 : 100 ) ;
2007-12-18 09:41:03 +01:00
if ( cache = = NULL ) {
printf ( " memcache_init failed \n " ) ;
return false ;
}
d1 = data_blob_const ( " d1 " , 2 ) ;
d2 = data_blob_const ( " d2 " , 2 ) ;
d3 = data_blob_const ( " d3 " , 2 ) ;
k1 = data_blob_const ( " d1 " , 2 ) ;
k2 = data_blob_const ( " d2 " , 2 ) ;
memcache_add ( cache , STAT_CACHE , k1 , d1 ) ;
memcache_add ( cache , GETWD_CACHE , k2 , d2 ) ;
if ( ! memcache_lookup ( cache , STAT_CACHE , k1 , & v1 ) ) {
printf ( " could not find k1 \n " ) ;
return false ;
}
if ( ! data_blob_equal ( d1 , v1 ) ) {
return false ;
}
if ( ! memcache_lookup ( cache , GETWD_CACHE , k2 , & v2 ) ) {
printf ( " could not find k2 \n " ) ;
return false ;
}
if ( ! data_blob_equal ( d2 , v2 ) ) {
return false ;
}
memcache_add ( cache , STAT_CACHE , k1 , d3 ) ;
if ( ! memcache_lookup ( cache , STAT_CACHE , k1 , & v3 ) ) {
printf ( " could not find replaced k1 \n " ) ;
return false ;
}
if ( ! data_blob_equal ( d3 , v3 ) ) {
return false ;
}
memcache_add ( cache , GETWD_CACHE , k1 , d1 ) ;
if ( memcache_lookup ( cache , GETWD_CACHE , k2 , & v2 ) ) {
printf ( " Did find k2, should have been purged \n " ) ;
return false ;
}
TALLOC_FREE ( cache ) ;
2008-11-13 23:50:19 +01:00
cache = memcache_init ( NULL , 0 ) ;
mem_ctx = talloc_init ( " foo " ) ;
str1 = talloc_strdup ( mem_ctx , " string1 " ) ;
str2 = talloc_strdup ( mem_ctx , " string2 " ) ;
memcache_add_talloc ( cache , SINGLETON_CACHE_TALLOC ,
2008-11-14 13:42:54 +01:00
data_blob_string_const ( " torture " ) , & str1 ) ;
2008-11-13 23:50:19 +01:00
size1 = talloc_total_size ( cache ) ;
memcache_add_talloc ( cache , SINGLETON_CACHE_TALLOC ,
2008-11-14 13:42:54 +01:00
data_blob_string_const ( " torture " ) , & str2 ) ;
2008-11-13 23:50:19 +01:00
size2 = talloc_total_size ( cache ) ;
printf ( " size1=%d, size2=%d \n " , ( int ) size1 , ( int ) size2 ) ;
if ( size2 > size1 ) {
printf ( " memcache leaks memory! \n " ) ;
goto fail ;
}
ret = true ;
fail :
TALLOC_FREE ( cache ) ;
return ret ;
2007-12-18 09:41:03 +01:00
}
2009-03-16 20:38:11 +01:00
static void wbclient_done ( struct tevent_req * req )
2008-12-28 17:43:18 +01:00
{
2009-02-04 09:07:36 +01:00
wbcErr wbc_err ;
2008-12-28 17:43:18 +01:00
struct winbindd_response * wb_resp ;
2009-03-16 20:38:11 +01:00
int * i = ( int * ) tevent_req_callback_data_void ( req ) ;
2008-12-28 17:43:18 +01:00
2009-02-04 09:07:36 +01:00
wbc_err = wb_trans_recv ( req , req , & wb_resp ) ;
2008-12-28 17:43:18 +01:00
TALLOC_FREE ( req ) ;
* i + = 1 ;
2009-02-04 09:07:36 +01:00
d_printf ( " wb_trans_recv %d returned %s \n " , * i , wbcErrorString ( wbc_err ) ) ;
2008-12-28 17:43:18 +01:00
}
static bool run_local_wbclient ( int dummy )
{
2013-02-18 09:55:58 +01:00
struct tevent_context * ev ;
2008-12-28 17:43:18 +01:00
struct wb_context * * wb_ctx ;
struct winbindd_request wb_req ;
bool result = false ;
int i , j ;
BlockSignals ( True , SIGPIPE ) ;
2013-12-13 14:55:45 +01:00
ev = tevent_context_init ( talloc_tos ( ) ) ;
2008-12-28 17:43:18 +01:00
if ( ev = = NULL ) {
goto fail ;
}
2012-04-04 14:29:33 +02:00
wb_ctx = talloc_array ( ev , struct wb_context * , torture_nprocs ) ;
2008-12-28 17:43:18 +01:00
if ( wb_ctx = = NULL ) {
goto fail ;
}
ZERO_STRUCT ( wb_req ) ;
wb_req . cmd = WINBINDD_PING ;
2012-04-04 14:29:33 +02:00
d_printf ( " torture_nprocs=%d, numops=%d \n " , ( int ) torture_nprocs , ( int ) torture_numops ) ;
2009-05-19 23:07:36 +02:00
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2009-04-21 09:58:42 +02:00
wb_ctx [ i ] = wb_context_init ( ev , NULL ) ;
2008-12-28 17:43:18 +01:00
if ( wb_ctx [ i ] = = NULL ) {
goto fail ;
}
2009-05-19 23:07:36 +02:00
for ( j = 0 ; j < torture_numops ; j + + ) {
2009-03-16 20:38:11 +01:00
struct tevent_req * req ;
2008-12-28 17:43:18 +01:00
req = wb_trans_send ( ev , ev , wb_ctx [ i ] ,
( j % 2 ) = = 0 , & wb_req ) ;
if ( req = = NULL ) {
goto fail ;
}
2009-03-16 20:38:11 +01:00
tevent_req_set_callback ( req , wbclient_done , & i ) ;
2008-12-28 17:43:18 +01:00
}
}
i = 0 ;
2012-04-04 14:29:33 +02:00
while ( i < torture_nprocs * torture_numops ) {
2010-05-25 15:23:55 -04:00
tevent_loop_once ( ev ) ;
2008-12-28 17:43:18 +01:00
}
result = true ;
fail :
TALLOC_FREE ( ev ) ;
return result ;
}
2009-04-26 00:01:43 +02:00
static void getaddrinfo_finished ( struct tevent_req * req )
{
char * name = ( char * ) tevent_req_callback_data_void ( req ) ;
struct addrinfo * ainfo ;
int res ;
res = getaddrinfo_recv ( req , & ainfo ) ;
if ( res ! = 0 ) {
d_printf ( " gai(%s) returned %s \n " , name , gai_strerror ( res ) ) ;
return ;
}
d_printf ( " gai(%s) succeeded \n " , name ) ;
freeaddrinfo ( ainfo ) ;
}
static bool run_getaddrinfo_send ( int dummy )
{
TALLOC_CTX * frame = talloc_stackframe ( ) ;
struct fncall_context * ctx ;
struct tevent_context * ev ;
bool result = false ;
const char * names [ 4 ] = { " www.samba.org " , " notfound.samba.org " ,
" www.slashdot.org " , " heise.de " } ;
struct tevent_req * reqs [ 4 ] ;
int i ;
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( frame ) ;
2009-04-26 00:01:43 +02:00
if ( ev = = NULL ) {
goto fail ;
}
ctx = fncall_context_init ( frame , 4 ) ;
for ( i = 0 ; i < ARRAY_SIZE ( names ) ; i + + ) {
reqs [ i ] = getaddrinfo_send ( frame , ev , ctx , names [ i ] , NULL ,
NULL ) ;
if ( reqs [ i ] = = NULL ) {
goto fail ;
}
tevent_req_set_callback ( reqs [ i ] , getaddrinfo_finished ,
2011-05-05 16:44:27 -07:00
discard_const_p ( void , names [ i ] ) ) ;
2009-04-26 00:01:43 +02:00
}
for ( i = 0 ; i < ARRAY_SIZE ( reqs ) ; i + + ) {
tevent_loop_once ( ev ) ;
}
result = true ;
fail :
TALLOC_FREE ( frame ) ;
return result ;
}
2009-12-11 15:37:52 +01:00
static bool dbtrans_inc ( struct db_context * db )
{
struct db_record * rec ;
2012-01-06 16:42:08 +01:00
uint32_t val ;
2009-12-11 15:37:52 +01:00
bool ret = false ;
NTSTATUS status ;
2011-08-25 10:59:06 +02:00
TDB_DATA value ;
2009-12-11 15:37:52 +01:00
2011-08-25 10:59:06 +02:00
rec = dbwrap_fetch_locked ( db , db , string_term_tdb_data ( " transtest " ) ) ;
2009-12-11 15:37:52 +01:00
if ( rec = = NULL ) {
printf ( __location__ " fetch_lock failed \n " ) ;
return false ;
}
2011-08-25 10:59:06 +02:00
value = dbwrap_record_get_value ( rec ) ;
if ( value . dsize ! = sizeof ( uint32_t ) ) {
2009-12-11 15:37:52 +01:00
printf ( __location__ " value.dsize = %d \n " ,
2011-08-25 10:59:06 +02:00
( int ) value . dsize ) ;
2009-12-11 15:37:52 +01:00
goto fail ;
}
2012-01-06 16:42:08 +01:00
memcpy ( & val , value . dptr , sizeof ( val ) ) ;
val + = 1 ;
2009-12-11 15:37:52 +01:00
2012-01-06 16:42:08 +01:00
status = dbwrap_record_store (
rec , make_tdb_data ( ( uint8_t * ) & val , sizeof ( val ) ) , 0 ) ;
2009-12-11 15:37:52 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( __location__ " store failed: %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
ret = true ;
fail :
TALLOC_FREE ( rec ) ;
return ret ;
}
static bool run_local_dbtrans ( int dummy )
{
struct db_context * db ;
struct db_record * rec ;
NTSTATUS status ;
uint32_t initial ;
int res ;
2011-08-25 10:59:06 +02:00
TDB_DATA value ;
2009-12-11 15:37:52 +01:00
db = db_open ( talloc_tos ( ) , " transtest.tdb " , 0 , TDB_DEFAULT ,
2014-01-27 14:49:12 +01:00
O_RDWR | O_CREAT , 0600 , DBWRAP_LOCK_ORDER_1 ,
DBWRAP_FLAG_NONE ) ;
2009-12-11 15:37:52 +01:00
if ( db = = NULL ) {
printf ( " Could not open transtest.db \n " ) ;
return false ;
}
2011-08-25 10:59:06 +02:00
res = dbwrap_transaction_start ( db ) ;
2011-06-20 18:40:33 +09:30
if ( res ! = 0 ) {
2009-12-11 15:37:52 +01:00
printf ( __location__ " transaction_start failed \n " ) ;
return false ;
}
2011-08-25 10:59:06 +02:00
rec = dbwrap_fetch_locked ( db , db , string_term_tdb_data ( " transtest " ) ) ;
2009-12-11 15:37:52 +01:00
if ( rec = = NULL ) {
printf ( __location__ " fetch_lock failed \n " ) ;
return false ;
}
2011-08-25 10:59:06 +02:00
value = dbwrap_record_get_value ( rec ) ;
if ( value . dptr = = NULL ) {
2009-12-11 15:37:52 +01:00
initial = 0 ;
2011-08-25 10:59:06 +02:00
status = dbwrap_record_store (
2009-12-11 15:37:52 +01:00
rec , make_tdb_data ( ( uint8_t * ) & initial ,
sizeof ( initial ) ) ,
0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( __location__ " store returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
}
TALLOC_FREE ( rec ) ;
2011-08-25 10:59:06 +02:00
res = dbwrap_transaction_commit ( db ) ;
2011-06-20 18:40:33 +09:30
if ( res ! = 0 ) {
2009-12-11 15:37:52 +01:00
printf ( __location__ " transaction_commit failed \n " ) ;
return false ;
}
while ( true ) {
uint32_t val , val2 ;
int i ;
2011-08-25 10:59:06 +02:00
res = dbwrap_transaction_start ( db ) ;
2011-06-20 18:40:33 +09:30
if ( res ! = 0 ) {
2009-12-11 15:37:52 +01:00
printf ( __location__ " transaction_start failed \n " ) ;
break ;
}
2012-06-14 20:39:27 +02:00
status = dbwrap_fetch_uint32_bystring ( db , " transtest " , & val ) ;
2011-10-06 21:07:27 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( __location__ " dbwrap_fetch_uint32 failed: %s \n " ,
nt_errstr ( status ) ) ;
2009-12-11 15:37:52 +01:00
break ;
}
for ( i = 0 ; i < 10 ; i + + ) {
if ( ! dbtrans_inc ( db ) ) {
return false ;
}
}
2012-06-14 20:39:27 +02:00
status = dbwrap_fetch_uint32_bystring ( db , " transtest " , & val2 ) ;
2011-10-06 21:07:27 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( __location__ " dbwrap_fetch_uint32 failed: %s \n " ,
nt_errstr ( status ) ) ;
2009-12-11 15:37:52 +01:00
break ;
}
if ( val2 ! = val + 10 ) {
printf ( __location__ " val=%d, val2=%d \n " ,
( int ) val , ( int ) val2 ) ;
break ;
}
printf ( " val2=%d \r " , val2 ) ;
2011-08-25 10:59:06 +02:00
res = dbwrap_transaction_commit ( db ) ;
2011-06-20 18:40:33 +09:30
if ( res ! = 0 ) {
2009-12-11 15:37:52 +01:00
printf ( __location__ " transaction_commit failed \n " ) ;
break ;
}
}
TALLOC_FREE ( db ) ;
return true ;
}
2009-04-26 00:01:43 +02:00
2010-06-10 09:50:32 +02:00
/*
* Just a dummy test to be run under a debugger . There ' s no real way
* to inspect the tevent_select specific function from outside of
* tevent_select . c .
*/
static bool run_local_tevent_select ( int dummy )
{
struct tevent_context * ev ;
struct tevent_fd * fd1 , * fd2 ;
bool result = false ;
ev = tevent_context_init_byname ( NULL , " select " ) ;
if ( ev = = NULL ) {
d_fprintf ( stderr , " tevent_context_init_byname failed \n " ) ;
goto fail ;
}
fd1 = tevent_add_fd ( ev , ev , 2 , 0 , NULL , NULL ) ;
if ( fd1 = = NULL ) {
d_fprintf ( stderr , " tevent_add_fd failed \n " ) ;
goto fail ;
}
fd2 = tevent_add_fd ( ev , ev , 3 , 0 , NULL , NULL ) ;
if ( fd2 = = NULL ) {
d_fprintf ( stderr , " tevent_add_fd failed \n " ) ;
goto fail ;
}
TALLOC_FREE ( fd2 ) ;
fd2 = tevent_add_fd ( ev , ev , 1 , 0 , NULL , NULL ) ;
if ( fd2 = = NULL ) {
d_fprintf ( stderr , " tevent_add_fd failed \n " ) ;
goto fail ;
}
result = true ;
fail :
TALLOC_FREE ( ev ) ;
return result ;
}
2012-02-03 03:27:19 +01:00
static bool run_local_hex_encode_buf ( int dummy )
{
char buf [ 17 ] ;
uint8_t src [ 8 ] ;
int i ;
for ( i = 0 ; i < sizeof ( src ) ; i + + ) {
src [ i ] = i ;
}
hex_encode_buf ( buf , src , sizeof ( src ) ) ;
if ( strcmp ( buf , " 0001020304050607 " ) ! = 0 ) {
return false ;
}
hex_encode_buf ( buf , NULL , 0 ) ;
if ( buf [ 0 ] ! = ' \0 ' ) {
return false ;
}
return true ;
}
2012-05-21 14:29:11 -07:00
static const char * remove_duplicate_addrs2_test_strings_vector [ ] = {
" 0.0.0.0 " ,
" ::0 " ,
" 1.2.3.1 " ,
" 0.0.0.0 " ,
" 0.0.0.0 " ,
" 1.2.3.2 " ,
" 1.2.3.3 " ,
" 1.2.3.4 " ,
" 1.2.3.5 " ,
" ::0 " ,
" 1.2.3.6 " ,
" 1.2.3.7 " ,
" ::0 " ,
" ::0 " ,
" ::0 " ,
" 1.2.3.8 " ,
" 1.2.3.9 " ,
" 1.2.3.10 " ,
" 1.2.3.11 " ,
" 1.2.3.12 " ,
" 1.2.3.13 " ,
" 1001:1111:1111:1000:0:1111:1111:1111 " ,
" 1.2.3.1 " ,
" 1.2.3.2 " ,
" 1.2.3.3 " ,
" 1.2.3.12 " ,
" ::0 " ,
" ::0 "
} ;
static const char * remove_duplicate_addrs2_test_strings_result [ ] = {
" 1.2.3.1 " ,
" 1.2.3.2 " ,
" 1.2.3.3 " ,
" 1.2.3.4 " ,
" 1.2.3.5 " ,
" 1.2.3.6 " ,
" 1.2.3.7 " ,
" 1.2.3.8 " ,
" 1.2.3.9 " ,
" 1.2.3.10 " ,
" 1.2.3.11 " ,
" 1.2.3.12 " ,
" 1.2.3.13 " ,
" 1001:1111:1111:1000:0:1111:1111:1111 "
} ;
static bool run_local_remove_duplicate_addrs2 ( int dummy )
{
struct ip_service test_vector [ 28 ] ;
int count , i ;
/* Construct the sockaddr_storage test vector. */
for ( i = 0 ; i < 28 ; i + + ) {
struct addrinfo hints ;
struct addrinfo * res = NULL ;
int ret ;
memset ( & hints , ' \0 ' , sizeof ( hints ) ) ;
hints . ai_flags = AI_NUMERICHOST ;
ret = getaddrinfo ( remove_duplicate_addrs2_test_strings_vector [ i ] ,
NULL ,
& hints ,
& res ) ;
if ( ret ) {
fprintf ( stderr , " getaddrinfo failed on [%s] \n " ,
remove_duplicate_addrs2_test_strings_vector [ i ] ) ;
return false ;
}
memset ( & test_vector [ i ] , ' \0 ' , sizeof ( test_vector [ i ] ) ) ;
memcpy ( & test_vector [ i ] . ss ,
res - > ai_addr ,
res - > ai_addrlen ) ;
freeaddrinfo ( res ) ;
}
count = remove_duplicate_addrs2 ( test_vector , i ) ;
if ( count ! = 14 ) {
fprintf ( stderr , " count wrong (%d) should be 14 \n " ,
count ) ;
return false ;
}
for ( i = 0 ; i < count ; i + + ) {
char addr [ INET6_ADDRSTRLEN ] ;
print_sockaddr ( addr , sizeof ( addr ) , & test_vector [ i ] . ss ) ;
if ( strcmp ( addr , remove_duplicate_addrs2_test_strings_result [ i ] ) ! = 0 ) {
fprintf ( stderr , " mismatch on [%d] [%s] [%s] \n " ,
i ,
addr ,
remove_duplicate_addrs2_test_strings_result [ i ] ) ;
return false ;
}
}
printf ( " run_local_remove_duplicate_addrs2: success \n " ) ;
return true ;
}
2012-10-02 15:44:41 +02:00
static bool run_local_tdb_opener ( int dummy )
{
TDB_CONTEXT * t ;
unsigned v = 0 ;
while ( 1 ) {
t = tdb_open ( " test.tdb " , 1000 , TDB_CLEAR_IF_FIRST ,
O_RDWR | O_CREAT , 0755 ) ;
if ( t = = NULL ) {
perror ( " tdb_open failed " ) ;
return false ;
}
tdb_close ( t ) ;
v + = 1 ;
printf ( " \r %u " , v ) ;
}
return true ;
}
static bool run_local_tdb_writer ( int dummy )
{
TDB_CONTEXT * t ;
unsigned v = 0 ;
TDB_DATA val ;
t = tdb_open ( " test.tdb " , 1000 , 0 , O_RDWR | O_CREAT , 0755 ) ;
if ( t = = 0 ) {
perror ( " tdb_open failed " ) ;
return 1 ;
}
val . dptr = ( uint8_t * ) & v ;
val . dsize = sizeof ( v ) ;
while ( 1 ) {
TDB_DATA data ;
int ret ;
ret = tdb_store ( t , val , val , 0 ) ;
if ( ret ! = 0 ) {
printf ( " %s \n " , tdb_errorstr ( t ) ) ;
}
v + = 1 ;
printf ( " \r %u " , v ) ;
data = tdb_fetch ( t , val ) ;
if ( data . dptr ! = NULL ) {
SAFE_FREE ( data . dptr ) ;
}
}
return true ;
}
2007-10-18 17:40:25 -07:00
static double create_procs ( bool ( * fn ) ( int ) , bool * result )
2001-06-19 02:02:19 +00:00
{
int i , status ;
2001-07-02 03:21:17 +00:00
volatile pid_t * child_status ;
2007-10-18 17:40:25 -07:00
volatile bool * child_status_out ;
2001-06-19 02:02:19 +00:00
int synccount ;
int tries = 8 ;
2009-11-24 10:59:09 +01:00
struct timeval start ;
2001-06-19 02:02:19 +00:00
synccount = 0 ;
2012-07-25 08:33:31 +02:00
child_status = ( volatile pid_t * ) anonymous_shared_allocate ( sizeof ( pid_t ) * torture_nprocs ) ;
2001-06-19 02:02:19 +00:00
if ( ! child_status ) {
printf ( " Failed to setup shared memory \n " ) ;
2001-07-02 03:21:17 +00:00
return - 1 ;
}
2012-07-25 08:33:31 +02:00
child_status_out = ( volatile bool * ) anonymous_shared_allocate ( sizeof ( bool ) * torture_nprocs ) ;
2001-07-02 03:21:17 +00:00
if ( ! child_status_out ) {
printf ( " Failed to setup result status shared memory \n " ) ;
return - 1 ;
2001-06-19 02:02:19 +00:00
}
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2002-01-16 02:31:53 +00:00
child_status [ i ] = 0 ;
child_status_out [ i ] = True ;
}
2001-07-02 03:21:17 +00:00
2009-11-24 10:59:09 +01:00
start = timeval_current ( ) ;
2001-06-19 02:02:19 +00:00
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2001-06-19 02:02:19 +00:00
procnum = i ;
if ( fork ( ) = = 0 ) {
pid_t mypid = getpid ( ) ;
sys_srandom ( ( ( int ) mypid ) ^ ( ( int ) time ( NULL ) ) ) ;
slprintf ( myname , sizeof ( myname ) , " CLIENT%d " , i ) ;
while ( 1 ) {
2006-07-31 09:41:25 +00:00
if ( torture_open_connection ( & current_cli , i ) ) break ;
2001-06-19 02:02:19 +00:00
if ( tries - - = = 0 ) {
printf ( " pid %d failed to start \n " , ( int ) getpid ( ) ) ;
_exit ( 1 ) ;
}
2004-02-23 02:54:03 +00:00
smb_msleep ( 10 ) ;
2001-06-19 02:02:19 +00:00
}
child_status [ i ] = getpid ( ) ;
2009-11-24 10:59:09 +01:00
while ( child_status [ i ] & & timeval_elapsed ( & start ) < 5 ) smb_msleep ( 2 ) ;
2001-06-19 02:02:19 +00:00
2001-07-02 03:21:17 +00:00
child_status_out [ i ] = fn ( i ) ;
2001-06-19 02:02:19 +00:00
_exit ( 0 ) ;
}
}
do {
synccount = 0 ;
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2001-06-19 02:02:19 +00:00
if ( child_status [ i ] ) synccount + + ;
}
2012-04-04 14:29:33 +02:00
if ( synccount = = torture_nprocs ) break ;
2004-02-23 02:54:03 +00:00
smb_msleep ( 10 ) ;
2009-11-24 10:59:09 +01:00
} while ( timeval_elapsed ( & start ) < 30 ) ;
2001-06-19 02:02:19 +00:00
2012-04-04 14:29:33 +02:00
if ( synccount ! = torture_nprocs ) {
printf ( " FAILED TO START %d CLIENTS (started %d) \n " , torture_nprocs , synccount ) ;
2001-07-02 03:21:17 +00:00
* result = False ;
2009-11-24 10:59:09 +01:00
return timeval_elapsed ( & start ) ;
2001-06-19 02:02:19 +00:00
}
/* start the client load */
2009-11-24 10:59:09 +01:00
start = timeval_current ( ) ;
2001-06-19 02:02:19 +00:00
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2001-06-19 02:02:19 +00:00
child_status [ i ] = 0 ;
}
2012-04-04 14:29:33 +02:00
printf ( " %d clients started \n " , torture_nprocs ) ;
2001-06-19 02:02:19 +00:00
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2002-03-06 21:05:26 +00:00
while ( waitpid ( 0 , & status , 0 ) = = - 1 & & errno = = EINTR ) /* noop */ ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
2001-06-19 02:02:19 +00:00
printf ( " \n " ) ;
2009-04-22 11:51:03 +02:00
2012-04-04 14:29:33 +02:00
for ( i = 0 ; i < torture_nprocs ; i + + ) {
2001-07-02 03:21:17 +00:00
if ( ! child_status_out [ i ] ) {
* result = False ;
}
}
2009-11-24 10:59:09 +01:00
return timeval_elapsed ( & start ) ;
2001-06-19 02:02:19 +00:00
}
# define FLAG_MULTIPROC 1
static struct {
2003-01-03 08:28:12 +00:00
const char * name ;
2007-10-18 17:40:25 -07:00
bool ( * fn ) ( int ) ;
2001-06-19 02:02:19 +00:00
unsigned flags ;
} torture_ops [ ] = {
{ " FDPASS " , run_fdpasstest , 0 } ,
{ " LOCK1 " , run_locktest1 , 0 } ,
{ " LOCK2 " , run_locktest2 , 0 } ,
{ " LOCK3 " , run_locktest3 , 0 } ,
{ " LOCK4 " , run_locktest4 , 0 } ,
{ " LOCK5 " , run_locktest5 , 0 } ,
2002-03-11 01:37:08 +00:00
{ " LOCK6 " , run_locktest6 , 0 } ,
2003-04-18 03:35:39 +00:00
{ " LOCK7 " , run_locktest7 , 0 } ,
2009-05-20 14:56:04 +02:00
{ " LOCK8 " , run_locktest8 , 0 } ,
2009-10-20 17:37:43 -07:00
{ " LOCK9 " , run_locktest9 , 0 } ,
2001-06-19 02:02:19 +00:00
{ " UNLINK " , run_unlinktest , 0 } ,
{ " BROWSE " , run_browsetest , 0 } ,
{ " ATTR " , run_attrtest , 0 } ,
{ " TRANS2 " , run_trans2test , 0 } ,
{ " MAXFID " , run_maxfidtest , FLAG_MULTIPROC } ,
{ " TORTURE " , run_torture , FLAG_MULTIPROC } ,
{ " RANDOMIPC " , run_randomipc , 0 } ,
{ " NEGNOWAIT " , run_negprot_nowait , 0 } ,
2002-02-05 01:31:47 +00:00
{ " NBENCH " , run_nbench , 0 } ,
2010-07-23 20:08:58 +02:00
{ " NBENCH2 " , run_nbench2 , 0 } ,
2001-06-19 02:02:19 +00:00
{ " OPLOCK1 " , run_oplock1 , 0 } ,
{ " OPLOCK2 " , run_oplock2 , 0 } ,
2011-01-14 15:15:01 -08:00
{ " OPLOCK4 " , run_oplock4 , 0 } ,
2001-06-19 02:02:19 +00:00
{ " DIR " , run_dirtest , 0 } ,
2002-09-25 15:19:00 +00:00
{ " DIR1 " , run_dirtest1 , 0 } ,
2010-02-01 18:49:50 -08:00
{ " DIR-CREATETIME " , run_dir_createtime , 0 } ,
2001-09-06 10:37:21 +00:00
{ " DENY1 " , torture_denytest1 , 0 } ,
{ " DENY2 " , torture_denytest2 , 0 } ,
2001-06-19 02:02:19 +00:00
{ " TCON " , run_tcon_test , 0 } ,
2003-03-30 16:37:10 +00:00
{ " TCONDEV " , run_tcon_devtype_test , 0 } ,
2001-06-19 02:02:19 +00:00
{ " RW1 " , run_readwritetest , 0 } ,
{ " RW2 " , run_readwritemulti , FLAG_MULTIPROC } ,
{ " RW3 " , run_readwritelarge , 0 } ,
2010-11-10 17:54:57 -08:00
{ " RW-SIGNING " , run_readwritelarge_signtest , 0 } ,
2001-06-19 02:02:19 +00:00
{ " OPEN " , run_opentest , 0 } ,
2009-03-11 14:28:47 -07:00
{ " POSIX " , run_simple_posix_open_test , 0 } ,
2009-11-29 16:05:36 +01:00
{ " POSIX-APPEND " , run_posix_append , 0 } ,
2011-04-03 14:36:53 +02:00
{ " CASE-INSENSITIVE-CREATE " , run_case_insensitive_create , 0 } ,
2010-10-06 18:46:43 +02:00
{ " ASYNC-ECHO " , run_async_echo , 0 } ,
2009-04-16 16:21:31 -07:00
{ " UID-REGRESSION-TEST " , run_uid_regression_test , 0 } ,
2009-05-14 16:03:31 -07:00
{ " SHORTNAME-TEST " , run_shortname_test , 0 } ,
2011-01-27 16:56:13 +01:00
{ " ADDRCHANGE " , run_addrchange , 0 } ,
2003-04-18 03:35:39 +00:00
# if 1
{ " OPENATTR " , run_openattrtest , 0 } ,
# endif
2002-02-24 08:38:11 +00:00
{ " XCOPY " , run_xcopy , 0 } ,
2002-03-05 19:45:16 +00:00
{ " RENAME " , run_rename , 0 } ,
2001-06-19 02:02:19 +00:00
{ " DELETE " , run_deletetest , 0 } ,
2011-01-18 16:57:25 -08:00
{ " DELETE-LN " , run_deletetest_ln , 0 } ,
2002-03-19 23:19:00 +00:00
{ " PROPERTIES " , run_properties , 0 } ,
2002-04-12 10:18:46 +00:00
{ " MANGLE " , torture_mangle , 0 } ,
2009-04-17 15:08:40 +02:00
{ " MANGLE1 " , run_mangle1 , 0 } ,
2001-06-19 02:02:19 +00:00
{ " W2K " , run_w2ktest , 0 } ,
2001-08-27 08:19:43 +00:00
{ " TRANS2SCAN " , torture_trans2_scan , 0 } ,
{ " NTTRANSSCAN " , torture_nttrans_scan , 0 } ,
2001-09-25 05:20:43 +00:00
{ " UTABLE " , torture_utable , 0 } ,
2001-10-02 05:52:11 +00:00
{ " CASETABLE " , torture_casetable , 0 } ,
2001-11-25 02:35:37 +00:00
{ " ERRMAPEXTRACT " , run_error_map_extract , 0 } ,
2002-07-15 10:35:28 +00:00
{ " PIPE_NUMBER " , run_pipe_number , 0 } ,
2003-04-18 03:35:39 +00:00
{ " TCON2 " , run_tcon2_test , 0 } ,
2003-04-23 08:12:34 +00:00
{ " IOCTL " , torture_ioctl_test , 0 } ,
2003-04-18 03:35:39 +00:00
{ " CHKPATH " , torture_chkpath_test , 0 } ,
{ " FDSESS " , run_fdsesstest , 0 } ,
2004-03-27 02:13:58 +00:00
{ " EATEST " , run_eatest , 0 } ,
2007-12-04 11:38:57 +01:00
{ " SESSSETUP_BENCH " , run_sesssetup_bench , 0 } ,
2009-04-05 23:20:45 +02:00
{ " CHAIN1 " , run_chain1 , 0 } ,
2009-05-07 16:24:46 +02:00
{ " CHAIN2 " , run_chain2 , 0 } ,
2012-02-28 20:28:55 +01:00
{ " CHAIN3 " , run_chain3 , 0 } ,
2008-12-19 23:41:19 +01:00
{ " WINDOWS-WRITE " , run_windows_write , 0 } ,
2013-03-13 15:43:21 -07:00
{ " LARGE_READX " , run_large_readx , 0 } ,
2011-06-18 09:56:12 +02:00
{ " NTTRANS-CREATE " , run_nttrans_create , 0 } ,
2011-09-15 16:13:54 -07:00
{ " NTTRANS-FSCTL " , run_nttrans_fsctl , 0 } ,
2008-08-27 19:30:57 +02:00
{ " CLI_ECHO " , run_cli_echo , 0 } ,
2009-04-26 00:01:43 +02:00
{ " GETADDRINFO " , run_getaddrinfo_send , 0 } ,
2009-06-19 13:06:02 +02:00
{ " TLDAP " , run_tldap } ,
2009-07-02 11:56:33 +02:00
{ " STREAMERROR " , run_streamerror } ,
2009-10-12 17:29:45 +02:00
{ " NOTIFY-BENCH " , run_notify_bench } ,
2012-04-04 14:35:12 +02:00
{ " NOTIFY-BENCH2 " , run_notify_bench2 } ,
{ " NOTIFY-BENCH3 " , run_notify_bench3 } ,
2010-09-27 18:24:01 -07:00
{ " BAD-NBT-SESSION " , run_bad_nbt_session } ,
2010-12-14 12:50:57 +01:00
{ " SMB-ANY-CONNECT " , run_smb_any_connect } ,
2011-05-04 17:45:34 +02:00
{ " NOTIFY-ONLINE " , run_notify_online } ,
2011-05-05 18:12:07 +02:00
{ " SMB2-BASIC " , run_smb2_basic } ,
2011-08-30 18:50:35 +02:00
{ " SMB2-NEGPROT " , run_smb2_negprot } ,
2011-09-19 10:08:48 +02:00
{ " SMB2-SESSION-RECONNECT " , run_smb2_session_reconnect } ,
2011-09-19 10:09:34 +02:00
{ " SMB2-TCON-DEPENDENCE " , run_smb2_tcon_dependence } ,
2011-10-22 10:34:31 +02:00
{ " SMB2-MULTI-CHANNEL " , run_smb2_multi_channel } ,
2011-10-22 10:37:34 +02:00
{ " SMB2-SESSION-REAUTH " , run_smb2_session_reauth } ,
2012-01-05 09:23:42 +01:00
{ " CLEANUP1 " , run_cleanup1 } ,
2012-01-05 17:44:44 +01:00
{ " CLEANUP2 " , run_cleanup2 } ,
2012-05-11 14:39:42 +02:00
{ " CLEANUP3 " , run_cleanup3 } ,
2013-09-01 18:54:59 +02:00
{ " CLEANUP4 " , run_cleanup4 } ,
2006-07-11 18:01:26 +00:00
{ " LOCAL-SUBSTITUTE " , run_local_substitute , 0 } ,
2006-09-09 21:05:51 +00:00
{ " LOCAL-GENCACHE " , run_local_gencache , 0 } ,
2009-08-16 10:44:06 +02:00
{ " LOCAL-TALLOC-DICT " , run_local_talloc_dict , 0 } ,
2012-02-15 12:26:59 +01:00
{ " LOCAL-CTDB-CONN " , run_ctdb_conn , 0 } ,
2012-02-15 15:17:33 +01:00
{ " LOCAL-DBWRAP-WATCH1 " , run_dbwrap_watch1 , 0 } ,
2009-07-10 17:29:22 +02:00
{ " LOCAL-BASE64 " , run_local_base64 , 0 } ,
2007-11-09 23:43:24 +01:00
{ " LOCAL-RBTREE " , run_local_rbtree , 0 } ,
2007-12-18 09:41:03 +01:00
{ " LOCAL-MEMCACHE " , run_local_memcache , 0 } ,
2008-01-19 23:10:09 +01:00
{ " LOCAL-STREAM-NAME " , run_local_stream_name , 0 } ,
2008-12-28 17:43:18 +01:00
{ " LOCAL-WBCLIENT " , run_local_wbclient , 0 } ,
2010-02-20 21:31:16 +01:00
{ " LOCAL-string_to_sid " , run_local_string_to_sid , 0 } ,
2013-07-31 10:38:23 -04:00
{ " LOCAL-sid_to_string " , run_local_sid_to_string , 0 } ,
2010-09-04 14:13:31 +10:00
{ " LOCAL-binary_to_sid " , run_local_binary_to_sid , 0 } ,
2009-12-11 15:37:52 +01:00
{ " LOCAL-DBTRANS " , run_local_dbtrans , 0 } ,
2010-06-10 09:50:32 +02:00
{ " LOCAL-TEVENT-SELECT " , run_local_tevent_select , 0 } ,
2011-03-30 17:30:08 +11:00
{ " LOCAL-CONVERT-STRING " , run_local_convert_string , 0 } ,
2011-09-01 18:18:31 +02:00
{ " LOCAL-CONV-AUTH-INFO " , run_local_conv_auth_info , 0 } ,
2011-10-26 17:21:04 +11:00
{ " LOCAL-sprintf_append " , run_local_sprintf_append , 0 } ,
2012-02-03 03:27:19 +01:00
{ " LOCAL-hex_encode_buf " , run_local_hex_encode_buf , 0 } ,
2012-02-22 15:44:27 +01:00
{ " LOCAL-IDMAP-TDB-COMMON " , run_idmap_tdb_common_test , 0 } ,
2012-05-21 14:29:11 -07:00
{ " LOCAL-remove_duplicate_addrs2 " , run_local_remove_duplicate_addrs2 , 0 } ,
2012-10-02 15:44:41 +02:00
{ " local-tdb-opener " , run_local_tdb_opener , 0 } ,
{ " local-tdb-writer " , run_local_tdb_writer , 0 } ,
2012-11-07 21:24:27 +01:00
{ " LOCAL-DBWRAP-CTDB " , run_local_dbwrap_ctdb , 0 } ,
2013-08-23 13:57:03 +00:00
{ " qpathinfo-bufsize " , run_qpathinfo_bufsize , 0 } ,
2001-06-19 02:02:19 +00:00
{ NULL , NULL , 0 } } ;
2013-01-17 15:22:32 +01:00
/*
* dummy function to satisfy linker dependency
*/
struct tevent_context * winbind_event_context ( void ) ;
struct tevent_context * winbind_event_context ( void )
{
return NULL ;
}
2001-06-19 02:02:19 +00:00
/****************************************************************************
run a specified test or " ALL "
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
static bool run_test ( const char * name )
2001-06-19 02:02:19 +00:00
{
2007-10-18 17:40:25 -07:00
bool ret = True ;
bool result = True ;
bool found = False ;
2001-06-19 02:02:19 +00:00
int i ;
2001-07-02 03:21:17 +00:00
double t ;
2001-06-19 02:02:19 +00:00
if ( strequal ( name , " ALL " ) ) {
for ( i = 0 ; torture_ops [ i ] . name ; i + + ) {
run_test ( torture_ops [ i ] . name ) ;
}
2003-12-30 15:18:25 +00:00
found = True ;
2001-06-19 02:02:19 +00:00
}
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
for ( i = 0 ; torture_ops [ i ] . name ; i + + ) {
2003-07-23 12:33:59 +00:00
fstr_sprintf ( randomfname , " \\ XX%x " ,
2001-06-19 02:02:19 +00:00
( unsigned ) random ( ) ) ;
if ( strequal ( name , torture_ops [ i ] . name ) ) {
2003-12-30 15:18:25 +00:00
found = True ;
2001-06-19 02:02:19 +00:00
printf ( " Running %s \n " , name ) ;
if ( torture_ops [ i ] . flags & FLAG_MULTIPROC ) {
2001-07-02 03:21:17 +00:00
t = create_procs ( torture_ops [ i ] . fn , & result ) ;
if ( ! result ) {
ret = False ;
printf ( " TEST %s FAILED! \n " , name ) ;
}
2001-06-19 02:02:19 +00:00
} else {
2009-11-24 10:59:09 +01:00
struct timeval start ;
start = timeval_current ( ) ;
2001-07-02 03:21:17 +00:00
if ( ! torture_ops [ i ] . fn ( 0 ) ) {
ret = False ;
printf ( " TEST %s FAILED! \n " , name ) ;
}
2009-11-24 10:59:09 +01:00
t = timeval_elapsed ( & start ) ;
2001-06-19 02:02:19 +00:00
}
2001-07-02 03:21:17 +00:00
printf ( " %s took %g secs \n \n " , name , t ) ;
2001-06-19 02:02:19 +00:00
}
}
2003-12-30 15:18:25 +00:00
if ( ! found ) {
printf ( " Did not find a test named %s \n " , name ) ;
ret = False ;
}
2001-07-02 03:21:17 +00:00
return ret ;
2001-06-19 02:02:19 +00:00
}
static void usage ( void )
{
int i ;
2005-05-02 15:00:51 +00:00
printf ( " WARNING samba4 test suite is much more complete nowadays. \n " ) ;
printf ( " Please use samba4 torture. \n \n " ) ;
2001-06-19 02:02:19 +00:00
printf ( " Usage: smbtorture //server/share <options> TEST1 TEST2 ... \n " ) ;
printf ( " \t -d debuglevel \n " ) ;
printf ( " \t -U user%%pass \n " ) ;
2002-03-04 00:24:24 +00:00
printf ( " \t -k use kerberos \n " ) ;
2001-06-19 02:02:19 +00:00
printf ( " \t -N numprocs \n " ) ;
printf ( " \t -n my_netbios_name \n " ) ;
printf ( " \t -W workgroup \n " ) ;
printf ( " \t -o num_operations \n " ) ;
printf ( " \t -O socket_options \n " ) ;
printf ( " \t -m maximum protocol \n " ) ;
printf ( " \t -L use oplocks \n " ) ;
2002-02-05 01:31:47 +00:00
printf ( " \t -c CLIENT.TXT specify client load file for NBENCH \n " ) ;
2001-09-06 10:37:21 +00:00
printf ( " \t -A showall \n " ) ;
2003-04-18 03:35:39 +00:00
printf ( " \t -p port \n " ) ;
2002-04-12 10:18:46 +00:00
printf ( " \t -s seed \n " ) ;
2006-07-31 09:41:25 +00:00
printf ( " \t -b unclist_filename specify multiple shares for multiple connections \n " ) ;
2011-05-04 17:45:34 +02:00
printf ( " \t -f filename filename to test \n " ) ;
2001-06-19 02:02:19 +00:00
printf ( " \n \n " ) ;
printf ( " tests are: " ) ;
for ( i = 0 ; torture_ops [ i ] . name ; i + + ) {
printf ( " %s " , torture_ops [ i ] . name ) ;
}
printf ( " \n " ) ;
printf ( " default test is ALL \n " ) ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
exit ( 1 ) ;
}
/****************************************************************************
main program
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
int main ( int argc , char * argv [ ] )
{
int opt , i ;
char * p ;
2003-02-24 03:28:37 +00:00
int gotuser = 0 ;
2001-06-19 02:02:19 +00:00
int gotpass = 0 ;
2007-10-18 17:40:25 -07:00
bool correct = True ;
2007-11-08 18:50:07 -08:00
TALLOC_CTX * frame = talloc_stackframe ( ) ;
2008-03-08 22:29:35 +01:00
int seed = time ( NULL ) ;
2001-06-19 02:02:19 +00:00
2001-07-02 04:47:55 +00:00
# ifdef HAVE_SETBUFFER
2001-06-19 02:02:19 +00:00
setbuffer ( stdout , NULL , 0 ) ;
2001-07-02 04:47:55 +00:00
# endif
2001-06-19 02:02:19 +00:00
2010-10-29 14:19:32 +11:00
setup_logging ( " smbtorture " , DEBUG_STDOUT ) ;
2006-01-23 00:19:45 +00:00
2010-10-29 14:19:32 +11:00
load_case_tables ( ) ;
2013-02-15 14:23:50 +01:00
fault_setup ( ) ;
2009-12-07 00:36:51 +01:00
2009-01-28 10:50:55 +01:00
if ( is_default_dyn_CONFIGFILE ( ) ) {
if ( getenv ( " SMB_CONF_PATH " ) ) {
set_dyn_CONFIGFILE ( getenv ( " SMB_CONF_PATH " ) ) ;
}
}
2011-07-28 10:14:27 +02:00
lp_load_global ( get_dyn_CONFIGFILE ( ) ) ;
2001-06-19 02:02:19 +00:00
load_interfaces ( ) ;
if ( argc < 2 ) {
usage ( ) ;
}
for ( p = argv [ 1 ] ; * p ; p + + )
if ( * p = = ' \\ ' )
* p = ' / ' ;
2009-04-22 11:51:03 +02:00
2001-06-19 02:02:19 +00:00
if ( strncmp ( argv [ 1 ] , " // " , 2 ) ) {
usage ( ) ;
}
fstrcpy ( host , & argv [ 1 ] [ 2 ] ) ;
2001-07-04 07:36:09 +00:00
p = strchr_m ( & host [ 2 ] , ' / ' ) ;
2001-06-19 02:02:19 +00:00
if ( ! p ) {
usage ( ) ;
}
* p = 0 ;
fstrcpy ( share , p + 1 ) ;
2009-02-13 10:56:34 +01:00
fstrcpy ( myname , get_myname ( talloc_tos ( ) ) ) ;
2007-11-08 18:50:07 -08:00
if ( ! * myname ) {
fprintf ( stderr , " Failed to get my hostname. \n " ) ;
return 1 ;
}
2001-06-19 02:02:19 +00:00
if ( * username = = 0 & & getenv ( " LOGNAME " ) ) {
2003-01-14 08:53:59 +00:00
fstrcpy ( username , getenv ( " LOGNAME " ) ) ;
2001-06-19 02:02:19 +00:00
}
argc - - ;
argv + + ;
fstrcpy ( workgroup , lp_workgroup ( ) ) ;
2011-05-04 17:45:34 +02:00
while ( ( opt = getopt ( argc , argv , " p:hW:U:n:N:O:o:m:Ll:d:Aec:ks:b:B:f: " ) )
! = EOF ) {
2001-06-19 02:02:19 +00:00
switch ( opt ) {
2003-04-18 03:35:39 +00:00
case ' p ' :
port_to_use = atoi ( optarg ) ;
break ;
2002-04-12 10:18:46 +00:00
case ' s ' :
2008-03-08 22:29:35 +01:00
seed = atoi ( optarg ) ;
2002-04-12 10:18:46 +00:00
break ;
2001-06-19 02:02:19 +00:00
case ' W ' :
fstrcpy ( workgroup , optarg ) ;
break ;
case ' m ' :
2013-08-11 13:10:13 +02:00
lp_set_cmdline ( " client max protocol " , optarg ) ;
2001-06-19 02:02:19 +00:00
break ;
case ' N ' :
2012-04-04 14:29:33 +02:00
torture_nprocs = atoi ( optarg ) ;
2001-06-19 02:02:19 +00:00
break ;
case ' o ' :
2002-04-12 10:18:46 +00:00
torture_numops = atoi ( optarg ) ;
2001-06-19 02:02:19 +00:00
break ;
case ' d ' :
2010-10-29 15:29:09 +11:00
lp_set_cmdline ( " log level " , optarg ) ;
2001-06-19 02:02:19 +00:00
break ;
case ' O ' :
sockops = optarg ;
break ;
case ' L ' :
use_oplocks = True ;
break ;
2009-10-20 17:37:43 -07:00
case ' l ' :
local_path = optarg ;
break ;
2001-09-06 10:37:21 +00:00
case ' A ' :
torture_showall = True ;
break ;
2001-06-19 02:02:19 +00:00
case ' n ' :
fstrcpy ( myname , optarg ) ;
break ;
2002-02-05 01:31:47 +00:00
case ' c ' :
client_txt = optarg ;
break ;
2008-01-04 16:09:24 -08:00
case ' e ' :
do_encrypt = true ;
break ;
2002-03-04 00:24:24 +00:00
case ' k ' :
# ifdef HAVE_KRB5
use_kerberos = True ;
# else
d_printf ( " No kerberos support compiled in \n " ) ;
exit ( 1 ) ;
# endif
break ;
2001-06-19 02:02:19 +00:00
case ' U ' :
2003-02-24 03:28:37 +00:00
gotuser = 1 ;
2003-01-14 08:53:59 +00:00
fstrcpy ( username , optarg ) ;
2001-07-04 07:36:09 +00:00
p = strchr_m ( username , ' % ' ) ;
2001-06-19 02:02:19 +00:00
if ( p ) {
* p = 0 ;
2003-01-14 08:53:59 +00:00
fstrcpy ( password , p + 1 ) ;
2001-06-19 02:02:19 +00:00
gotpass = 1 ;
}
break ;
2006-07-31 09:41:25 +00:00
case ' b ' :
fstrcpy ( multishare_conn_fname , optarg ) ;
use_multishare_conn = True ;
break ;
2008-12-19 23:41:19 +01:00
case ' B ' :
torture_blocksize = atoi ( optarg ) ;
break ;
2011-05-04 17:45:34 +02:00
case ' f ' :
test_filename = SMB_STRDUP ( optarg ) ;
break ;
2001-06-19 02:02:19 +00:00
default :
printf ( " Unknown option %c (%d) \n " , ( char ) opt , opt ) ;
usage ( ) ;
}
}
2008-03-08 22:29:35 +01:00
d_printf ( " using seed %d \n " , seed ) ;
srandom ( seed ) ;
2003-02-24 03:28:37 +00:00
if ( use_kerberos & & ! gotuser ) gotpass = True ;
2001-06-19 02:02:19 +00:00
while ( ! gotpass ) {
2012-11-22 15:46:06 +01:00
char pwd [ 256 ] = { 0 } ;
int rc ;
rc = samba_getpass ( " Password: " , pwd , sizeof ( pwd ) , false , false ) ;
if ( rc = = 0 ) {
fstrcpy ( password , pwd ) ;
2001-06-19 02:02:19 +00:00
gotpass = 1 ;
}
}
printf ( " host=%s share=%s user=%s myname=%s \n " ,
host , share , username , myname ) ;
2003-12-30 15:18:25 +00:00
if ( argc = = optind ) {
2001-07-02 03:21:17 +00:00
correct = run_test ( " ALL " ) ;
2001-06-19 02:02:19 +00:00
} else {
2003-12-30 15:18:25 +00:00
for ( i = optind ; i < argc ; i + + ) {
2001-07-02 03:21:17 +00:00
if ( ! run_test ( argv [ i ] ) ) {
correct = False ;
}
2001-06-19 02:02:19 +00:00
}
}
2007-11-08 18:50:07 -08:00
TALLOC_FREE ( frame ) ;
2001-07-02 03:21:17 +00:00
if ( correct ) {
return ( 0 ) ;
} else {
return ( 1 ) ;
}
2001-06-19 02:02:19 +00:00
}