2003-08-13 01:53:07 +00:00
/*
Unix SMB / CIFS implementation .
RAW_CLOSE_ * individual test suite
Copyright ( C ) Andrew Tridgell 2003
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
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
2006-01-03 13:41:17 +00:00
# include "torture/torture.h"
2004-11-02 00:24:21 +00:00
# include "system/time.h"
2005-12-28 15:38:36 +00:00
# include "libcli/raw/libcliraw.h"
2006-01-03 15:40:05 +00:00
# include "libcli/libcli.h"
2006-03-17 17:59:58 +00:00
# include "torture/util.h"
2003-08-13 01:53:07 +00:00
/* basic testing of all RAW_CLOSE_* calls
*/
2006-03-25 16:01:28 +00:00
BOOL torture_raw_close ( struct torture_context * torture )
2003-08-13 01:53:07 +00:00
{
2004-08-04 13:23:35 +00:00
struct smbcli_state * cli ;
2003-08-13 01:53:07 +00:00
BOOL ret = True ;
TALLOC_CTX * mem_ctx ;
union smb_close io ;
2006-03-10 20:49:20 +00:00
union smb_flush io_flush ;
2003-08-13 01:53:07 +00:00
int fnum ;
const char * fname = " \\ torture_close.txt " ;
time_t basetime = ( time ( NULL ) + 3 * 86400 ) & ~ 1 ;
union smb_fileinfo finfo , finfo2 ;
NTSTATUS status ;
2006-07-10 08:00:06 +00:00
if ( ! torture_open_connection ( & cli , 0 ) ) {
2003-08-13 01:53:07 +00:00
return False ;
}
mem_ctx = talloc_init ( " torture_raw_close " ) ;
# define REOPEN do { \
fnum = create_complex_file ( cli , mem_ctx , fname ) ; \
if ( fnum = = - 1 ) { \
printf ( " (%d) Failed to create %s \n " , __LINE__ , fname ) ; \
ret = False ; \
goto done ; \
} } while ( 0 )
# define CHECK_STATUS(status, correct) do { \
if ( ! NT_STATUS_EQUAL ( status , correct ) ) { \
printf ( " (%d) Incorrect status %s - should be %s \n " , \
__LINE__ , nt_errstr ( status ) , nt_errstr ( correct ) ) ; \
ret = False ; \
goto done ; \
} } while ( 0 )
REOPEN ;
io . close . level = RAW_CLOSE_CLOSE ;
2006-03-12 22:48:25 +00:00
io . close . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
io . close . in . write_time = basetime ;
status = smb_raw_close ( cli - > tree , & io ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
status = smb_raw_close ( cli - > tree , & io ) ;
CHECK_STATUS ( status , NT_STATUS_INVALID_HANDLE ) ;
printf ( " testing close.in.write_time \n " ) ;
/* the file should have the write time set */
finfo . generic . level = RAW_FILEINFO_ALL_INFO ;
2006-03-12 22:48:25 +00:00
finfo . generic . in . file . path = fname ;
2003-08-13 01:53:07 +00:00
status = smb_raw_pathinfo ( cli - > tree , mem_ctx , & finfo ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
2004-05-25 13:57:39 +00:00
if ( basetime ! = nt_time_to_unix ( finfo . all_info . out . write_time ) ) {
2003-08-13 01:53:07 +00:00
printf ( " Incorrect write time on file - %s - %s \n " ,
2004-04-10 20:18:22 +00:00
timestring ( mem_ctx , basetime ) ,
2004-05-25 13:57:39 +00:00
nt_time_string ( mem_ctx , finfo . all_info . out . write_time ) ) ;
2003-08-13 01:53:07 +00:00
dump_all_info ( mem_ctx , & finfo ) ;
ret = False ;
}
printf ( " testing other times \n " ) ;
/* none of the other times should be set to that time */
if ( nt_time_equal ( & finfo . all_info . out . write_time ,
& finfo . all_info . out . access_time ) | |
nt_time_equal ( & finfo . all_info . out . write_time ,
& finfo . all_info . out . create_time ) | |
nt_time_equal ( & finfo . all_info . out . write_time ,
& finfo . all_info . out . change_time ) ) {
printf ( " Incorrect times after close - only write time should be set \n " ) ;
dump_all_info ( mem_ctx , & finfo ) ;
ret = False ;
}
2004-08-04 13:23:35 +00:00
smbcli_unlink ( cli - > tree , fname ) ;
2003-08-13 01:53:07 +00:00
REOPEN ;
finfo2 . generic . level = RAW_FILEINFO_ALL_INFO ;
2006-03-12 22:48:25 +00:00
finfo2 . generic . in . file . path = fname ;
2003-08-13 01:53:07 +00:00
status = smb_raw_pathinfo ( cli - > tree , mem_ctx , & finfo2 ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
io . close . level = RAW_CLOSE_CLOSE ;
2006-03-12 22:48:25 +00:00
io . close . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
io . close . in . write_time = 0 ;
status = smb_raw_close ( cli - > tree , & io ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
/* the file should have the write time set equal to access time */
finfo . generic . level = RAW_FILEINFO_ALL_INFO ;
2006-03-12 22:48:25 +00:00
finfo . generic . in . file . path = fname ;
2003-08-13 01:53:07 +00:00
status = smb_raw_pathinfo ( cli - > tree , mem_ctx , & finfo ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
if ( ! nt_time_equal ( & finfo . all_info . out . write_time ,
& finfo2 . all_info . out . write_time ) ) {
printf ( " Incorrect write time on file - 0 time should be ignored \n " ) ;
dump_all_info ( mem_ctx , & finfo ) ;
ret = False ;
}
printf ( " testing splclose \n " ) ;
/* check splclose on a file */
REOPEN ;
io . splclose . level = RAW_CLOSE_SPLCLOSE ;
2006-03-12 22:48:25 +00:00
io . splclose . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
status = smb_raw_close ( cli - > tree , & io ) ;
2005-07-04 05:24:39 +00:00
CHECK_STATUS ( status , NT_STATUS_DOS ( ERRSRV , ERRerror ) ) ;
2003-08-13 01:53:07 +00:00
printf ( " testing flush \n " ) ;
2004-08-04 13:23:35 +00:00
smbcli_close ( cli - > tree , fnum ) ;
2003-08-13 01:53:07 +00:00
2006-05-19 15:10:39 +00:00
io_flush . flush . level = RAW_FLUSH_FLUSH ;
io_flush . flush . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
status = smb_raw_flush ( cli - > tree , & io_flush ) ;
CHECK_STATUS ( status , NT_STATUS_INVALID_HANDLE ) ;
2006-05-19 15:10:39 +00:00
io_flush . flush_all . level = RAW_FLUSH_ALL ;
2003-08-13 01:53:07 +00:00
status = smb_raw_flush ( cli - > tree , & io_flush ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
REOPEN ;
2006-05-19 15:10:39 +00:00
io_flush . flush . level = RAW_FLUSH_FLUSH ;
io_flush . flush . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
status = smb_raw_flush ( cli - > tree , & io_flush ) ;
CHECK_STATUS ( status , NT_STATUS_OK ) ;
printf ( " Testing SMBexit \n " ) ;
smb_raw_exit ( cli - > session ) ;
2006-05-19 15:10:39 +00:00
io_flush . flush . level = RAW_FLUSH_FLUSH ;
io_flush . flush . in . file . fnum = fnum ;
2003-08-13 01:53:07 +00:00
status = smb_raw_flush ( cli - > tree , & io_flush ) ;
CHECK_STATUS ( status , NT_STATUS_INVALID_HANDLE ) ;
done :
2004-08-04 13:23:35 +00:00
smbcli_close ( cli - > tree , fnum ) ;
smbcli_unlink ( cli - > tree , fname ) ;
2003-08-13 01:53:07 +00:00
torture_close_connection ( cli ) ;
2005-01-27 07:08:20 +00:00
talloc_free ( mem_ctx ) ;
2003-08-13 01:53:07 +00:00
return ret ;
}