blob: f53451e51dd26d49fd31718138fe703e900c64ee [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_sal.hxx"
//------------------------------------------------------------------------
// include files
//------------------------------------------------------------------------
#include <sal/types.h>
#include <rtl/ustring.hxx>
#include <rtl/ustrbuf.hxx>
#include "osl/thread.h"
#include "rtl/ustrbuf.hxx"
#include <osl/file.hxx>
#include <osl_File_Const.h>
#include "gtest/gtest.h"
// #ifdef WNT
// # define UNICODE
// # define WIN32_LEAN_AND_MEAN
// # include <windows.h>
// # include <tchar.h>
// #endif
using namespace osl;
using namespace rtl;
//------------------------------------------------------------------------
// helper functions
//------------------------------------------------------------------------
/** detailed wrong message.
*/
inline ::rtl::OString errorToString( const ::osl::FileBase::RC _nError )
{
::rtl::OString sResult;
switch ( _nError ) {
case ::osl::FileBase::E_None:
sResult = "Success";
break;
case ::osl::FileBase::E_PERM:
sResult = "Operation not permitted";
break;
case ::osl::FileBase::E_NOENT:
sResult = "No such file or directory";
break;
case ::osl::FileBase::E_EXIST:
sResult = "Already Exist";
break;
case ::osl::FileBase::E_ACCES:
sResult = "Permission denied";
break;
case ::osl::FileBase::E_INVAL:
sResult = "The format of the parameters was not valid";
break;
case ::osl::FileBase::E_NOTDIR:
sResult = "Not a directory";
break;
case ::osl::FileBase::E_ISDIR:
sResult = "Is a directory";
break;
case ::osl::FileBase::E_BADF:
sResult = "Bad file";
break;
case ::osl::FileBase::E_NOTEMPTY:
sResult = "The directory is not empty";
break;
default:
sResult = "Unknown Error";
break;
}
return sResult;
}
rtl::OUString errorToStr( ::osl::FileBase::RC const& nError)
{
rtl::OUStringBuffer suBuf;
suBuf.append( rtl::OUString::createFromAscii("The returned error is: ") );
suBuf.append( rtl::OStringToOUString(errorToString(nError), RTL_TEXTENCODING_ASCII_US) );
suBuf.append( rtl::OUString::createFromAscii("!\n") );
return suBuf.makeStringAndClear();
}
/** print a file type name.
*/
inline void printFileType( const ::osl::FileStatus::Type nType )
{
printf( "#printFileType# " );
switch ( nType ) {
case ::osl::FileStatus::Directory:
printf( "This file is a: Directory.\n" );
break;
case ::osl::FileStatus::Volume:
printf( "This file is a: volume device.\n" );
break;
case ::osl::FileStatus::Regular:
printf( "This file is a: regular file.\n" );
break;
case ::osl::FileStatus::Fifo:
printf( "This file is a: fifo.\n" );
break;
case ::osl::FileStatus::Socket:
printf( "This file is a: socket.\n" );
break;
case ::osl::FileStatus::Link:
printf( "This file is a: link file.\n" );
break;
case ::osl::FileStatus::Special:
printf( "This file is a: special.\n" );
break;
case ::osl::FileStatus::Unknown:
printf( "The file type is unknown %d \n", nType );
break;
}
}
/** print a file attributes.
*/
inline void printFileAttributes( const sal_Int64 nAttributes )
{
printf( "#printFileAttributes# This file is a: (" );
if ( ( nAttributes | Attribute_ReadOnly ) == nAttributes )
printf( " ReadOnly " );
if ( ( nAttributes | Attribute_Hidden ) == nAttributes )
printf( " Hidden " );
if ( ( nAttributes | Attribute_Executable ) == nAttributes )
printf( " Executable " );
if ( ( nAttributes | Attribute_GrpWrite ) == nAttributes )
printf( " GrpWrite " );
if ( ( nAttributes | Attribute_GrpRead ) == nAttributes )
printf( " GrpRead " );
if ( ( nAttributes | Attribute_GrpExe ) == nAttributes )
printf( " GrpExe " );
if ( ( nAttributes | Attribute_OwnWrite ) == nAttributes )
printf( " OwnWrite " );
if ( ( nAttributes | Attribute_OwnRead ) == nAttributes )
printf( " OwnRead " );
if ( ( nAttributes | Attribute_OwnExe ) == nAttributes )
printf( " OwnExe " );
if ( ( nAttributes | Attribute_OthWrite ) == nAttributes )
printf( " OthWrite " );
if ( ( nAttributes | Attribute_OthRead ) == nAttributes )
printf( " OthRead " );
if ( ( nAttributes | Attribute_OthExe ) == nAttributes )
printf( " OthExe " );
printf( ") file!\n" );
}
/** print a UNI_CODE file name.
*/
inline void printFileName( const ::rtl::OUString & str )
{
rtl::OString aString;
printf( "#printFileName_u# " );
aString = ::rtl::OUStringToOString( str, RTL_TEXTENCODING_ASCII_US );
printf( "%s\n", aString.getStr( ) );
}
/** print a ASCII_CODE file name.
*/
inline void printFileName( const sal_Char * str )
{
printf( "#printFileName_a# " );
printf( "%s\n", str );
}
/** print an output wrong message.
*/
inline void printError( const ::osl::FileBase::RC nError )
{
printf( "#printError# " );
printFileName( errorToStr(nError) );
}
/** print an signed Integer Number.
*/
inline void printInt( sal_Int64 i )
{
printf( "#printInt_i64# " );
printf( "The Integer64 is %lld\n", i);
}
/** print an unsigned Integer Number.
*/
inline void printInt( sal_uInt64 i )
{
printf( "#printInt_u64# " );
printf( "The unsigned Integer64 is %llu\n", i);
}
/** print Boolean value.
*/
inline void printBool( sal_Bool bOk )
{
printf( "#printBool# " );
( sal_True == bOk ) ? printf( "YES!\n" ): printf( "NO!\n" );
}
/** print struct TimeValue in local time format.
*/
inline void printTime( TimeValue *tv )
{
oslDateTime *pDateTime = ( oslDateTime* )malloc( sizeof( oslDateTime ) ) ;
ASSERT_TRUE(pDateTime != NULL) << "Error in printTime() function,malloc ";
TimeValue *pLocalTV = ( TimeValue* )malloc( sizeof( TimeValue ) );
ASSERT_TRUE(pLocalTV != NULL) << "Error in printTime() function,malloc ";
ASSERT_TRUE(sal_True == osl_getLocalTimeFromSystemTime( tv, pLocalTV )) << "Error in printTime() function,osl_getLocalTimeFromSystemTime ";
ASSERT_TRUE(sal_True == osl_getDateTimeFromTimeValue( pLocalTV, pDateTime )) << "Error in printTime() function,osl_gepDateTimeFromTimeValue ";
printf( "#printTime# " );
printf( " Time is: %d/%d/%d ", pDateTime->Month, pDateTime->Day, pDateTime->Year);
switch ( pDateTime->DayOfWeek )
{
case 0: printf("Sun. "); break;
case 1: printf("Mon. "); break;
case 2: printf("Tue. "); break;
case 3: printf("Thr. "); break;
case 4: printf("Wen. "); break;
case 5: printf("Fri. "); break;
case 6: printf("Sat. "); break;
}
printf( " %d:%d:%d %d nsecs\n", pDateTime->Hours, pDateTime->Minutes, pDateTime->Seconds, pDateTime->NanoSeconds);
free( pDateTime );
free( pLocalTV );
}
/** compare two TimeValue, unit is "ms", since Windows time precision is better than UNX.
*/
#if ( defined UNX ) || ( defined OS2 ) //precision of time in Windows is better than UNX
# define delta 2000 //time precision, 2000ms
#else
# define delta 1800 //time precision, 1.8s
#endif
inline sal_Int64 t_abs64(sal_Int64 _nValue)
{
// std::abs() seems to have some ambiguity problems (so-texas)
// return abs(_nValue);
printf("t_abs64(%ld)\n", _nValue);
// ASSERT_TRUE(_nValue < 2147483647);
if (_nValue < 0)
{
_nValue = -_nValue;
}
return _nValue;
}
inline sal_Bool t_compareTime( TimeValue *m_aEndTime, TimeValue *m_aStartTime, sal_Int32 nDelta)
{
// sal_uInt64 uTimeValue;
// sal_Int64 iTimeValue;
//
// iTimeValue = t_abs64(( tv1->Seconds - tv2->Seconds) * 1000000000 + tv1->Nanosec - tv2->Nanosec);
// uTimeValue = ( iTimeValue / 1000000 );
sal_Int32 nDeltaSeconds = m_aEndTime->Seconds - m_aStartTime->Seconds;
sal_Int32 nDeltaNanoSec = sal_Int32(m_aEndTime->Nanosec) - sal_Int32(m_aStartTime->Nanosec);
if (nDeltaNanoSec < 0)
{
nDeltaNanoSec = 1000000000 + nDeltaNanoSec;
nDeltaSeconds--;
}
sal_Int32 nDeltaMilliSec = (nDeltaSeconds * 1000) + (nDeltaNanoSec / 1000000);
return ( nDeltaMilliSec < nDelta );
}
/** compare two OUString file name.
*/
inline sal_Bool compareFileName( const ::rtl::OUString & ustr1, const ::rtl::OUString & ustr2 )
{
sal_Bool bOk;
//on Windows, the seperatar is '\', so here change to '/', then compare
#if defined (WNT )
::rtl::OUString ustr1new,ustr2new;
sal_Unicode reverseSlash = (sal_Unicode)'\\';
if (ustr1.lastIndexOf(reverseSlash) != -1)
ustr1new = ustr1.replace(reverseSlash,(sal_Unicode)'/');
else
ustr1new = ustr1;
if (ustr2.lastIndexOf(reverseSlash) != -1)
ustr2new = ustr2.replace(reverseSlash,(sal_Unicode)'/');
else
ustr2new = ustr2;
bOk = ustr1new.equalsIgnoreAsciiCase( ustr2new ) ;
#else
bOk = ustr1.equalsIgnoreAsciiCase( ustr2 );
#endif
return bOk;
}
/** compare a OUString and an ASCII file name.
*/
inline sal_Bool compareFileName( const ::rtl::OUString & ustr, const sal_Char *astr )
{
(void)ustr;
::rtl::OUString ustr1 = rtl::OUString::createFromAscii( astr );
sal_Bool bOk = ustr1.equalsIgnoreAsciiCase( ustr1 );
return bOk;
}
/** simple version to judge if a file name or directory name is a URL or a system path, just to see if it
is start with "file:///";.
*/
inline sal_Bool isURL( const sal_Char *pathname )
{
return ( 0 == strncmp( pathname, FILE_PREFIX, sizeof( FILE_PREFIX ) - 1 ) );
}
/** simple version to judge if a file name or directory name is a URL or a system path, just to see if it
is start with "file:///";.
*/
inline sal_Bool isURL( const ::rtl::OUString pathname )
{
return ( ( pathname.indexOf( aPreURL ) == 0 ) ? sal_True : sal_False );
}
/** concat two part to form a URL or system path, add PATH_SEPERATOR between them if necessary, add "file:///" to beginning if necessary.
*/
inline void concatURL( ::rtl::OUString & pathname1, const ::rtl::OUString & pathname2 )
{
//check if pathname1 is full qualified URL;
if ( !isURL( pathname1 ) )
{
::rtl::OUString aPathName = pathname1.copy( 0 );
::osl::FileBase::getFileURLFromSystemPath( pathname1, aPathName ); //convert if not full qualified URL
pathname1 = aPathName.copy( 0 );
}
sal_Int32 index = 0;
//check if '/' is in the end of pathname1 or at the begin of pathname2;
if ( ( ( index = pathname1.lastIndexOf( aSlashURL ) ) != ( pathname1.getLength( ) - 1 ) ) &&
( ( index = pathname2.indexOf( aSlashURL ) ) != 0 ) )
pathname1 += aSlashURL;
pathname1 += pathname2;
}
/** create a temp test file using OUString name of full qualified URL or system path.
*/
inline void createTestFile( const ::rtl::OUString filename )
{
::rtl::OUString aPathURL = filename.copy( 0 );
::osl::FileBase::RC nError;
if ( !isURL( filename ) )
::osl::FileBase::getFileURLFromSystemPath( filename, aPathURL ); //convert if not full qualified URL
//::std::auto_ptr<File> pFile( new File( aPathURL ) );
File aFile(aPathURL);
//nError = pFile->open( OpenFlag_Read | OpenFlag_Write | OpenFlag_Create );
nError = aFile.open( OpenFlag_Read | OpenFlag_Write | OpenFlag_Create );
//ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_EXIST )) << "In createTestFile Function: creation ";
if ( ( ::osl::FileBase::E_None != nError ) && ( nError != ::osl::FileBase::E_EXIST ))
{
printf("createTestFile failed!\n");
}
aFile.close();
}
/** create a temp test file using OUString name of full qualified URL or system path in a base directory.
*/
inline void createTestFile( const ::rtl::OUString basename, const ::rtl::OUString filename )
{
::rtl::OUString aBaseURL = basename.copy( 0 );
concatURL( aBaseURL, filename );
createTestFile( aBaseURL );
}
/** detete a temp test file using OUString name.
*/
inline void deleteTestFile( const ::rtl::OUString filename )
{
// LLA: printf("deleteTestFile\n");
::rtl::OUString aPathURL = filename.copy( 0 );
::osl::FileBase::RC nError;
if ( !isURL( filename ) )
::osl::FileBase::getFileURLFromSystemPath( filename, aPathURL ); //convert if not full qualified URL
nError = ::osl::File::setAttributes( aPathURL, Attribute_GrpWrite| Attribute_OwnWrite| Attribute_OthWrite ); // if readonly, make writtenable.
ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) || ( ::osl::FileBase::E_NOENT == nError )) << "In deleteTestFile Function: set writtenable ";
nError = ::osl::File::remove( aPathURL );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_NOENT )) << "In deleteTestFile Function: remove ";
}
/** delete a temp test file using OUString name of full qualified URL or system path in a base directory.
*/
inline void deleteTestFile( const ::rtl::OUString basename, const ::rtl::OUString filename )
{
::rtl::OUString aBaseURL = basename.copy( 0 );
concatURL( aBaseURL, filename );
deleteTestFile( aBaseURL );
}
/** create a temp test directory using OUString name of full qualified URL or system path.
*/
inline void createTestDirectory( const ::rtl::OUString dirname )
{
::rtl::OUString aPathURL = dirname.copy( 0 );
::osl::FileBase::RC nError;
if ( !isURL( dirname ) )
::osl::FileBase::getFileURLFromSystemPath( dirname, aPathURL ); //convert if not full qualified URL
nError = ::osl::Directory::create( aPathURL );
//ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_EXIST )) << "In createTestDirectory Function: creation: ";
if ( ( ::osl::FileBase::E_None != nError ) && ( nError != ::osl::FileBase::E_EXIST ))
printf("createTestDirectory failed!\n");
}
/** create a temp test directory using OUString name of full qualified URL or system path in a base directory.
*/
inline void createTestDirectory( const ::rtl::OUString basename, const ::rtl::OUString dirname )
{
::rtl::OUString aBaseURL = basename.copy( 0 );
::rtl::OString aString;
concatURL( aBaseURL, dirname );
createTestDirectory( aBaseURL );
}
/** delete a temp test directory using OUString name of full qualified URL or system path.
*/
inline void deleteTestDirectory( const ::rtl::OUString dirname )
{
// LLA: printf("deleteTestDirectory\n");
::rtl::OUString aPathURL = dirname.copy( 0 );
::osl::FileBase::RC nError;
// LLA: printFileName(aPathURL);
if ( !isURL( dirname ) )
::osl::FileBase::getFileURLFromSystemPath( dirname, aPathURL ); //convert if not full qualified URL
::osl::Directory testDir( aPathURL );
if ( testDir.isOpen( ) == sal_True )
{
// LLA: printf("#close Dir\n");
testDir.close( ); //close if still open.
}
nError = ::osl::Directory::remove( aPathURL );
// LLA: printError(nError);
// LLA: if (( ::osl::FileBase::E_None == nError ))
// LLA: {
// LLA: printf("nError == E_None\n");
// LLA: }
// LLA: else if ( ( nError == ::osl::FileBase::E_NOENT ))
// LLA: {
// LLA: printf("nError == E_NOENT\n");
// LLA: }
// LLA: else
// LLA: {
// LLA: // printf("nError == %d\n", nError);
// LLA: }
rtl::OUString strError = rtl::OUString::createFromAscii( "In deleteTestDirectory function: remove Directory ");
strError += aPathURL;
EXPECT_TRUE(( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_NOENT )) << strError.pData;
// LLA: if (! ( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_NOENT ))
// LLA: {
// LLA: printf("In deleteTestDirectory function: remove\n");
// LLA: }
}
/** delete a temp test directory using OUString name of full qualified URL or system path in a base directory.
*/
inline void deleteTestDirectory( const ::rtl::OUString basename, const ::rtl::OUString dirname )
{
::rtl::OUString aBaseURL = basename.copy( 0 );
concatURL( aBaseURL, dirname );
deleteTestDirectory( aBaseURL );
}
/** Check for the file and directory access right.
*/
typedef enum {
osl_Check_Mode_Exist,
osl_Check_Mode_OpenAccess,
osl_Check_Mode_ReadAccess,
osl_Check_Mode_WriteAccess
} oslCheckMode;
// not used here
inline sal_Bool checkFile( const ::rtl::OUString & str, oslCheckMode nCheckMode )
{
::osl::FileBase::RC nError1, nError2;
::osl::File testFile( str );
sal_Bool bCheckResult;
bCheckResult = sal_False;
nError1 = testFile.open ( OpenFlag_Read );
if ( ( ::osl::FileBase::E_NOENT != nError1 ) && ( ::osl::FileBase::E_ACCES != nError1 ) ){
switch ( nCheckMode ) {
case osl_Check_Mode_Exist:
/// check if the file is exist.
if ( ::osl::FileBase::E_None == nError1 )
bCheckResult = sal_True;
break;
case osl_Check_Mode_OpenAccess:
/// check if the file is openable.
if ( ::osl::FileBase::E_None == nError1 )
bCheckResult = sal_True;
break;
case osl_Check_Mode_WriteAccess:
/// check the file name and whether it can be write.
/// write chars into the file.
//testFile.close( );
//testFile.open( OpenFlag_Write );
sal_uInt64 nCount_write;
nError2 = testFile.write( pBuffer_Char, 10, nCount_write );
if ( ::osl::FileBase::E_None == nError2 )
bCheckResult = sal_True;
break;
default:
bCheckResult = sal_False;
}/// swith
nError2 = testFile.close( );
EXPECT_TRUE(nError2 == FileBase::E_None) << " in CheckFile() function, close file ";
}
return bCheckResult;
}
//check if the file exist
inline sal_Bool ifFileExist( const ::rtl::OUString & str )
{
sal_Bool bCheckResult = sal_False;
/*#ifdef WNT
::rtl::OUString aUStr = str.copy( 0 );
if ( isURL( str ) )
::osl::FileBase::getSystemPathFromFileURL( str, aUStr );
::rtl::OString aString = ::rtl::OUStringToOString( aUStr, RTL_TEXTENCODING_ASCII_US );
const char *path = aString.getStr( );
if (( _access( path, 0 ) ) != -1 )
bCheckResult = sal_True;
#else*/
::rtl::OString aString = ::rtl::OUStringToOString( str, RTL_TEXTENCODING_ASCII_US );
// const char *path = aString.getStr( );
::osl::File testFile( str );
bCheckResult = ( osl::FileBase::E_None == testFile.open( OpenFlag_Read ) );
//if (bCheckResult)
//printf("%s exist!\n", path);
//else
//printf("%s not exist!\n", path);
//#endif
return bCheckResult;
}
//check if the file can be written
inline sal_Bool ifFileCanWrite( const ::rtl::OUString & str )
{
sal_Bool bCheckResult = sal_False;
//on Windows, the file has no write right, but can be written
#ifdef WNT
::rtl::OUString aUStr = str.copy( 0 );
if ( isURL( str ) )
::osl::FileBase::getSystemPathFromFileURL( str, aUStr );
::rtl::OString aString = ::rtl::OUStringToOString( aUStr, RTL_TEXTENCODING_ASCII_US );
const char *path = aString.getStr( );
if (( _access( path, 2 ) ) != -1 )
bCheckResult = sal_True;
//on UNX, just test if open success with OpenFlag_Write
#else
::osl::File testFile( str );
bCheckResult = (osl::FileBase::E_None == testFile.open( OpenFlag_Write ));
#endif
return bCheckResult;
}
inline sal_Bool checkDirectory( const ::rtl::OUString & str, oslCheckMode nCheckMode )
{
rtl::OUString aUString;
DirectoryItem rItem;
FileBase::RC rc;
sal_Bool bCheckResult= sal_False;
//::std::auto_ptr<Directory> pDir( new Directory( str ) );
Directory aDir( str );
rc = aDir.open( );
if ( ( ::osl::FileBase::E_NOENT != rc ) && ( ::osl::FileBase::E_ACCES != rc ) ){
switch ( nCheckMode ) {
case osl_Check_Mode_Exist:
if ( rc == ::osl::FileBase::E_None )
bCheckResult = sal_True;
break;
case osl_Check_Mode_OpenAccess:
if ( rc == ::osl::FileBase::E_None )
bCheckResult = sal_True;
break;
case osl_Check_Mode_ReadAccess:
//rc = pDir->getNextItem( rItem, 0 );
rc = aDir.getNextItem( rItem, 0 );
if ( ( rc == ::osl::FileBase::E_None ) || ( rc == ::osl::FileBase::E_NOENT ) )
bCheckResult = sal_True;
else
bCheckResult = sal_False;
break;
case osl_Check_Mode_WriteAccess:
( ( aUString += str ) += aSlashURL ) += aTmpName2;
//if ( ( rc = pDir->create( aUString ) ) == ::osl::FileBase::E_None )
if ( ( rc = Directory::create( aUString ) ) == ::osl::FileBase::E_None )
{
bCheckResult = sal_True;
//rc = pDir->remove( aUString );
rc = Directory::remove( aUString );
EXPECT_TRUE( rc == ::osl::FileBase::E_None );
}
else
bCheckResult = sal_False;
break;
default:
bCheckResult = sal_False;
}// switch
rc = aDir.close( );
EXPECT_TRUE( rc == FileBase::E_None );
}//if
return bCheckResult;
}
/** construct error message
*/
inline ::rtl::OUString outputError( const ::rtl::OUString & returnVal, const ::rtl::OUString & rightVal, const sal_Char * msg = "")
{
::rtl::OUString aUString;
if ( returnVal.equals( rightVal ) )
return aUString;
aUString += ::rtl::OUString::createFromAscii(msg);
aUString += ::rtl::OUString::createFromAscii(": the returned value is '");
aUString += returnVal;
aUString += ::rtl::OUString::createFromAscii("', but the value should be '");
aUString += rightVal;
aUString += ::rtl::OUString::createFromAscii("'.");
return aUString;
}
/** Change file mode, two version in UNIX and Windows;.
*/
#if ( defined UNX ) || ( defined OS2 ) //chmod() method is differ in Windows
inline void changeFileMode( ::rtl::OUString & filepath, sal_Int32 mode )
{
rtl::OString aString;
rtl::OUString aUStr = filepath.copy( 0 );
if ( isURL( filepath ) )
::osl::FileBase::getSystemPathFromFileURL( filepath, aUStr );
aString = ::rtl::OUStringToOString( aUStr, RTL_TEXTENCODING_ASCII_US );
chmod( aString.getStr( ), mode );
}
#else //Windows version
inline void changeFileMode( ::rtl::OUString & filepath, sal_Int32 mode )
{
(void)filepath;
(void)mode;
printf("this method is not implemented yet");
}
#endif
inline ::rtl::OUString getCurrentPID( void );
//------------------------------------------------------------------------
// Beginning of the test cases for FileBase class
//------------------------------------------------------------------------
namespace osl_FileBase
{
#if 0 //~ this function has been deprecated
//---------------------------------------------------------------------
// testing the method
// static inline RC getCanonicalName( const ::rtl::OUString& ustrRequestedURL, ::rtl::OUString& ustrValidURL )
//
// The illegal characters are ;+=[]',\"*\\<>/?:|.
// because getCanonicalName method is not implemented yet and will be deprecated in the future, this test is not necessary.
//---------------------------------------------------------------------
class getCanonicalName:public ::testing::Test
{
public:
::osl::FileBase::RC nError;
};// class getCanonicalName
TEST_F(getCanonicalName, getCanonicalName_001 )
{
::rtl::OUString aUStr_ValidURL;
nError = ::osl::FileBase::getCanonicalName( aCanURL1, aUStr_ValidURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && aUStr_ValidURL.equalsIgnoreAsciiCase( aCanURL1 )) << "test for getCanonicalName function: check valid and unused file name";
}
TEST_F(getCanonicalName, getCanonicalName_002 )
{
::rtl::OUString aUStr_ValidURL;
createTestFile( aCanURL1 );
nError = ::osl::FileBase::getCanonicalName( aCanURL1, aUStr_ValidURL );
deleteTestFile( aCanURL1 );
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && aUStr_ValidURL.equalsIgnoreAsciiCase( aCanURL1 )) << " test for getCanonicalName function: an existed file name, should different from the request, it did not passed(W32)(UNX)";
}
TEST_F(getCanonicalName, getCanonicalName_003 )
{
::rtl::OUString aUStr_ValidURL;
nError = ::osl::FileBase::getCanonicalName ( aCanURL2, aUStr_ValidURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && aUStr_ValidURL.equalsIgnoreAsciiCase( aCanURL2 )) << " test for getCanonicalName function: invalid file name, should different from the request, it did not passed(W32)(UNX)";
}
#endif
//---------------------------------------------------------------------
// testing the method
// static inline RC getAbsoluteFileURL( const ::rtl::OUString& ustrBaseDirectoryURL,
// const ::rtl::OUString& ustrRelativeFileURL,
// ::rtl::OUString& ustrAbsoluteFileURL )
//---------------------------------------------------------------------
class getAbsoluteFileURL:public ::testing::Test
{
protected:
::osl::FileBase aFileBase;
::rtl::OUString aResultURL1, aResultURL2, aResultURL3, aResultURL4, aResultURL5, aResultURL6;
::osl::FileBase::RC nError;
sal_Bool bOk;
public:
void SetUp();
void TearDown();
void check_getAbsoluteFileURL( rtl::OUString const& _suBaseURL, rtl::OString const& _sRelativeURL, ::osl::FileBase::RC _nAssumeError, rtl::OUString const& _suAssumeResultStr );
}; //class getAbsoluteFileURL
/* use coding format as same as getSystemPathFromFileURL*/
// initialization
void getAbsoluteFileURL::SetUp( )
{
sal_Char pResultURL1[] = "/relative/file1";
sal_Char pResultURL2[] = "/relative/file2";
sal_Char pResultURL3[] = "/file3";
sal_Char pResultURL4[] = "/file4";
sal_Char pResultURL5[] = "/canonical.name";
sal_Char pResultURL6[] = "/relative/";
aResultURL1 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL1 ) );
aResultURL2 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL2 ) );
aResultURL3 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL3 ) );
aResultURL4 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL4 ) );
aResultURL5 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL5 ) );
aResultURL6 = aUserDirectoryURL.concat( rtl::OUString::createFromAscii( pResultURL6 ) );
}
void getAbsoluteFileURL::TearDown( )
{
}
// test code
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001)
{
::rtl::OUString aUStr_AbsURL;
::osl::FileBase::RC nError11 = aFileBase.getAbsoluteFileURL( aUserDirectoryURL, aRelURL1, aUStr_AbsURL );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getAbsoluteFileURL(' ");
suError += aUserDirectoryURL;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aRelURL1;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aUStr_AbsURL;
suError += outputError( aUStr_AbsURL, aResultURL1, "' ),");
sal_Bool nError12 = aUStr_AbsURL.equals( aResultURL1 );
::osl::FileBase::RC nError21 = aFileBase.getAbsoluteFileURL( aUserDirectoryURL, aRelURL2, aUStr_AbsURL );
sal_Bool nError22 = aUStr_AbsURL.equals( aResultURL2 );
::osl::FileBase::RC nError31 = aFileBase.getAbsoluteFileURL( aUserDirectoryURL, aRelURL3, aUStr_AbsURL );
sal_Bool nError32 = aUStr_AbsURL.equals( aResultURL3 );
::osl::FileBase::RC nError41 = aFileBase.getAbsoluteFileURL( aUserDirectoryURL, aRelURL4, aUStr_AbsURL );
sal_Bool nError42 = aUStr_AbsURL.equals( aResultURL4 );
printFileName( aUStr_AbsURL );
printFileName( aResultURL6 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError11 ) && ( sal_True == nError12 ) &&
( ::osl::FileBase::E_None == nError21 ) && ( sal_True == nError22 ) &&
( ::osl::FileBase::E_None == nError31 ) && ( sal_True == nError32 ) &&
( ::osl::FileBase::E_None == nError41 ) && ( sal_True == nError42 )) << "test for getAbsoluteFileURL function: valid file name with valid directory";
}
#if ( defined UNX ) || ( defined OS2 ) //Link is not defined in Windows
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_002_1)
{
::rtl::OUString aUStr_AbsURL, aUStr_LnkFileSys( aTempDirectorySys ), aUStr_SrcFileSys( aTempDirectorySys );
( ( aUStr_LnkFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/link.file");
( ( aUStr_SrcFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/canonical.name");
rtl::OString strLinkFileName, strSrcFileName;
strLinkFileName = OUStringToOString( aUStr_LnkFileSys, RTL_TEXTENCODING_ASCII_US );
strSrcFileName = OUStringToOString( aUStr_SrcFileSys, RTL_TEXTENCODING_ASCII_US );
createTestFile( aCanURL1 );
sal_Int32 fd = symlink( strSrcFileName.getStr(), strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
nError = aFileBase.getAbsoluteFileURL( aUserDirectoryURL, aLnkURL1, aUStr_AbsURL );
bOk = aUStr_AbsURL.equals( aResultURL5 );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getAbsoluteFileURL(' ");
suError += aUserDirectoryURL;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aLnkURL1;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aUStr_AbsURL;
suError += outputError( aUStr_AbsURL, aResultURL5, "' ),");
//printFileName(suError);
deleteTestFile( aCanURL1 );
fd = remove( strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) && ( sal_True == bOk )) << "test for getAbsoluteFileURL function: URL contain link( Solaris version )";
}
#else //Windows version
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_002_1)
{
ASSERT_TRUE(1) << "test for getAbsoluteFileURL function: URL contain link( Windows version )";
}
#endif
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_003_1)
{
// LLA: may be a wrong test, aTmpName1 not a real URL
#if 0
::rtl::OUString aUStr_AbsURL;
nError = aFileBase.getAbsoluteFileURL( aTmpName1, aRelURL1, aUStr_AbsURL ); //base dir invalid error
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getAbsoluteFileURL('");
suError += aTmpName1;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aRelURL1;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aUStr_AbsURL;
suError += ::rtl::OUString::createFromAscii("' ),Parameter is invalid. it ignore the invalid base in Windows, did not pass in (W32), the reason maybe caused by the similar bug with getSystemPathFromFileURL() ");
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError )) << suError;
#endif
}
//use ".." in relartive path, the BasePath must exist on the file system
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_004_1)
{
//create two level directories under $Temp/PID/
::rtl::OUString aUStrUpBase = aUserDirectoryURL + ::rtl::OUString::createFromAscii("/test1");
createTestDirectory( aUStrUpBase );
::rtl::OUString aUStrBase = aUserDirectoryURL + ::rtl::OUString::createFromAscii("/test1/dir1");
createTestDirectory( aUStrBase );
::rtl::OUString aUStrRelar = ::rtl::OUString::createFromAscii("../../mytestfile");
::rtl::OUString aUStr_AbsURL;
::rtl::OUString aResultURL6 = aUserDirectoryURL + ::rtl::OUString::createFromAscii("/mytestfile");
nError = aFileBase.getAbsoluteFileURL( aUStrBase, aUStrRelar, aUStr_AbsURL );
bOk = aUStr_AbsURL.equals( aResultURL6 );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getAbsoluteFileURL('");
suError += aUStrBase;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aUStrRelar;
suError += ::rtl::OUString::createFromAscii("', '");
suError += aUStr_AbsURL;
suError += outputError( aUStr_AbsURL, aResultURL6, "' ), did not pass on Win32 ");
deleteTestDirectory( aUStrBase );
deleteTestDirectory( aUStrUpBase );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError ) && ( sal_True == bOk )) << suError.pData;
}
void getAbsoluteFileURL::check_getAbsoluteFileURL( rtl::OUString const& _suBaseURL, rtl::OString const& _sRelativeURL, ::osl::FileBase::RC _nAssumeError, rtl::OUString const& _suAssumeResultStr )
{
rtl::OUString suRelativeURL = rtl::OStringToOUString(_sRelativeURL, RTL_TEXTENCODING_UTF8);
rtl::OString sBaseURL = rtl::OUStringToOString(_suBaseURL, RTL_TEXTENCODING_UTF8);
rtl::OUString suResultURL;
osl::FileBase::RC nError = FileBase::getAbsoluteFileURL( _suBaseURL, suRelativeURL, suResultURL );
rtl::OString sResultURL = rtl::OUStringToOString( suResultURL, RTL_TEXTENCODING_UTF8);
rtl::OString sError = errorToString(nError);
printf("getAbsoluteFileURL('%s','%s') deliver absolute URL: '%s', error '%s'\n", sBaseURL.getStr(), _sRelativeURL.getStr(),sResultURL.getStr(), sError.getStr() );
ASSERT_TRUE(nError == _nAssumeError) << "Assumption is wrong: error number is wrong";
if ( nError == ::osl::FileBase::E_None )
{
sal_Bool bStrAreEqual = _suAssumeResultStr.equals( suResultURL );
ASSERT_TRUE(bStrAreEqual == sal_True) << "Assumption is wrong: ResultURL is not equal to expected URL ";
}
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_1)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/relative/file1") );
check_getAbsoluteFileURL( aUserDirectoryURL, "relative/file1",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_2)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/relative/file2") );
check_getAbsoluteFileURL( aUserDirectoryURL, "relative/./file2",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_3)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/file3") );
check_getAbsoluteFileURL( aUserDirectoryURL, "relative/../file3",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_4)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/file4") );
check_getAbsoluteFileURL( aUserDirectoryURL, "././relative/../file4",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_5)
{
rtl::OUString suAssume;
#if ( defined UNX )
suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/relative/") );
#else
suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/relative") );
#endif
check_getAbsoluteFileURL( aUserDirectoryURL, "././relative/.",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_6)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/.relative") );
check_getAbsoluteFileURL( aUserDirectoryURL, "./.relative",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_7)
{
rtl::OUString suAssume;
#if (defined UNX )
suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/.a/") );
#else //windows
suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/.a") );
#endif
check_getAbsoluteFileURL( aUserDirectoryURL, "./.a/mydir/..",::osl::FileBase::E_None, suAssume );
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_001_8)
{
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/tmp/ok") );
#if ( defined UNX ) || ( defined OS2 )
check_getAbsoluteFileURL( aUserDirectoryURL, "tmp//ok",::osl::FileBase::E_None, suAssume );
#else
check_getAbsoluteFileURL( aUserDirectoryURL, "tmp//ok",::osl::FileBase::E_INVAL, suAssume );
#endif
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_002)
{
#if ( defined UNX ) || ( defined OS2 ) //Link is not defined in Windows
::rtl::OUString aUStr_AbsURL, aUStr_LnkFileSys( aTempDirectorySys ), aUStr_SrcFileSys( aTempDirectorySys );
( ( aUStr_LnkFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/link.file");
( ( aUStr_SrcFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/canonical.name");
rtl::OString strLinkFileName, strSrcFileName;
strLinkFileName = OUStringToOString( aUStr_LnkFileSys, RTL_TEXTENCODING_ASCII_US );
strSrcFileName = OUStringToOString( aUStr_SrcFileSys, RTL_TEXTENCODING_ASCII_US );
createTestFile( aCanURL1 );
sal_Int32 fd = symlink( strSrcFileName.getStr(), strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
rtl::OString sLnkURL = OUStringToOString( aLnkURL1, RTL_TEXTENCODING_ASCII_US );
rtl::OUString suAssume = aUserDirectoryURL.concat( rtl::OUString::createFromAscii("/canonical.name") );
check_getAbsoluteFileURL( aUserDirectoryURL, sLnkURL, ::osl::FileBase::E_None, suAssume );
deleteTestFile( aCanURL1 );
fd = remove( strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
#endif
}
//please see line# 930
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_003)
{
}
TEST_F(getAbsoluteFileURL, getAbsoluteFileURL_004)
{
//create two level directories under $Temp/PID/
::rtl::OUString aUStrUpBase = aUserDirectoryURL + ::rtl::OUString::createFromAscii("/test1");
createTestDirectory( aUStrUpBase );
::rtl::OUString aUStrBase = aUserDirectoryURL + ::rtl::OUString::createFromAscii("/test1/dir1");
createTestDirectory( aUStrBase );
::rtl::OUString suAssume = aUserDirectoryURL.concat( ::rtl::OUString::createFromAscii("/mytestfile") );
check_getAbsoluteFileURL( aUStrBase, "../../mytestfile" , ::osl::FileBase::E_None, suAssume );
deleteTestDirectory( aUStrBase );
deleteTestDirectory( aUStrUpBase );
}
//---------------------------------------------------------------------
// testing two methods:
// static inline RC getSystemPathFromFileURL( const ::rtl::OUString& ustrFileURL,
// ::rtl::OUString& ustrSystemPath )
// static RC getFileURLFromSystemPath( const ::rtl::OUString & ustrSystemPath,
// ::rtl::OUString & ustrFileURL );
//---------------------------------------------------------------------
class SystemPath_FileURL:public ::testing::Test
{
protected:
//::osl::FileBase aFileBase;
// ::rtl::OUString aUStr;
// ::osl::FileBase::RC nError;
//void check_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sAssumeResultStr);
void check_SystemPath_FileURL(rtl::OString const& _sSource, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sAssumeResultStr, sal_Bool bDirection = sal_True );
void checkWNTBehaviour_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sWNTAssumeResultString );
void checkUNXBehaviour_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sUnixAssumeResultString );
void checkWNTBehaviour_getFileURLFromSystemPath(rtl::OString const& _sSysPath, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sWNTAssumeResultString);
void checkUNXBehaviour_getFileURLFromSystemPath(rtl::OString const& _sSysPath, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sUnixAssumeResultString);
};// class SystemPath_FileURL
// test code.
/* void getSystemPathFromFileURL::check_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sAssumeResultStr)
{
// PRE: URL as String
rtl::OUString suURL;
rtl::OUString suStr;
suURL = rtl::OStringToOUString(_sURL, RTL_TEXTENCODING_UTF8);
::osl::FileBase::RC nError = osl::FileBase::getSystemPathFromFileURL( suURL, suStr ); // start with /
// if the given string is gt length 0,
// we check also this string
rtl::OString sStr = rtl::OUStringToOString(suStr, RTL_TEXTENCODING_UTF8);
rtl::OString sError = errorToString(nError);
printf("getSystemPathFromFileURL('%s') deliver system path: '%s', error '%s'\n", _sURL.getStr(), sStr.getStr(), sError.getStr() );
// rtl::OUString suStrEncode = rtl::Uri::encode(suStr, rtl_UriCharClassUnoParamValue, rtl_UriEncodeKeepEscapes, RTL_TEXTENCODING_UTF8);
// sStr = rtl::OUStringToOString(suStr, RTL_TEXTENCODING_UTF8);
// printf("UTF8: %s\n", sStr.getStr() );
if (_sAssumeResultStr.getLength() > 0)
{
sal_Bool bStrAreEqual = _sAssumeResultStr.equals(sStr);
ASSERT_TRUE(nError == _nAssumeError && bStrAreEqual == sal_True) << "Assumption is wrong";
}
else
{
ASSERT_TRUE(nError == _nAssumeError) << "Assumption is wrong";
}
}*/
// if bDirection==sal_True, check getSystemPathFromFileURL
// if bDirection==sal_False, check getFileURLFromSystemPath
void SystemPath_FileURL::check_SystemPath_FileURL(rtl::OString const& _sSource, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sAssumeResultStr, sal_Bool bDirection)
{
// PRE: URL as String
rtl::OUString suSource;
rtl::OUString suStr;
suSource = rtl::OStringToOUString(_sSource, RTL_TEXTENCODING_UTF8);
::osl::FileBase::RC nError;
if ( bDirection == sal_True )
nError = osl::FileBase::getSystemPathFromFileURL( suSource, suStr );
else
nError = osl::FileBase::getFileURLFromSystemPath( suSource, suStr );
// if the given string is gt length 0,
// we check also this string
rtl::OString sStr = rtl::OUStringToOString(suStr, RTL_TEXTENCODING_UTF8);
rtl::OString sError = errorToString(nError);
if ( bDirection == sal_True )
printf("getSystemPathFromFileURL('%s') deliver system path: '%s', error '%s'\n", _sSource.getStr(), sStr.getStr(), sError.getStr() );
else
printf("getFileURLFromSystemPath('%s') deliver File URL: '%s', error '%s'\n", _sSource.getStr(), sStr.getStr(), sError.getStr() );
// rtl::OUString suStrEncode = rtl::Uri::encode(suStr, rtl_UriCharClassUnoParamValue, rtl_UriEncodeKeepEscapes, RTL_TEXTENCODING_UTF8);
// sStr = rtl::OUStringToOString(suStr, RTL_TEXTENCODING_UTF8);
// printf("UTF8: %s\n", sStr.getStr() );
if (_sAssumeResultStr.getLength() > 0)
{
sal_Bool bStrAreEqual = _sAssumeResultStr.equals(sStr);
ASSERT_TRUE(nError == _nAssumeError && bStrAreEqual == sal_True) << "Assumption is wrong";
}
else
{
ASSERT_TRUE(nError == _nAssumeError) << "Assumption is wrong";
}
}
void SystemPath_FileURL::checkWNTBehaviour_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sWNTAssumeResultString)
{
#if ( defined WNT )
check_SystemPath_FileURL(_sURL, _nAssumeError, _sWNTAssumeResultString);
#else
(void)_sURL;
(void)_nAssumeError;
(void)_sWNTAssumeResultString;
#endif
}
void SystemPath_FileURL::checkUNXBehaviour_getSystemPathFromFileURL(rtl::OString const& _sURL, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sUnixAssumeResultString)
{
#if ( defined UNX )
check_SystemPath_FileURL(_sURL, _nAssumeError, _sUnixAssumeResultString);
#else
(void)_sURL;
(void)_nAssumeError;
(void)_sUnixAssumeResultString;
#endif
}
void SystemPath_FileURL::checkWNTBehaviour_getFileURLFromSystemPath(rtl::OString const& _sSysPath, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sWNTAssumeResultString)
{
#if ( defined WNT )
check_SystemPath_FileURL(_sSysPath, _nAssumeError, _sWNTAssumeResultString, sal_False );
#else
(void)_sSysPath;
(void)_nAssumeError;
(void)_sWNTAssumeResultString;
#endif
}
void SystemPath_FileURL::checkUNXBehaviour_getFileURLFromSystemPath(rtl::OString const& _sSysPath, ::osl::FileBase::RC _nAssumeError, rtl::OString const& _sUnixAssumeResultString)
{
#if ( defined UNX )
check_SystemPath_FileURL(_sSysPath, _nAssumeError, _sUnixAssumeResultString, sal_False );
#else
(void)_sSysPath;
(void)_nAssumeError;
(void)_sUnixAssumeResultString;
#endif
}
/** LLA: Test for getSystemPathFromFileURL()
this test is splitted into 2 different OS tests,
the first function checkUNXBehaviour... runs only on Unix based Systems,
the second only on windows based systems
the first parameter are a file URL where we want to get the system path of,
the second parameter is the assumed error of the osl_getSystemPathFromFileURL() function,
the third parameter is the assumed result string, the string will only test, if it's length is greater 0
*/
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_1)
{
rtl::OString sURL("");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_2)
{
rtl::OString sURL("/");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "\\");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_21)
{
// rtl::OString sURL("%2f");
rtl::OString sURL("%2F");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/"); // LLA: this is may be a BUG
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_22)
{
rtl::OString sURL("file:///tmp%2Fmydir");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_3)
{
rtl::OString sURL("a");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "a");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "a");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_31)
{
rtl::OString sURL("tmpname");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "tmpname");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "tmpname");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_4)
{
rtl::OString sURL("file://");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_41)
{
rtl::OString sURL("file://localhost/tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_5)
{
rtl::OString sURL("file:///tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/tmp");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_51)
{
rtl::OString sURL("file://c:/tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:/tmp"); // LLA: this is may be a BUG
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_52)
{
rtl::OString sURL("file:///c:/tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/c:/tmp");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:\\tmp");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_53)
{
// LLA: is this a legal file path?
rtl::OString sURL("file:///c|/tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/c|/tmp");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:\\tmp");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_6)
{
rtl::OString sURL("file:///tmp/first");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/tmp/first");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_61)
{
rtl::OString sURL("file:///c:/tmp/first");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/c:/tmp/first");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:\\tmp\\first");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_7)
{
rtl::OString sURL("file:///tmp/../second");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/tmp/../second"); // LLA: may be a BUG
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_71)
{
rtl::OString sURL("file:///c:/tmp/../second");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/c:/tmp/../second");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:\\tmp\\..\\second");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_8)
{
rtl::OString sURL("../tmp");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "../tmp");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "..\\tmp");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_81)
{
rtl::OString sURL("file://~/tmp");
char* home_path;
home_path = getenv("HOME");
rtl::OString expResult(home_path);
expResult += "/tmp";
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, expResult );
// checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "\\tmp");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_9)
{
rtl::OString sURL("file:///tmp/first%20second");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/tmp/first second");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_91)
{
rtl::OString sURL("file:///c:/tmp/first%20second");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "/c:/tmp/first second");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "c:\\tmp\\first second");
}
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_001_92)
{
rtl::OString sURL("ca@#;+.,$///78no%01ni..name");
checkUNXBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_None, "");
checkWNTBehaviour_getSystemPathFromFileURL(sURL, osl::FileBase::E_INVAL, "");
}
#if 0
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_003)
{
// LLA: ???
//!! seems to be, that the directories do not pass together
::rtl::OUString aUStr;
::rtl::OUString aRelativeURL = ::rtl::OUString::createFromAscii("../../relartive/file3");
::rtl::OUString aResultURL ( aSysPath4 );
::osl::FileBase::RC nError = osl::FileBase::getSystemPathFromFileURL( aRelativeURL, aUStr );
sal_Bool bOk = compareFileName( aUStr, aResultURL );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getSystemPathFromFileURL(");
suError += aRelativeURL;
suError += ::rtl::OUString::createFromAscii(") function:use a relative file URL, did not pass in(W32), it did not specified in method declaration of relative path issue, ");
suError += outputError(aUStr, aResultURL);
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && ( sal_True == bOk )) << suError;
}
#endif
//normal legal case
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_004)
{
::rtl::OUString aUStr;
::rtl::OUString aNormalURL( aTmpName6 );
::rtl::OUString aResultURL ( aSysPath4 );
::osl::FileBase::RC nError = osl::FileBase::getSystemPathFromFileURL( aNormalURL, aUStr );
sal_Bool bOk = compareFileName( aUStr, aResultURL );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getSystemPathFromFileURL(' ");
suError += aNormalURL;
suError += ::rtl::OUString::createFromAscii(" ') function:use an absolute file URL, ");
suError += outputError(aUStr, aResultURL);
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && ( sal_True == bOk )) << suError.pData;
}
//CJK characters case
TEST_F(SystemPath_FileURL, getSystemPathFromFileURL_005)
{
::rtl::OUString aUStr;
createTestDirectory( aTmpName10 );
::rtl::OUString aNormalURL( aTmpName10 );
::rtl::OUString aResultURL ( aSysPath5 );
::osl::FileBase::RC nError = osl::FileBase::getSystemPathFromFileURL( aNormalURL, aUStr );
sal_Bool bOk = compareFileName( aUStr, aResultURL );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for getSystemPathFromFileURL(' ");
suError += aNormalURL;
suError += ::rtl::OUString::createFromAscii(" ') function:use a CJK coded absolute URL, ");
suError += outputError(aUStr, aResultURL);
deleteTestDirectory( aTmpName10 );
ASSERT_TRUE(( osl::FileBase::E_None == nError ) && ( sal_True == bOk )) << suError.pData;
}
TEST_F(SystemPath_FileURL, getFileURLFromSystemPath_001)
{
rtl::OString sSysPath("~/tmp");
char* home_path;
home_path = getenv("HOME");
rtl::OString expResult(home_path);
expResult = "file://"+ expResult + "/tmp";
checkUNXBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_None, expResult );
checkWNTBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_None, "~/tmp");
}
TEST_F(SystemPath_FileURL, getFileURLFromSystemPath_002)
{
rtl::OString sSysPath("c:/tmp");
checkUNXBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_None, "c:/tmp");
checkWNTBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_None, "file:///c:/tmp");
}
TEST_F(SystemPath_FileURL, getFileURLFromSystemPath_003)
{
rtl::OString sSysPath("file:///temp");
checkUNXBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_INVAL, "");
checkWNTBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getFileURLFromSystemPath_004)
{
rtl::OString sSysPath("//tmp//first start");
checkUNXBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_None, "file:///tmp/first%20start");
checkWNTBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_INVAL, "");
}
TEST_F(SystemPath_FileURL, getFileURLFromSystemPath_005)
{
rtl::OString sSysPath("");
checkUNXBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_INVAL, "");
checkWNTBehaviour_getFileURLFromSystemPath(sSysPath, osl::FileBase::E_INVAL, "");
}
// start with "~user", not impletment
// void SystemPath_FileURL::getFileURLFromSystemPath_006()
//---------------------------------------------------------------------
// testing the method
// static inline RC searchFileURL( const ::rtl::OUString& ustrFileName,
// const ::rtl::OUString& ustrSearchPath,
// ::rtl::OUString& ustrFileURL )
//---------------------------------------------------------------------
class searchFileURL:public ::testing::Test
{
protected:
//::osl::FileBase aFileBase;
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2, nError3,nError4;
public:
};// class searchFileURL
// test code.
TEST_F(searchFileURL, searchFileURL_001 )
{
/* search file is passed by system filename */
nError1 = ::osl::FileBase::searchFileURL( aTmpName1, aUserDirectorySys, aUStr );
/* search file is passed by full qualified file URL */
nError2 = ::osl::FileBase::searchFileURL( aCanURL1, aUserDirectorySys, aUStr );
/* search file is passed by relative file path */
nError3 = ::osl::FileBase::searchFileURL( aRelURL4, aUserDirectorySys, aUStr );
ASSERT_TRUE(( osl::FileBase::E_NOENT == nError1 ) &&
( osl::FileBase::E_NOENT == nError2 ) &&
( osl::FileBase::E_NOENT == nError3 )) << "test for searchFileURL function: system filename/URL filename/relative path, system directory, searched files that is not exist, but it reply invalid error, did not pass in (W32) ";
}
TEST_F(searchFileURL, searchFileURL_002 )
{
/* search file is passed by system filename */
nError1 = ::osl::FileBase::searchFileURL( aTempDirectorySys, aRootSys, aUStr );
sal_Bool bOk1 = compareFileName( aUStr, aTempDirectoryURL );
/* search file is passed by full qualified file URL */
nError2 = ::osl::FileBase::searchFileURL( aTempDirectoryURL, aRootSys, aUStr );
sal_Bool bOk2 = compareFileName( aUStr, aTempDirectoryURL );
/* search file is passed by relative file path */
nError3 = ::osl::FileBase::searchFileURL( aRelURL5, aRootSys, aUStr );
sal_Bool bOk3 = compareFileName( aUStr, aTempDirectoryURL );
/* search file is passed by an exist file */
createTestFile( aCanURL1 );
nError4 = ::osl::FileBase::searchFileURL( aCanURL4, aUserDirectorySys, aUStr );
sal_Bool bOk4 = compareFileName( aUStr, aCanURL1 );
deleteTestFile( aCanURL1 );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( osl::FileBase::E_None == nError2 ) &&
( osl::FileBase::E_None == nError3 ) &&
( osl::FileBase::E_None == nError4 ) &&
( sal_True == bOk1 ) &&
( sal_True == bOk2 ) &&
( sal_True == bOk3 ) &&
( sal_True == bOk4 )) << "test for searchFileURL function: system filename/URL filename/relative path, system directory, searched file already exist.";
}
TEST_F(searchFileURL, searchFileURL_003 )
{
OSLTEST_DECLARE( SystemPathList, TEST_PLATFORM_ROOT":"TEST_PLATFORM_ROOT TEST_PLATFORM_TEMP":"TEST_PLATFORM_ROOT"system/path" );
nError1 = ::osl::FileBase::searchFileURL( aUserDirectoryURL, aSystemPathList, aUStr );
sal_Bool bOk = compareFileName( aUStr, aUserDirectoryURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( sal_True == bOk )) << "test for searchFileURL function: search directory is a list of system paths";
}
TEST_F(searchFileURL, searchFileURL_004 )
{
OSLTEST_DECLARE( SystemPathList, TEST_PLATFORM_ROOT PATH_LIST_DELIMITER TEST_PLATFORM_ROOT TEST_PLATFORM_TEMP PATH_LIST_DELIMITER TEST_PLATFORM_ROOT "system/path/../name" );
nError1 = ::osl::FileBase::searchFileURL( aUserDirectoryURL, aSystemPathList, aUStr );
sal_Bool bOk = compareFileName( aUStr, aUserDirectoryURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( sal_True == bOk )) << "test for searchFileURL function: search directory is a list of system paths";
}
TEST_F(searchFileURL, searchFileURL_005 )
{
nError1 = ::osl::FileBase::searchFileURL( aUserDirectoryURL, aNullURL, aUStr );
sal_Bool bOk = compareFileName( aUStr, aUserDirectoryURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( sal_True == bOk )) << "test for searchFileURL function: search directory is NULL";
}
//---------------------------------------------------------------------
// testing the method
// static inline RC getTempDirURL( ::rtl::OUString& ustrTempDirURL )
//---------------------------------------------------------------------
class getTempDirURL:public ::testing::Test
{
protected:
//::osl::FileBase aFileBase;
::rtl::OUString aUStr;
::osl::FileBase::RC nError;
public:
// initialization
void SetUp( )
{
nError = FileBase::getTempDirURL( aUStr );
}
void TearDown( )
{
}
};// class getTempDirURL
TEST_F(getTempDirURL, getTempDirURL_001 )
{
ASSERT_TRUE(( osl::FileBase::E_None == nError )) << "test for getTempDirURL function: excution";
}
TEST_F(getTempDirURL, getTempDirURL_002 )
{
ASSERT_TRUE(checkDirectory( aUStr, osl_Check_Mode_OpenAccess ) &&
checkDirectory( aUStr, osl_Check_Mode_ReadAccess ) &&
checkDirectory( aUStr,osl_Check_Mode_WriteAccess )) << "test for getTempDirURL function: test for open and write access rights";
}
//---------------------------------------------------------------------
// testing the method
// static inline RC createTempFile( ::rtl::OUString* pustrDirectoryURL,
// oslFileHandle* pHandle,
// ::rtl::OUString* pustrTempFileURL)
//---------------------------------------------------------------------
class createTempFile:public ::testing::Test
{
protected:
//::osl::FileBase aFileBase;
::osl::FileBase::RC nError1, nError2;
sal_Bool bOK;
oslFileHandle *pHandle;
::rtl::OUString *pUStr_DirURL;
::rtl::OUString *pUStr_FileURL;
public:
// initialization
void SetUp( )
{
pHandle = new oslFileHandle();
pUStr_DirURL = new ::rtl::OUString( aUserDirectoryURL );
pUStr_FileURL = new ::rtl::OUString();
//*pUStr_DirURL = aUserDirectoryURL; /// create temp file in /tmp/PID or c:\temp\PID.*/
}
void TearDown( )
{
delete pUStr_DirURL;
delete pUStr_FileURL;
delete pHandle;
}
};// class createTempFile
TEST_F(createTempFile, createTempFile_001 )
{
nError1 = FileBase::createTempFile( pUStr_DirURL, pHandle, pUStr_FileURL );
::osl::File testFile( *pUStr_FileURL );
//printFileName(*pUStr_FileURL);
nError2 = testFile.open( OpenFlag_Create );
if ( osl::FileBase::E_EXIST == nError2 ) {
osl_closeFile( *pHandle );
deleteTestFile( *pUStr_FileURL );
}
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) && ( pHandle != NULL ) && ( osl::FileBase::E_EXIST== nError2 )) << "test for createTempFile function: create temp file and test the existence";
}
TEST_F(createTempFile, createTempFile_002 )
{
bOK = sal_False;
nError1 = FileBase::createTempFile( pUStr_DirURL, pHandle, pUStr_FileURL );
::osl::File testFile( *pUStr_FileURL );
nError2 = testFile.open( OpenFlag_Create );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) && ( pHandle != NULL ) &&
( osl::FileBase::E_EXIST == nError2 )) << "createTempFile function: create a temp file, but it does not exist";
//check file if have the write permission
if ( osl::FileBase::E_EXIST == nError2 ) {
bOK = ifFileCanWrite( *pUStr_FileURL );
osl_closeFile( *pHandle );
deleteTestFile( *pUStr_FileURL );
}
ASSERT_TRUE(( sal_True == bOK )) << "test for open and write access rights, in (W32), it did not have write access right, but it should be writtenable.";
}
TEST_F(createTempFile, createTempFile_003 )
{
nError1 = FileBase::createTempFile( pUStr_DirURL, pHandle, 0 );
//the temp file will be removed when return from createTempFile
bOK = ( pHandle != NULL && pHandle != 0);
if ( sal_True == bOK )
osl_closeFile( *pHandle );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&( sal_True == bOK )) << "test for createTempFile function: set pUStrFileURL to 0 to let it remove the file after call.";
}
TEST_F(createTempFile, createTempFile_004 )
{
nError1 = FileBase::createTempFile( pUStr_DirURL, 0, pUStr_FileURL );
bOK = ( pUStr_FileURL != 0);
::osl::File testFile( *pUStr_FileURL );
nError2 = testFile.open( OpenFlag_Create );
deleteTestFile( *pUStr_FileURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) && ( osl::FileBase::E_EXIST == nError2 ) &&( sal_True == bOK )) << "createTempFile function: create a temp file, but it does not exist";
}
}// namespace osl_FileBase
//------------------------------------------------------------------------
// Beginning of the test cases for VolumeDevice class
//------------------------------------------------------------------------
#if 0 //~ this Class has been deprecated
namespace osl_VolumeDevice
{
//---------------------------------------------------------------------
// testing the method
// VolumeDevice() : _aHandle( NULL )
//---------------------------------------------------------------------
class VolumeDeviceCtors : public ::testing::Test
{
protected:
::osl::VolumeDevice aVolumeDevice;
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
}
void TearDown( )
{
}
};// class ctors
TEST_F(VolumeDeviceCtors, ctors_001 )
{
::osl::VolumeDevice aVolumeDevice1;
ASSERT_TRUE(( osl::FileBase::E_None != aVolumeDevice1.automount( ) ) &&
( osl::FileBase::E_None != aVolumeDevice1.unmount( ) ) &&
( aNullURL.equals( aVolumeDevice1.getMountPath( ) ) )) << "test for ctors function: Constructor for VolumeDevice with no args.";
}
TEST_F(VolumeDeviceCtors, ctors_002 )
{
::osl::VolumeInfo aVolumeInfo( VolumeInfoMask_Attributes );
nError1 = ::osl::Directory::getVolumeInfo( aRootURL, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
::osl::VolumeDevice aVolumeDevice1( aVolumeInfo.getDeviceHandle( ) );
sal_Bool bOk = compareFileName( aNullURL, aVolumeDevice1.getMountPath( ) );
ASSERT_TRUE(sal_False == bOk) << "test for ctors function: Copy constructor for VolumeDevice, the copied VolumeDevice should have a mount path file:///, but it returned an empty OUString, it also may be the error from getDeviceHandle(), it did not pass in (UNX), (W32).";
}
TEST_F(VolumeDeviceCtors, ctors_003 )
{
::osl::VolumeInfo aVolumeInfo( VolumeInfoMask_Attributes );
nError1 = ::osl::Directory::getVolumeInfo( aRootURL, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
::osl::VolumeDevice aVolumeDevice1 = aVolumeInfo.getDeviceHandle( );
sal_Bool bOk = compareFileName( aNullURL, aVolumeDevice1.getMountPath( ) );
ASSERT_TRUE(sal_False == bOk) << "test for ctors function: Assigned operator for VolumeDevice, the assigned VolumeDevice should have a mount path file:///, but it returned an empty OUString, it also may be the error from getDeviceHandle(),it did not pass in (UNX), (W32).";
}
//---------------------------------------------------------------------
// testing the method
// inline RC automount()
//---------------------------------------------------------------------
class automount : public ::testing::Test
{
protected:
::osl::VolumeDevice aVolumeDevice;
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
}
void TearDown( )
{
}
};// class automount
TEST_F(automount, automount_001 )
{
::osl::VolumeDevice aVolumeDevice1;
nError1 = aVolumeDevice1.automount( );
ASSERT_TRUE(( osl::FileBase::E_INVAL == nError1 )) << "test for automount function: invalid parameter.";
}
TEST_F(automount, automount_002 )
{
::osl::VolumeInfo aVolumeInfo( VolumeInfoMask_Attributes );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL2, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
::osl::VolumeDevice aVolumeDevice1( aVolumeInfo.getDeviceHandle( ) );
nError1 = aVolumeDevice1.unmount( );
nError1 = aVolumeDevice1.automount( );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 )) << "test for automount function: this test is not implemented yet, it did not pass in (UNX), (W32).";
}
}// namespace osl_VolumeDevice
#endif
//------------------------------------------------------------------------
// Beginning of the test cases for VolumeInfo class
//------------------------------------------------------------------------
namespace osl_VolumeInfo
{
//---------------------------------------------------------------------
// testing the method
// VolumeInfo( sal_uInt32 nMask ): _nMask( nMask )
//---------------------------------------------------------------------
class VolumeInfoCtors : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
::osl::VolumeDevice aVolumeDevice1;
public:
// initialization
void SetUp( )
{
}
void tearDown( )
{
}
};// class ctors
TEST_F(VolumeInfoCtors, ctors_001 )
{
::osl::VolumeInfo aVolumeInfo( 0 );
nError1 = ::osl::Directory::getVolumeInfo( aRootURL, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_uInt64 uiTotalSpace = aVolumeInfo.getTotalSpace( );
sal_uInt32 uiMaxPathLength = aVolumeInfo.getMaxPathLength( );
aUStr = aVolumeInfo.getFileSystemName( );
ASSERT_TRUE(( 0 == uiTotalSpace ) &&
( 0 == uiMaxPathLength ) &&
sal_True == compareFileName( aUStr, aNullURL )) << "test for ctors function: mask is empty";
}
#if ( defined UNX ) || ( defined OS2 )
TEST_F(VolumeInfoCtors, ctors_002 )
{
::osl::VolumeInfo aVolumeInfo( VolumeInfoMask_TotalSpace |
VolumeInfoMask_UsedSpace |
VolumeInfoMask_FileSystemName );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL4, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
//ASSERT_TRUE( aVolumeInfo.isValid( mask ) );
sal_uInt64 uiTotalSpace = aVolumeInfo.getTotalSpace( );
sal_uInt64 uiUsedSpace = aVolumeInfo.getUsedSpace( );
aUStr = aVolumeInfo.getFileSystemName( );
ASSERT_TRUE(( 0 != uiTotalSpace ) &&
( 0 != uiUsedSpace ) &&
sal_True == compareFileName( aUStr, "nfs" )) << "test for ctors function: mask is specified as certain valid fields, and get the masked fields";
}
#else /// Windows version,here we can not determine whichvolume in Windows is serve as an nfs volume.
TEST_F(VolumeInfoCtors, ctors_002 )
{
ASSERT_TRUE(1 == 1) << "test for ctors function: mask is specified as certain valid fields, and get the masked fields( Windows version )";
}
#endif
TEST_F(VolumeInfoCtors, ctors_003 )
{
sal_Int32 mask1 = VolumeInfoMask_FreeSpace;
::osl::VolumeInfo aVolumeInfo1( mask1 );
nError1 = ::osl::Directory::getVolumeInfo( aRootURL, aVolumeInfo1 );
ASSERT_TRUE( sal_True == aVolumeInfo1.isValid( mask1 ) );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_uInt64 uiTotalSpace1 = aVolumeInfo1.getTotalSpace( );
aUStr = aVolumeInfo1.getFileSystemName( );
sal_Int32 mask2 = VolumeInfoMask_TotalSpace;
::osl::VolumeInfo aVolumeInfo2( mask2 );
nError2 = ::osl::Directory::getVolumeInfo( aRootURL, aVolumeInfo2 );
ASSERT_TRUE( sal_True == aVolumeInfo2.isValid( mask2 ) );
ASSERT_TRUE( osl::FileBase::E_None == nError2 );
sal_uInt64 uiTotalSpace2 = aVolumeInfo2.getTotalSpace( );
ASSERT_TRUE(( 0 == uiTotalSpace1 ) && ( 0 != uiTotalSpace2 ) &&
sal_True == compareFileName( aUStr, aNullURL )) << "test for ctors function: mask is specified as certain valid fields, but get unmasked fields, use mask to FreeSpace, but I can get TotalSpace, did not pass in (UNX)(W32)";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool isValid( sal_uInt32 nMask ) const
//---------------------------------------------------------------------
class VolumeInfoIsValid : public ::testing::Test
{
protected:
::osl::VolumeDevice aVolumeDevice;
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
}
void TearDown( )
{
}
};// class isValid
TEST_F(VolumeInfoIsValid, isValid_001 )
{
sal_Int32 mask = 0;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL4, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE(sal_True == aVolumeInfo.isValid( mask )) << "test for isValid function: no fields specified.";
}
#if ( defined UNX ) || ( defined OS2 )
TEST_F(VolumeInfoIsValid, isValid_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes | VolumeInfoMask_TotalSpace | osl_VolumeInfo_Mask_UsedSpace |
osl_VolumeInfo_Mask_FreeSpace | osl_VolumeInfo_Mask_MaxNameLength |
osl_VolumeInfo_Mask_MaxPathLength | osl_VolumeInfo_Mask_FileSystemName;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL4, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE(sal_True == aVolumeInfo.isValid( mask )) << "test for isValid function: all valid fields specified for a nfs volume.";
}
#else /// Windows version,here we can not determine whichvolume in Windows is serve as an nfs volume.
TEST_F(VolumeInfoIsValid, isValid_002 )
{
ASSERT_TRUE(1 == 1) << "test for isValid function: all valid fields specified for a nfs volume.( Windows version )";
}
#endif
TEST_F(VolumeInfoIsValid, isValid_003 )
{
::osl::VolumeDevice aVolumeDevice1;
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk1 = aVolumeInfo.isValid( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL2, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk2 = aVolumeInfo.isValid( mask );
ASSERT_TRUE(( sal_True == bOk1 ) && ( sal_True == bOk2 )) << "test for isValid function: VolumeInfoMask_Attributes, it should be valid for some volume such as /, floppy, cdrom, etc. but it did not pass";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getRemoteFlag() const
//---------------------------------------------------------------------
class getRemoteFlag : public ::testing::Test
{
protected:
::osl::VolumeDevice aVolumeDevice;
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
};// class getRemoteFlag
TEST_F(getRemoteFlag, getRemoteFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRemoteFlag( );
ASSERT_TRUE(( sal_False == bOk )) << "test for getRemoteFlag function: get a volume device which is not remote.";
}
#if ( defined UNX ) || ( defined OS2 ) //remote Volume is different in Solaris and Windows
TEST_F(getRemoteFlag, getRemoteFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL4, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRemoteFlag( );
ASSERT_TRUE(( sal_True == bOk )) << "test for getRemoteFlag function: get a volume device which is remote( Solaris version ).";
}
#else //Windows version
TEST_F(getRemoteFlag, getRemoteFlag_002 )
{
ASSERT_TRUE(1 == 1) << "test for getRemoteFlag function: get a volume device which is remote( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getRemoveableFlag() const
//---------------------------------------------------------------------
class getRemoveableFlag : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
};// class getRemoveableFlag
TEST_F(getRemoveableFlag, getRemoveableFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRemoveableFlag( );
ASSERT_TRUE(sal_False == bOk) << "test for getRemoveableFlag function: get a volume device which is not removable.";
}
TEST_F(getRemoveableFlag, getRemoveableFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL2, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRemoveableFlag( );
ASSERT_TRUE(sal_True == bOk) << "test for getRemoveableFlag function: get a volume device which is removable, not sure, here we use floppy disk, but it did not pass.";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getCompactDiscFlag() const
//---------------------------------------------------------------------
class getCompactDiscFlag : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getCompactDiscFlag
TEST_F(getCompactDiscFlag, getCompactDiscFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getCompactDiscFlag( );
ASSERT_TRUE(( sal_False == bOk )) << "test for getCompactDiscFlag function: get a volume device which is not a cdrom.";
}
TEST_F(getCompactDiscFlag, getCompactDiscFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL6, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getCompactDiscFlag( );
ASSERT_TRUE(( sal_True == bOk )) << "test for getCompactDiscFlag function: get a cdrom volume device flag, it did not pass.";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getFloppyDiskFlag() const
//---------------------------------------------------------------------
class getFloppyDiskFlag : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getFloppyDiskFlag
TEST_F(getFloppyDiskFlag, getFloppyDiskFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getFloppyDiskFlag( );
ASSERT_TRUE(( sal_False == bOk )) << "test for getFloppyDiskFlag function: get a volume device which is not a floppy disk.";
}
TEST_F(getFloppyDiskFlag, getFloppyDiskFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL2, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getFloppyDiskFlag( );
ASSERT_TRUE(( sal_True == bOk )) << "test for getFloppyDiskFlag function: get a floppy volume device flag, it did not pass.";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getFixedDiskFlag() const
//---------------------------------------------------------------------
class getFixedDiskFlag : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getFixedDiskFlag
TEST_F(getFixedDiskFlag, getFixedDiskFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL2, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getFixedDiskFlag( );
ASSERT_TRUE(( sal_False == bOk )) << "test for getFixedDiskFlag function: get a volume device which is not a fixed disk.";
}
TEST_F(getFixedDiskFlag, getFixedDiskFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getFixedDiskFlag( );
ASSERT_TRUE(( sal_True == bOk )) << "test for getFixedDiskFlag function: get a fixed disk volume device flag, it did not pass.";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool getRAMDiskFlag() const
//---------------------------------------------------------------------
class getRAMDiskFlag : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getRAMDiskFlag
TEST_F(getRAMDiskFlag, getRAMDiskFlag_001 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRAMDiskFlag( );
ASSERT_TRUE(( sal_False == bOk )) << "test for getRAMDiskFlag function: get a volume device which is not a RAM disk.";
}
TEST_F(getRAMDiskFlag, getRAMDiskFlag_002 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
sal_Bool bOk = aVolumeInfo.getRAMDiskFlag( );
ASSERT_TRUE(( sal_True == bOk )) << "test for getRAMDiskFlag function: FIX ME, don't know how to get a RAM disk flag, perhaps Windows 98 boot disk can create a RAM disk, it did not pass in (UNX)(W32).";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt64 getTotalSpace() const
//---------------------------------------------------------------------
class getTotalSpace : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getTotalSpace
TEST_F(getTotalSpace, getTotalSpace_001 )
{
sal_Int32 mask = VolumeInfoMask_TotalSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiTotalSpace = aVolumeInfo.getTotalSpace( );
ASSERT_TRUE(0 != uiTotalSpace) << "test for getTotalSpace function: get total space of Fixed disk volume mounted on /, it should not be 0";
}
#if defined( UNX )
TEST_F(getTotalSpace, getTotalSpace_002 )
{
sal_Int32 mask = VolumeInfoMask_TotalSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL3, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiTotalSpace = aVolumeInfo.getTotalSpace( );
ASSERT_TRUE(0 == uiTotalSpace) << "test for getTotalSpace function: get total space of /proc, it should be 0";
}
#else /// Windows version, in Windows, there is no /proc directory
TEST_F(getTotalSpace, getTotalSpace_002 )
{
ASSERT_TRUE(1 == 1) << "test for getTotalSpace function:not applicable for /proc( Windows version )";
}
#endif
#if defined(SOLARIS)
TEST_F(getTotalSpace, getTotalSpace_003 )
{
struct statvfs aStatFS;
static const sal_Char name[] = "/";
memset (&aStatFS, 0, sizeof(aStatFS));
statvfs( name, &aStatFS);
sal_uInt64 TotalSpace = aStatFS.f_frsize * aStatFS.f_blocks ;
sal_Int32 mask = VolumeInfoMask_TotalSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiTotalSpace = aVolumeInfo.getTotalSpace( );
ASSERT_TRUE(uiTotalSpace == TotalSpace) << "test for getTotalSpace function: get total space by hand, then compare with getTotalSpace, it did not pass";
}
#else /// Windows version
TEST_F(getTotalSpace, getTotalSpace_003 )
{
ASSERT_TRUE(1 == 1) << "test for getTotalSpace function:not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt64 getFreeSpace() const
//---------------------------------------------------------------------
class getFreeSpace : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getFreeSpace
TEST_F(getFreeSpace, getFreeSpace_001 )
{
sal_Int32 mask = VolumeInfoMask_FreeSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiFreeSpace = aVolumeInfo.getFreeSpace( );
ASSERT_TRUE(0 != uiFreeSpace) << "test for getFreeSpace function: get free space of Fixed disk volume mounted on /, it should not be 0, suggestion: returned value, -1 is better, since some times the free space may be 0";
}
#if defined( UNX )
TEST_F(getFreeSpace, getFreeSpace_002 )
{
sal_Int32 mask = VolumeInfoMask_FreeSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL3, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiFreeSpace = aVolumeInfo.getFreeSpace( );
ASSERT_TRUE(0 == uiFreeSpace) << "test for getFreeSpace function: get free space of /proc, it should be 0";
}
#else /// Windows version, in Windows, there is no /proc directory
TEST_F(getFreeSpace, getFreeSpace_002 )
{
ASSERT_TRUE(1 == 1) << "test for getFreeSpace function: not applicable for /proc( Windows version )";
}
#endif
#if defined(SOLARIS)
TEST_F(getFreeSpace, getFreeSpace_003 )
{
struct statvfs aStatFS;
static const sal_Char name[] = "/";
memset (&aStatFS, 0, sizeof(aStatFS));
statvfs( name, &aStatFS);
sal_uInt64 FreeSpace = aStatFS.f_bfree * aStatFS.f_frsize ;
sal_Int32 mask = VolumeInfoMask_FreeSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiFreeSpace = aVolumeInfo.getFreeSpace( );
ASSERT_TRUE(uiFreeSpace == FreeSpace) << "test for getFreeSpace function: get free space by hand, then compare with getFreeSpace, it did not pass";
}
#else //Windows version
TEST_F(getFreeSpace, getFreeSpace_003 )
{
ASSERT_TRUE(1 == 1) << "test for getFreeSpace function: not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt64 getUsedSpace() const
//---------------------------------------------------------------------
class getUsedSpace : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getUsedSpace
TEST_F(getUsedSpace, getUsedSpace_001 )
{
sal_Int32 mask = VolumeInfoMask_UsedSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiUsedSpace = aVolumeInfo.getUsedSpace( );
ASSERT_TRUE(0 != uiUsedSpace) << "test for getUsedSpace function: get used space of Fixed disk volume mounted on /, it should not be 0, suggestion: returned value, -1 is better, since some times the used space may be 0";
}
#if defined( UNX )
TEST_F(getUsedSpace, getUsedSpace_002 )
{
sal_Int32 mask = VolumeInfoMask_UsedSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL3, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiUsedSpace = aVolumeInfo.getUsedSpace( );
ASSERT_TRUE(0 == uiUsedSpace) << "test for getUsedSpace function: get used space of /proc, it should be 0";
}
#else /// Windows version, in Windows, there is no /proc directory
TEST_F(getUsedSpace, getUsedSpace_002 )
{
ASSERT_TRUE(1 == 1) << "test for getUsedSpace function: not applicable for /proc( Windows version )";
}
#endif
#if defined(SOLARIS)
TEST_F(getUsedSpace, getUsedSpace_003 )
{
struct statvfs aStatFS;
static const sal_Char name[] = "/";
memset (&aStatFS, 0, sizeof(aStatFS));
statvfs( name, &aStatFS);
sal_uInt64 UsedSpace = ( aStatFS.f_blocks - aStatFS.f_bavail ) * aStatFS.f_frsize;
sal_Int32 mask = VolumeInfoMask_UsedSpace;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiUsedSpace = aVolumeInfo.getUsedSpace( );
ASSERT_TRUE(uiUsedSpace == UsedSpace) << "test for getUsedSpace function: get used space by hand, then compare with getUsedSpace, it did not pass";
}
#else //Windows version
TEST_F(getUsedSpace, getUsedSpace_003 )
{
ASSERT_TRUE(1 == 1) << "test for getUsedSpace function: not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt32 getMaxNameLength() const
//---------------------------------------------------------------------
class getMaxNameLength : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getMaxNameLength
TEST_F(getMaxNameLength, getMaxNameLength_001 )
{
sal_Int32 mask = VolumeInfoMask_MaxNameLength;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt32 uiMaxNameLength = aVolumeInfo.getMaxNameLength( );
ASSERT_TRUE(0 != uiMaxNameLength) << "test for getMaxNameLength function: get max name length of Fixed disk volume mounted on /, it should not be 0";
}
#if ( defined UNX ) || ( defined OS2 )
TEST_F(getMaxNameLength, getMaxNameLength_002 )
{
struct statvfs aStatFS;
static const sal_Char name[] = "/";
memset (&aStatFS, 0, sizeof(aStatFS));
statvfs( name, &aStatFS);
sal_uInt64 MaxNameLength = aStatFS.f_namemax;
sal_Int32 mask = VolumeInfoMask_MaxNameLength;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiMaxNameLength = aVolumeInfo.getMaxNameLength( );
ASSERT_TRUE(uiMaxNameLength == MaxNameLength) << "test for getMaxNameLength function: get max name length by hand, then compare with getMaxNameLength";
}
#else //Windows version
TEST_F(getMaxNameLength, getMaxNameLength_002 )
{
ASSERT_TRUE(1 == 1) << "test for getMaxNameLength function: not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt32 getMaxPathLength() const
//---------------------------------------------------------------------
class getMaxPathLength : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
};// class getMaxPathLength
TEST_F(getMaxPathLength, getMaxPathLength_001 )
{
sal_Int32 mask = VolumeInfoMask_MaxPathLength;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt32 uiMaxPathLength = aVolumeInfo.getMaxPathLength( );
ASSERT_TRUE(0 != uiMaxPathLength) << "test for getMaxPathLength function: get max path length of Fixed disk volume mounted on /, it should not be 0";
}
#if ( defined UNX ) || ( defined OS2 )
TEST_F(getMaxPathLength, getMaxPathLength_002 )
{
sal_Int32 mask = VolumeInfoMask_MaxPathLength;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
sal_uInt64 uiMaxPathLength = aVolumeInfo.getMaxPathLength( );
ASSERT_TRUE(uiMaxPathLength == PATH_MAX) << "test for getMaxPathLength function: get max path length by hand, then compare with getMaxPathLength";
}
#else //Windows version
TEST_F(getMaxPathLength, getMaxPathLength_002 )
{
ASSERT_TRUE(1 == 1) << "test for getMaxPathLength function: not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline ::rtl::OUString getFileSystemName() const
//---------------------------------------------------------------------
class getFileSystemName : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::FileBase::RC nError1;
};// class getFileSystemName
TEST_F(getFileSystemName, getFileSystemName_001 )
{
sal_Int32 mask = VolumeInfoMask_FileSystemName;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
aUStr = aVolumeInfo.getFileSystemName( );
ASSERT_TRUE(sal_False == compareFileName( aNullURL, aUStr )) << "test for getFileSystemName function: get file system name of Fixed disk volume mounted on /, it should not be empty string";
}
#if defined(SOLARIS)
TEST_F(getFileSystemName, getFileSystemName_002 )
{
struct statvfs aStatFS;
static const sal_Char name[] = "/";
memset (&aStatFS, 0, sizeof(aStatFS));
statvfs( name, &aStatFS);
sal_Char * astrFileSystemName = aStatFS.f_basetype;
sal_Int32 mask = VolumeInfoMask_FileSystemName;
::osl::VolumeInfo aVolumeInfo( mask );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
ASSERT_TRUE( sal_True == aVolumeInfo.isValid( mask ) );
aUStr = aVolumeInfo.getFileSystemName( );
ASSERT_TRUE(sal_True == compareFileName( aUStr, astrFileSystemName )) << "test for getFileSystemName function: get file system name by hand, then compare with getFileSystemName";
}
#else //Windows version
TEST_F(getFileSystemName, getFileSystemName_002 )
{
ASSERT_TRUE(1 == 1) << "test for getFileSystemName function: not implemented yet( Windows version )";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline VolumeDevice getDeviceHandle() const
//---------------------------------------------------------------------
class getDeviceHandle : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::FileBase::RC nError1;
};// class getDeviceHandle
TEST_F(getDeviceHandle, getDeviceHandle_001 )
{
::osl::VolumeInfo aVolumeInfo( VolumeInfoMask_Attributes );
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
ASSERT_TRUE( osl::FileBase::E_None == nError1 );
::osl::VolumeDevice aVolumeDevice1( aVolumeInfo.getDeviceHandle( ) );
sal_Bool bOk = compareFileName( aNullURL, aVolumeDevice1.getMountPath( ) );
ASSERT_TRUE(( sal_False == bOk )) << "test for getDeviceHandle function: get device handle of Fixed disk volume mounted on /, it should not be NULL, it did not pass in (W32) (UNX).";
}
}// namespace osl_VolumeInfo
//------------------------------------------------------------------------
// Beginning of the test cases for VolumeDevice class
//------------------------------------------------------------------------
namespace osl_FileStatus
{
//---------------------------------------------------------------------
// testing the method
// FileStatus( sal_uInt32 nMask ): _nMask( nMask )
//---------------------------------------------------------------------
class FileStatusCtors : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
::std::auto_ptr<Directory> pDir( new Directory( aTmpName3 ) );
nError1 = pDir->open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = pDir->getNextItem( rItem, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
pDir->close();
/*
Directory aDir( aTmpName3 );
nError1 = aDir.open();
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = aDir.getNextItem( rItem, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
aDir.close();
*/
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class ctors
TEST_F(FileStatusCtors, ctors_001 )
{
::osl::FileStatus rFileStatus( FileStatusMask_All );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
aUStr = rFileStatus.getFileName( );
ASSERT_TRUE(sal_True == compareFileName( aUStr, aTmpName2)) << "test for ctors function: mask all and see the file name";
}
TEST_F(FileStatusCtors, ctors_002 )
{
::osl::FileStatus rFileStatus( 0 );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
aUStr = rFileStatus.getFileName( );
ASSERT_TRUE(sal_True == compareFileName( aUStr, aNullURL)) << "test for ctors function: mask is empty";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool isValid( sal_uInt32 nMask ) const
//---------------------------------------------------------------------
class FileStatusIsValid : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::Directory *pDir;
::osl::DirectoryItem rItem_file, rItem_link;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
pDir = new Directory( aTmpName3 );
//::std::auto_ptr<Directory> pDir( new Directory( aTmpName3 ) );
::osl::FileBase::RC nError1 = pDir->open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = pDir->getNextItem( rItem_file, 1 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
::osl::FileBase::RC nError1 = pDir->close( );
delete pDir;
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << errorToStr(nError1).pData;
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
void check_FileStatus(::osl::FileStatus const& _aStatus)
{
rtl::OString sStat;
if (_aStatus.isValid(FileStatusMask_Type))
{
sStat += "type ";
}
if (_aStatus.isValid(FileStatusMask_Attributes))
{
sStat += "attributes ";
}
if (_aStatus.isValid(FileStatusMask_CreationTime))
{
sStat += "ctime ";
}
if (_aStatus.isValid(FileStatusMask_AccessTime))
{
sStat += "atime ";
}
if (_aStatus.isValid(FileStatusMask_ModifyTime))
{
sStat += "mtime ";
}
if (_aStatus.isValid(FileStatusMask_FileSize))
{
sStat += "filesize ";
}
if (_aStatus.isValid(FileStatusMask_FileName))
{
sStat += "filename ";
}
if (_aStatus.isValid(FileStatusMask_FileURL))
{
sStat += "fileurl ";
}
printf("mask: %s\n", sStat.getStr());
}
};// class ctors
TEST_F(FileStatusIsValid, isValid_001 )
{
sal_uInt32 mask = 0;
::osl::FileStatus rFileStatus( mask );
::osl::FileBase::RC nError1 = rItem_file.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
sal_Bool bOk = rFileStatus.isValid( mask );
ASSERT_TRUE(( sal_True == bOk )) << "test for isValid function: no fields specified";
}
TEST_F(FileStatusIsValid, isValid_002 )
{
createTestFile( aTmpName6 );
sal_uInt32 mask_file = ( FileStatusMask_Type | FileStatusMask_Attributes |
FileStatusMask_CreationTime | FileStatusMask_AccessTime |
FileStatusMask_ModifyTime | FileStatusMask_FileSize |
FileStatusMask_FileName | FileStatusMask_FileURL) ;
::osl::FileStatus rFileStatus( mask_file );
::osl::FileBase::RC nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem_file );
nError1 = rItem_file.getFileStatus( rFileStatus );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << errorToStr(nError1).pData;
// LLA: this is wrong, we never should try to check on all masks
// only on one.
// Second, it's not a bug, if a value is not valid, it's an unhandled feature.
// sal_Bool bOk = rFileStatus.isValid( mask_file );
check_FileStatus(rFileStatus);
deleteTestFile( aTmpName6 );
// ASSERT_TRUE(// ( sal_True == bOk )) << "test for isValid function: regular file mask fields test, #FileStatusMask_CreationTime# should be valid field for regular file, but feedback is invalid";
}
//Link is not defined in Windows, and on Linux, we can not get the directory item of the link file
// LLA: we have to differ to filesystems, normal filesystems support links (EXT2, ...)
// castrated filesystems don't (FAT, FAT32)
// Windows NT NTFS support links, but the windows api don't :-(
TEST_F(FileStatusIsValid, isValid_003 )
{
#if defined ( UNX )
// ::osl::FileBase::RC nError;
sal_Int32 fd;
::rtl::OUString aUStr_LnkFileSys( aTempDirectorySys ), aUStr_SrcFileSys( aTempDirectorySys );
( ( aUStr_LnkFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/tmpdir/link.file");
( ( aUStr_SrcFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/tmpdir/tmpname");
rtl::OString strLinkFileName;
rtl::OString strSrcFileName;
strLinkFileName = OUStringToOString( aUStr_LnkFileSys, RTL_TEXTENCODING_ASCII_US );
strSrcFileName = OUStringToOString( aUStr_SrcFileSys, RTL_TEXTENCODING_ASCII_US );
//create a link file and link it to file "/tmp/PID/tmpdir/tmpname"
fd = symlink( strSrcFileName.getStr(), strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
// testDirectory is "/tmp/PID/tmpdir/"
::osl::Directory testDirectory( aTmpName3 );
::osl::FileBase::RC nError1 = testDirectory.open( );
::rtl::OUString aFileName = ::rtl::OUString::createFromAscii("link.file");
sal_Bool bOk = sal_False;
while (1) {
nError1 = testDirectory.getNextItem( rItem_link, 4 );
if (::osl::FileBase::E_None == nError1) {
sal_uInt32 mask_link = FileStatusMask_FileName | FileStatusMask_LinkTargetURL;
::osl::FileStatus rFileStatus( mask_link );
rItem_link.getFileStatus( rFileStatus );
//printFileName( rFileStatus.getFileName( ) );
if ( compareFileName( rFileStatus.getFileName( ), aFileName) == sal_True )
{
//printf("find the link file");
if ( sal_True == rFileStatus.isValid( FileStatusMask_LinkTargetURL ) )
{
bOk = sal_True;
break;
}
}
}
else
break;
};
fd = remove( strLinkFileName );
ASSERT_TRUE( fd == 0 );
ASSERT_TRUE(( sal_True == bOk )) << "test for isValid function: link file, check for LinkTargetURL";
#endif
}
TEST_F(FileStatusIsValid, isValid_004 )
{
sal_uInt32 mask_file_all = FileStatusMask_All;
::osl::FileStatus rFileStatus_all( mask_file_all );
::osl::FileBase::RC nError1 = rItem_file.getFileStatus( rFileStatus_all );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
check_FileStatus(rFileStatus_all);
// LLA: this is wrong
// sal_Bool bOk1 = rFileStatus_all.isValid( mask_file_all );
sal_uInt32 mask_file_val = FileStatusMask_Validate;
::osl::FileStatus rFileStatus_val( mask_file_val );
nError1 = rItem_file.getFileStatus( rFileStatus_val );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
// sal_Bool bOk2 = rFileStatus_val.isValid( mask_file_val );
check_FileStatus(rFileStatus_val);
// ASSERT_TRUE(// ( sal_False == bOk1 ) && ( sal_True == bOk2 )) << "test for isValid function: check for Mask_All and Validate, really not sure what validate used for and how to use it, help me. did not pass (W32)(UNX).";
}
//---------------------------------------------------------------------
// testing the method
// inline Type getFileType() const
//---------------------------------------------------------------------
class getFileType : public ::testing::Test
{
protected:
::rtl::OUString aUStr;
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem m_aItem_1, m_aItem_2, m_aVolumeItem, m_aFifoItem;
::osl::DirectoryItem m_aLinkItem, m_aSocketItem, m_aSpecialItem;
public:
// initialization
void SetUp( )
{
// create a tempfile: $TEMP/tmpdir/tmpname.
// a tempdirectory: $TEMP/tmpdir/tmpdir.
// use $ROOT/staroffice as volume ---> use dev/fd as volume.
// and get their directory item.
createTestDirectory( aTmpName3 );
//printFileName( aTmpName2);
createTestFile( aTmpName3, aTmpName2 );
createTestDirectory( aTmpName3, aTmpName1 );
::std::auto_ptr<Directory> pDir( new Directory( aTmpName3 ) );
nError1 = pDir->open( );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "open aTmpName3 failed!";
//getNextItem can not assure which item retrieved
nError1 = pDir->getNextItem( m_aItem_1, 1 );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get first item failed!";
nError1 = pDir->getNextItem( m_aItem_2 );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get second item failed!";
pDir->close();
//mindy: failed on my RH9,so removed temporaly
//nError1 = ::osl::DirectoryItem::get( aVolURL2, m_aVolumeItem );
//ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get volume item failed!";
}
void TearDown( )
{
// remove all in $TEMP/tmpdir.
deleteTestDirectory( aTmpName3, aTmpName1 );
deleteTestFile( aTmpName3, aTmpName2 );
deleteTestDirectory( aTmpName3 );
}
void check_FileType(osl::FileStatus const& _rFileStatus )
{
sal_Bool bOK = sal_False;
if ( _rFileStatus.isValid(FileStatusMask_FileName))
{
rtl::OUString suFilename = _rFileStatus.getFileName();
if ( _rFileStatus.isValid(FileStatusMask_Type))
{
osl::FileStatus::Type eType = _rFileStatus.getFileType( );
if ( compareFileName( suFilename, aTmpName2) == sal_True )
{
// regular
bOK = ( eType == osl::FileStatus::Regular );
}
if ( compareFileName( suFilename, aTmpName1) == sal_True )
{
// directory
bOK = ( eType == ::osl::FileStatus::Directory );
}
ASSERT_TRUE(( bOK == sal_True )) << "test for getFileType function: ";
}
}
// LLA: it's not a bug, if a FileStatus not exist, so no else
}
};// class getFileType
TEST_F(getFileType, getFileType_001 )
{
::osl::FileStatus rFileStatus( FileStatusMask_Type | FileStatusMask_FileName );
nError1 = m_aItem_1.getFileStatus( rFileStatus );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "getFileStatus failed";
check_FileType(rFileStatus);
}
TEST_F(getFileType, getFileType_002 )
{
::osl::FileStatus rFileStatus( FileStatusMask_Type | FileStatusMask_FileName );
nError1 = m_aItem_2.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
check_FileType(rFileStatus);
}
TEST_F(getFileType, getFileType_003 )
{
#if 0
// LLA: this have to be discussed.
::osl::FileStatus rFileStatus( FileStatusMask_Type );
nError1 = m_aVolumeItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
if (rFileStatus.isValid(FileStatusMask_Type))
{
osl::FileStatus::Type eType = rFileStatus.getFileType( );
ASSERT_TRUE(( eType == ::osl::FileStatus::Volume )) << "test for getFileType function: Volume, it seems the volume part of the field is not implemented, it did not pass in (W32)(UNX).";
}
#endif
}
TEST_F(getFileType, getFileType_004 )
{
#if ( defined UNX ) || ( defined OS2 ) //Fifo creation is differ in Windows
//create a fifo in $ROOT/tmp/tmpdir, get its DirectoryItem.
rtl::OString strFifoSys;
strFifoSys = OUStringToOString( aFifoSys, RTL_TEXTENCODING_ASCII_US );
::rtl::OUString aFifoURL;
int fd = mkfifo( strFifoSys.getStr(), O_RDWR | O_CREAT );
ASSERT_TRUE(fd == 0) << "mkfifo failed!";
::osl::FileBase::getFileURLFromSystemPath( aFifoSys, aFifoURL );
nError1 = ::osl::DirectoryItem::get( aFifoURL, m_aFifoItem );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get item failed!";
//check for File type
::osl::FileStatus rFileStatus( FileStatusMask_Type );
nError1 = m_aFifoItem.getFileStatus( rFileStatus );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get Status failed!";
//delete fifo
nError1 = ::osl::File::remove( aFifoURL );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "remove file failed!";
if (rFileStatus.isValid(FileStatusMask_Type))
{
osl::FileStatus::Type eType = rFileStatus.getFileType( );
ASSERT_TRUE(( eType == ::osl::FileStatus::Fifo )) << "test for getFileType function: Fifo, Solaris version ";
}
#endif
}
/*
* LLA: removed, m_aSocketItem is wrong initialised.
*/
// LLA: TEST_F(getFileType, getFileType_005 )
// LLA: {
// LLA: #if defined ( SOLARIS ) //Socket file may differ in Windows
// LLA: // nError1 = ::osl::DirectoryItem::get( aTypeURL1, m_aSocketItem );
// LLA: nError1 = ::osl::DirectoryItem::get( rtl::OUString::createFromAscii("/dev/null"), m_aSocketItem );
// LLA: printError(nError1);
// LLA: ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "get Socket type file failed";
// LLA:
// LLA: //check for File type
// LLA: ::osl::FileStatus rFileStatus( FileStatusMask_Type );
// LLA:
// LLA: nError1 = m_aSocketItem.getFileStatus( rFileStatus );
// LLA: ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "getFileStatus failed";
// LLA:
// LLA: if (rFileStatus.isValid( FileStatusMask_Type ))
// LLA: {
// LLA: osl::FileStatus::Type eType = rFileStatus.getFileType( );
// LLA: printFileType(eType);
// LLA: ASSERT_TRUE(// LLA: ( eType == ::osl::FileStatus::Socket )) << "test for getFileType function: Socket, Solaris version ";
// LLA: }
// LLA: #endif
// LLA: }
// deprecated since there is a same case Directory::getNextItem_004
/*#if defined 0 //( UNX ) //( SOLARIS ) //Link file is not defined in Windows
TEST_F(getFileType, getFileType_006 )
{
nError1 = ::osl::DirectoryItem::get( aTypeURL3, m_aLinkItem );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check for File type
::osl::FileStatus rFileStatus( FileStatusMask_Type );
nError1 = m_aLinkItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( ::osl::FileStatus::Link == rFileStatus.getFileType( ) )) << "test for getFileType function: Link, UNX version ";
}
#endif */
TEST_F(getFileType, getFileType_007 )
{
#if defined ( SOLARIS ) //Special file is differ in Windows
nError1 = ::osl::DirectoryItem::get( aTypeURL2, m_aSpecialItem );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check for File type
::osl::FileStatus rFileStatus( FileStatusMask_Type );
nError1 = m_aSpecialItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
if (rFileStatus.isValid(FileStatusMask_Type))
{
osl::FileStatus::Type eType = rFileStatus.getFileType( );
ASSERT_TRUE(( eType == ::osl::FileStatus::Special )) << "test for getFileType function: Special, Solaris version ";
}
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt64 getAttributes() const
//---------------------------------------------------------------------
class getAttributes : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL, aTypeURL_Hid;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem, rItem_hidden;
public:
// initialization
void SetUp( )
{
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
aTypeURL_Hid = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL_Hid, aHidURL1 );
createTestFile( aTypeURL_Hid );
nError = ::osl::DirectoryItem::get( aTypeURL_Hid, rItem_hidden );
ASSERT_TRUE( nError == FileBase::E_None );
}
void TearDown( )
{
deleteTestFile( aTypeURL );
deleteTestFile( aTypeURL_Hid );
}
};// class getAttributes
#if ( defined UNX ) || ( defined OS2 )
//windows only 3 file attributes: normal, readonly, hidden
TEST_F(getAttributes, getAttributes_001 )
{
changeFileMode( aTypeURL, S_IRUSR | S_IRGRP | S_IROTH );
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
ASSERT_TRUE(( Attribute_ReadOnly | Attribute_GrpRead | Attribute_OwnRead | Attribute_OthRead ) ==
rFileStatus.getAttributes( )) << "test for getAttributes function: ReadOnly, GrpRead, OwnRead, OthRead( UNX version ) ";
}
#else //Windows version
TEST_F(getAttributes, getAttributes_001 )
{
ASSERT_TRUE(1 == 1) << "test for getAttributes function: ReadOnly, GrpRead, OwnRead, OthRead( Windows version )";
}
#endif
TEST_F(getAttributes, getAttributes_002 )
{
#if ( defined UNX ) || ( defined OS2 )
changeFileMode( aTypeURL, S_IXUSR | S_IXGRP | S_IXOTH );
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
ASSERT_TRUE(( Attribute_ReadOnly | Attribute_Executable | Attribute_GrpExe | Attribute_OwnExe | Attribute_OthExe ) ==
rFileStatus.getAttributes( )) << "test for getAttributes function: Executable, GrpExe, OwnExe, OthExe, the result is Readonly, Executable, GrpExe, OwnExe, OthExe, it partly not pass( Solaris version )";
#endif
}
#if ( defined UNX ) || ( defined OS2 )
TEST_F(getAttributes, getAttributes_003 )
{
changeFileMode( aTypeURL, S_IWUSR | S_IWGRP | S_IWOTH );
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
ASSERT_TRUE(( Attribute_GrpWrite | Attribute_OwnWrite | Attribute_OthWrite ) ==
rFileStatus.getAttributes( )) << "test for getAttributes function: GrpWrite, OwnWrite, OthWrite( Solaris version )";
}
#else //Windows version
TEST_F(getAttributes, getAttributes_003 )
{
ASSERT_TRUE(1 == 1) << "test for getAttributes function: GrpWrite, OwnWrite, OthWrite( Windows version )";
}
#endif
#if ( defined UNX ) || ( defined OS2 ) //hidden file definition may different in Windows
TEST_F(getAttributes, getAttributes_004 )
{
sal_Int32 test_Attributes = Attribute_Hidden;
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError = rItem_hidden.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
test_Attributes &= rFileStatus.getAttributes( );
ASSERT_TRUE(test_Attributes == Attribute_Hidden) << "test for getAttributes function: Hidden files( Solaris version )";
}
#else //Windows version
TEST_F(getAttributes, getAttributes_004 )
{
::rtl::OUString aUserHiddenFileURL = ::rtl::OUString::createFromAscii("file:///c:/AUTOEXEC.BAT");
nError = ::osl::DirectoryItem::get( aUserHiddenFileURL, rItem_hidden );
//printFileName( aUserHiddenFileURL );
ASSERT_TRUE(nError == FileBase::E_None) << "get item fail";
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError = rItem_hidden.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
ASSERT_TRUE((rFileStatus.getAttributes( ) & Attribute_Hidden)!= 0) << "Hidden files(Windows version), please check if hidden file c:/AUTOEXEC.BAT exists ";
}
#endif
//---------------------------------------------------------------------
// testing the method
// inline TimeValue getAccessTime() const
//---------------------------------------------------------------------
class getAccessTime : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
}
void TearDown( )
{
deleteTestFile( aTypeURL );
}
};// class getAccessTime
TEST_F(getAccessTime, getAccessTime_001)
{
TimeValue *pTV_current = NULL;
ASSERT_TRUE( ( pTV_current = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
TimeValue *pTV_access = NULL;
ASSERT_TRUE( ( pTV_access = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
::osl::FileStatus rFileStatus( FileStatusMask_AccessTime );
nError = rItem.getFileStatus( rFileStatus );
sal_Bool bOk = osl_getSystemTime( pTV_current );
ASSERT_TRUE( sal_True == bOk && nError == FileBase::E_None );
*pTV_access = rFileStatus.getAccessTime( );
sal_Bool bOK = t_compareTime( pTV_access, pTV_current, delta );
free( pTV_current );
free( pTV_access );
ASSERT_TRUE(sal_True == bOK) << "test for getAccessTime function: This test turns out that UNX pricision is no more than 1 sec, don't know how to test this function, in Windows test, it lost hour min sec, only have date time. ";
}
//---------------------------------------------------------------------
// testing the method
// inline TimeValue getModifyTime() const
//---------------------------------------------------------------------
class getModifyTime : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
};// class getModifyTime
TEST_F(getModifyTime, getModifyTime_001)
{
TimeValue *pTV_current = NULL;
ASSERT_TRUE( ( pTV_current = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
//create file
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
//get current time
sal_Bool bOk = osl_getSystemTime( pTV_current );
ASSERT_TRUE( sal_True == bOk );
//get instance item and filestatus
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
::osl::FileStatus rFileStatus( FileStatusMask_ModifyTime );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
//get modify time
TimeValue *pTV_modify = NULL;
ASSERT_TRUE( ( pTV_modify = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
*pTV_modify = rFileStatus.getModifyTime( );
sal_Bool bOK = t_compareTime( pTV_modify, pTV_current, delta );
//delete file
deleteTestFile( aTypeURL );
free( pTV_current );
ASSERT_TRUE(sal_True == bOK) << "test for getModifyTime function: This test turns out that UNX pricision is no more than 1 sec, don't know how to improve this function. ";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_uInt64 getFileSize() const
//---------------------------------------------------------------------
class getFileSize : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
}
void TearDown( )
{
deleteTestFile( aTypeURL );
}
};// class getFileSize
TEST_F(getFileSize, getFileSize_001 )
{
::osl::FileStatus rFileStatus( FileStatusMask_FileSize );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
sal_uInt64 uFileSize = rFileStatus.getFileSize( );
ASSERT_TRUE(0 == uFileSize) << "test for getFileSize function: empty file ";
}
TEST_F(getFileSize, getFileSize_002 )
{
::osl::File testfile( aTypeURL );
nError = testfile.open( OpenFlag_Write | OpenFlag_Read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError );
nError = testfile.setSize( TEST_FILE_SIZE );
ASSERT_TRUE( ::osl::FileBase::E_None == nError );
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
::osl::FileStatus rFileStatus( FileStatusMask_FileSize );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
sal_uInt64 uFileSize = rFileStatus.getFileSize( );
ASSERT_TRUE(TEST_FILE_SIZE == uFileSize) << "test for getFileSize function: file with size of TEST_FILE_SIZE, did not pass in (W32). ";
}
//---------------------------------------------------------------------
// testing the method
// inline ::rtl::OUString getFileName() const
//---------------------------------------------------------------------
class getFileName : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
nError = ::osl::DirectoryItem::get( aTypeURL, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
}
void TearDown( )
{
deleteTestFile( aTypeURL );
}
};// class getFileName
TEST_F(getFileName, getFileName_001 )
{
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
::rtl::OUString aFileName = rFileStatus.getFileName( );
ASSERT_TRUE(sal_True == compareFileName( aFileName, aTmpName2 )) << "test for getFileName function: name compare with specify";
}
//---------------------------------------------------------------------
// testing the method
// inline ::rtl::OUString getFileURL() const
//---------------------------------------------------------------------
class getFileURL : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
createTestFile( aTmpName6 );
nError = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( nError == FileBase::E_None );
}
void TearDown( )
{
deleteTestFile( aTmpName6 );
}
};// class getFileURL
TEST_F(getFileURL, getFileURL_001 )
{
::osl::FileStatus rFileStatus( FileStatusMask_FileURL );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError == FileBase::E_None );
::rtl::OUString aFileURL = rFileStatus.getFileURL( );
ASSERT_TRUE(sal_True == compareFileName( aFileURL, aTmpName6 )) << "test for getFileURL function: ";
}
//---------------------------------------------------------------------
// testing the method
// inline ::rtl::OUString getLinkTargetURL() const
//---------------------------------------------------------------------
class getLinkTargetURL : public ::testing::Test
{
protected:
::rtl::OUString aTypeURL;
::osl::FileBase::RC nError;
::osl::DirectoryItem rItem;
public:
// test code.
// initialization
void SetUp( )
{
aTypeURL = aUserDirectoryURL.copy( 0 );
concatURL( aTypeURL, aTmpName2 );
createTestFile( aTypeURL );
}
void TearDown( )
{
deleteTestFile( aTypeURL );
}
};// class getLinkTargetURL
#if ( defined UNX ) || ( defined OS2 ) //Link file is not define in Windows
TEST_F(getLinkTargetURL, getLinkTargetURL_001 )
{
//create a link file;
::rtl::OUString aUStr_LnkFileSys( aTempDirectorySys ), aUStr_SrcFileSys( aTempDirectorySys );
( ( aUStr_LnkFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/link.file");
( ( aUStr_SrcFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/tmpname");
rtl::OString strLinkFileName, strSrcFileName;
strLinkFileName = OUStringToOString( aUStr_LnkFileSys, RTL_TEXTENCODING_ASCII_US );
strSrcFileName = OUStringToOString( aUStr_SrcFileSys, RTL_TEXTENCODING_ASCII_US );
sal_Int32 fd;
fd = symlink( strSrcFileName.getStr(), strLinkFileName.getStr() );
ASSERT_TRUE(fd == 0) << "in creating link file";
//get linkTarget URL
nError = ::osl::DirectoryItem::get( aLnkURL1, rItem );
ASSERT_TRUE(nError == FileBase::E_None) << "in getting link file item";
::osl::FileStatus rFileStatus( FileStatusMask_LinkTargetURL );
nError = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE(nError == FileBase::E_None) << "in getting link file status";
::rtl::OUString aFileURL = rFileStatus.getLinkTargetURL( );
//remove link file
fd = remove( strLinkFileName.getStr() );
ASSERT_TRUE(fd == 0) << "in deleting link file";
ASSERT_TRUE(sal_True == compareFileName( aFileURL, aTypeURL )) << "test for getLinkTargetURL function: Solaris version, creat a file, and a link file link to it, get its LinkTargetURL and compare";
}
#else
TEST_F(getLinkTargetURL, getLinkTargetURL_001 )
{
ASSERT_TRUE(1) << "test for getLinkTargetURL function: Windows version, not tested";
}
#endif
}// namespace osl_FileStatus
//------------------------------------------------------------------------
// Beginning of the test cases for File class
//------------------------------------------------------------------------
namespace osl_File
{
//---------------------------------------------------------------------
// testing the method
// File( const ::rtl::OUString& ustrFileURL )
//---------------------------------------------------------------------
class FileCtors : public ::testing::Test
{
protected:
// ::osl::FileBase::RC nError1;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class ctors
TEST_F(FileCtors, ctors_001 )
{
::osl::File testFile( aTmpName4 );
::osl::FileBase::RC nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
::osl::FileBase::RC nError2 = testFile.close( );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) && ( ::osl::FileBase::E_None == nError2 )) << "test for ctors function: initialize a File and test its open and close";
}
TEST_F(FileCtors, ctors_002 )
{
::osl::File testFile( aTmpName5 );
sal_Char buffer[30] = "Test for File constructor";
sal_uInt64 nCount;
::osl::FileBase::RC nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
::osl::FileBase::RC nError2 = testFile.write( buffer, 30, nCount );
testFile.close( );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) && ( ::osl::FileBase::E_None == nError2 )) << "test for ctors function: test relative file URL, this test show that relative file URL is also acceptable";
}
//---------------------------------------------------------------------
// testing the method
// inline RC open( sal_uInt32 uFlags )
//---------------------------------------------------------------------
class FileOpen : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2, nError3;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class open
// test code.
TEST_F(FileOpen, open_001 )
{
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
nError2 = testFile.close( );
ASSERT_TRUE(::osl::FileBase::E_None == nError2) << "close error";
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "test for open function: open a regular file";
}
TEST_F(FileOpen, open_002 )
{
::osl::File testFile( aTmpName3 );
nError1 = testFile.open( OpenFlag_Read );
ASSERT_TRUE(( File::E_INVAL == nError1 ) || ( File::E_ACCES == nError1 )) << "test for open function: open a directory";
}
TEST_F(FileOpen, open_003 )
{
::osl::File testFile( aCanURL1 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE(File::E_NOENT == nError1) << "test for open function: open a non-exist file";
}
TEST_F(FileOpen, open_004 )
{
::rtl::OUString aTestFile( aRootURL );
concatURL( aTestFile, aTmpName2 );
::osl::File testFile( aTestFile );
nError1 = testFile.open( OpenFlag_Create );
sal_Bool bOK = ( File::E_ACCES == nError1 );
#if defined (WNT )
bOK = sal_True; /// in Windows, you can create file in c:/ any way.
testFile.close( );
deleteTestFile( aTestFile);
#endif
ASSERT_TRUE(bOK == sal_True) << "test for open function: create an illegal file";
}
TEST_F(FileOpen, open_005 )
{
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Create );
ASSERT_TRUE(File::E_EXIST == nError1) << "test for open function: create an exist file";
}
TEST_F(FileOpen, open_006 )
{
::osl::File testFile( aCanURL1 );
sal_Char buffer_write[30] = "Test for File open";
sal_Char buffer_read[30];
sal_uInt64 nCount_write, nCount_read;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write | OpenFlag_Create );
nError2 = testFile.write( buffer_write, 30, nCount_write );
::osl::FileBase::RC nError4 = testFile.setPos( Pos_Absolut, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError4 );
nError3 = testFile.read( buffer_read, 10, nCount_read );
::osl::FileBase::RC nError5 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError5 );
::osl::FileBase::RC nError6 = testFile.remove( aCanURL1 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError6 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&
( ::osl::FileBase::E_None == nError2 ) &&
( ::osl::FileBase::E_None == nError3 ) &&
( 30 == nCount_write ) &&
( 10 == nCount_read )) << "test for open function: test for OpenFlag_Read,OpenFlag_Write and OpenFlag_Create";
}
//---------------------------------------------------------------------
// testing the method
// inline RC close()
//---------------------------------------------------------------------
class FileClose : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2, nError3;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class close
TEST_F(FileClose, close_001 )
{
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError2 = testFile.close( );
ASSERT_TRUE(::osl::FileBase::E_None == nError2) << "test for close function: close a regular file";
}
TEST_F(FileClose, close_002 )
{
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError2 = testFile.close( );
nError3 = testFile.setPos( Pos_Absolut, 0 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError2 ) &&
( ::osl::FileBase::E_None != nError3 )) << "test for close function: manipulate a file after it has been closed";
}
//---------------------------------------------------------------------
// testing the method
// inline RC setPos( sal_uInt32 uHow, sal_Int64 uPos )
//---------------------------------------------------------------------
class setPos : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class setPos
TEST_F(setPos, setPos_001 )
{
::osl::File testFile( aTmpName4 );
sal_Char buffer_read[2];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Absolut, 26 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 1, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(buffer_read[0] == pBuffer_Char[26]) << "test for setPos function: test for Pos_Absolut, set the position to 26, test if the 26th char in file is correct";
}
TEST_F(setPos, setPos_002 )
{
::osl::File testFile( aTmpName4 );
sal_Char buffer_read[2];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Absolut, sizeof( pBuffer_Char ) - 2 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Current, 0);
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 1, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(buffer_read[0] == pBuffer_Char[sizeof( pBuffer_Char ) - 2]) << "test for setPos function: test for Pos_Current, set the position to end, test if the ( end -1 ) char in file is correct";
}
TEST_F(setPos, setPos_003 )
{
::osl::File testFile( aTmpName4 );
sal_Char buffer_read[2];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//the file size is smaller than 100
nError1 = testFile.setPos( Pos_End, -100 );
ASSERT_TRUE(::osl::FileBase::E_INVAL == nError1) << "should return error";
nError1 = testFile.setPos( Pos_End, -53 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 1, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(buffer_read[0] == pBuffer_Char[0]) << "test for setPos function: test for Pos_End, set the position to end, test if the first char in file is correct";
}
//---------------------------------------------------------------------
// testing the method
// inline RC getPos( sal_uInt64& uPos )
//---------------------------------------------------------------------
class getPos : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class getPos
TEST_F(getPos, getPos_001 )
{
::osl::File testFile( aTmpName4 );
sal_uInt64 nFilePointer;
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_INVAL == nError1 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Absolut, 26 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(26 == nFilePointer) << "test for getPos function: set the position to 26, get position and check if it is right";
}
//---------------------------------------------------------------------
// testing the method
// inline RC isEndOfFile( sal_Bool *pIsEOF )
//---------------------------------------------------------------------
class isEndOfFile : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class isEndOfFile
TEST_F(isEndOfFile, isEndOfFile_001 )
{
::osl::File testFile( aTmpName4 );
sal_Bool bEOF = sal_False;
sal_Bool *pEOF = &bEOF;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_End, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.isEndOfFile( pEOF );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(sal_True == *pEOF) << "test for isEndOfFile function: set the position to end, check if reach end";
}
TEST_F(isEndOfFile, isEndOfFile_002 )
{
::osl::File testFile( aTmpName4 );
sal_Bool bEOF = sal_False;
sal_Bool *pEOF = &bEOF;
sal_uInt64 nFilePointer = 0;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Absolut, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
*pEOF = sal_False;
while ( !( *pEOF ) )
{
nError1 = testFile.isEndOfFile( pEOF );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Current, 1 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(sizeof( pBuffer_Char ) + 1 == nFilePointer) << "test for isEndOfFile function: use isEndOfFile to move pointer step by step";
}
//---------------------------------------------------------------------
// testing the method
// inline RC setSize( sal_uInt64 uSize )
//---------------------------------------------------------------------
class setSize : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class setSize
TEST_F(setSize, setSize_001 )
{
::osl::File testFile( aTmpName4 );
// sal_Bool bEOF = sal_False;
// sal_Bool *pEOF = &bEOF;
sal_uInt64 nFilePointer;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//enlarge the file to size of 100;
nError1 = testFile.setSize( 100 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get the file size;
nError1 = testFile.setPos( Pos_End, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(100 == nFilePointer) << "test for setSize function: enlarge the file ";
}
TEST_F(setSize, setSize_002 )
{
::osl::File testFile( aTmpName4 );
// sal_Bool bEOF = sal_False;
// sal_Bool *pEOF = &bEOF;
sal_uInt64 nFilePointer;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//enlarge the file to size of 100;
nError1 = testFile.setSize( 10 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get the file size;
nError1 = testFile.setPos( Pos_End, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(10 == nFilePointer) << "test for setSize function: truncate the file ";
}
/* TEST_F(setSize, setSize_003 )
{
::osl::File testFile( aTmpName4 );
// sal_Bool bEOF = sal_False;
// sal_Bool *pEOF = &bEOF;
sal_uInt64 nFilePointer;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//enlarge the file to size of 100;
nError1 = testFile.setSize( 10 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get the file size;
nError1 = testFile.setPos( Pos_End, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(10 == nFilePointer) << "test for setSize function: truncate the file ";
}
*/
//---------------------------------------------------------------------
// testing the method
// inline RC read( void *pBuffer, sal_uInt64 uBytesRequested, sal_uInt64& rBytesRead )
//---------------------------------------------------------------------
class read : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class read
TEST_F(read, read_001 )
{
::osl::File testFile( aTmpName4 );
sal_uInt64 nFilePointer;
sal_Char buffer_read[10];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 10, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( 10 == nFilePointer ) && ( 0 == strncmp( buffer_read, pBuffer_Char, 10 ) )) << "test for read function: read whole content in the file to a buffer";
}
TEST_F(read, read_002 )
{
::osl::File testFile( aTmpName4 );
sal_uInt64 nFilePointer;
sal_Char buffer_read[26];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.setPos( Pos_Absolut, 26 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 26, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( 52 == nFilePointer ) && ( 26 == nCount_read ) && ( 0 == strncmp( buffer_read, &pBuffer_Char[26], 26 ) )) << "test for read function: read from a special position in the file";
}
//---------------------------------------------------------------------
// testing the method
// inline RC write(const void *pBuffer, sal_uInt64 uBytesToWrite, sal_uInt64& rBytesWritten)
//---------------------------------------------------------------------
class write : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class write
TEST_F(write, write_001 )
{
::osl::File testFile( aTmpName6 );
sal_uInt64 nFilePointer;
sal_Char buffer_read[10];
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//write chars into the file.
nError1 = testFile.write( pBuffer_Char, 10, nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get the current pointer;
nError1 = testFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//reset pointer to the beginning;
nError1 = testFile.setPos( Pos_Absolut, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.read( buffer_read, 10, nCount_read );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( 10 == nFilePointer ) &&
( 0 == strncmp( buffer_read, pBuffer_Char, 10 ) ) &&
( 10 == nCount_write )) << "test for write function: read whole content in the file to a buffer. Note, buffer size can not smaller than the read size";
}
//---------------------------------------------------------------------
// testing the method
// inline RC readLine( ::rtl::ByteSequence& aSeq )
//---------------------------------------------------------------------
class readLine : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
::rtl::ByteSequence aSequence;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
//write some strings into the file.
::osl::File testFile( aTmpName6 );
sal_Char ppStrSeq[3][27] = { "abcde\n",
"1234567890\n",
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
};
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
for ( int nCount = 0; nCount < 3; nCount++ )
{
nError1 = testFile.write( ppStrSeq[nCount], strlen( ppStrSeq[nCount] ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class readLine
TEST_F(readLine, readLine_001 )
{
::osl::File testFile( aTmpName6 );
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.readLine( aSequence );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&
( 0 == strncmp( ( const char * )aSequence.getArray( ), pBuffer_Char, 5 ) )) << "test for readLine function: read the first line of the file.";
}
TEST_F(readLine, readLine_002 )
{
::osl::File testFile( aTmpName6 );
sal_Bool bEOF = sal_False;
sal_Bool *pEOF = &bEOF;
nError1 = testFile.open( OpenFlag_Read | OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
for ( int nCount = 0; nCount < 3; nCount++ )
{
nError1 = testFile.readLine( aSequence );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
nError1 = testFile.isEndOfFile( pEOF );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(*pEOF &&
( 0 == strncmp( ( const char * )aSequence.getArray( ), &pBuffer_Char[26], 26 ) )) << "test for readLine function: read three lines of the file and check the file pointer moving.";
}
//---------------------------------------------------------------------
// testing the method
// inline static RC copy( const ::rtl::OUString& ustrSourceFileURL, const ::rtl::OUString& ustrDestFileURL )
//---------------------------------------------------------------------
class copy : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class copy
TEST_F(copy, copy_001 )
{
::osl::File testFile( aTmpName6 );
//copy $TEMP/tmpdir/tmpname to $TEMP/tmpname.
nError1 = ::osl::File::copy( aTmpName4, aTmpName6 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check
nError1 = testFile.open( OpenFlag_Create );
deleteTestFile( aTmpName6 );
ASSERT_TRUE(::osl::FileBase::E_EXIST == nError1) << "test for copy function: copy file to upper directory";
}
TEST_F(copy, copy_002 )
{
//copy $TEMP/tmpdir/tmpname to $TEMP/tmpdir.
nError1 = ::osl::File::copy( aTmpName4, aTmpName3 );
ASSERT_TRUE(( ::osl::FileBase::E_ISDIR == nError1 ) ||( ::osl::FileBase::E_ACCES == nError1 )) << "test for copy function: use directory as destination";
}
TEST_F(copy, copy_003 )
{
//copy $TEMP/tmpdir/tmpname to $ROOT/tmpname.
nError1 = ::osl::File::copy( aTmpName4, aTmpName7 );
#if defined (WNT )
nError1 = ::osl::FileBase::E_ACCES; /// for Windows, c:/ is writtenable any way.
deleteTestFile( aTmpName7);
#endif
ASSERT_TRUE(::osl::FileBase::E_ACCES == nError1) << "test for copy function: copy to an illigal place";
}
TEST_F(copy, copy_004 )
{
//copy $TEMP/tmpname to $TEMP/tmpdir/tmpname.
nError1 = ::osl::File::copy( aTmpName6, aTmpName4 );
ASSERT_TRUE(::osl::FileBase::E_NOENT == nError1) << "test for copy function: copy a not exist file";
}
TEST_F(copy, copy_005 )
{
//copy $TEMP/tmpname to $TEMP/system.path using system path.
nError1 = ::osl::File::copy( aTmpName6, aSysPath1 );
ASSERT_TRUE(::osl::FileBase::E_INVAL == nError1) << "test for copy function: copy a file using system file path";
}
TEST_F(copy, copy_006 )
{
createTestFile( aTmpName6 );
File tmpFile( aTmpName6 );
FileBase::RC err = tmpFile.open( OpenFlag_Write | OpenFlag_Read );
(void)err;
tmpFile.setSize( 200 );
tmpFile.close();
//copy to new path
nError1 = ::osl::File::copy( aTmpName6, aTmpName4 );
ASSERT_TRUE( nError1 == FileBase::E_None );
//check if is the new file
File newFile( aTmpName4 );
newFile.open( OpenFlag_Write | OpenFlag_Read );
newFile.setPos( Pos_End, 0 );
// ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
sal_uInt64 nFilePointer;
nError1 = newFile.getPos( nFilePointer );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
newFile.close( );
deleteTestFile( aTmpName6 );
ASSERT_TRUE(nFilePointer == 200) << "test for copy function: the dest file exist";
}
//copyLink has not been impletmented yet
TEST_F(copy, copy_007 )
{
#if ( defined UNX )
ASSERT_TRUE(::osl::FileBase::E_INVAL == nError1) << "test for copy function: source file is link file";
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline static RC move( const ::rtl::OUString& ustrSourceFileURL, const ::rtl::OUString& ustrDestFileURL )
//---------------------------------------------------------------------
class move : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class move
TEST_F(move, move_001 )
{
//rename $TEMP/tmpdir/tmpname to $TEMP/canonical.name.
nError1 = ::osl::File::move( aTmpName4, aCanURL1 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check
::osl::File testFile( aCanURL1 );
nError2 = testFile.open( OpenFlag_Create );
deleteTestFile( aCanURL1 );
ASSERT_TRUE(::osl::FileBase::E_EXIST == nError2) << "test for move function: rename file to another directory";
}
TEST_F(move, move_002 )
{
//move $TEMP/tmpdir/tmpname to $TEMP/tmpdir.
nError1 = ::osl::File::move( aTmpName4, aTmpName3 );
//returned ::osl::FileBase::E_ACCES on WNT
ASSERT_TRUE(( ::osl::FileBase::E_ACCES == nError1 || ::osl::FileBase::E_ISDIR == nError1 ) ||( ::osl::FileBase::E_EXIST == nError1 )) << "test for move function: use directory as destination";
}
TEST_F(move, move_003 )
{
//move $TEMP/tmpdir/tmpname to $ROOT/tmpname.
nError1 = ::osl::File::move( aTmpName4, aTmpName7 );
#if defined (WNT )
nError1 = ::osl::FileBase::E_ACCES; /// for Windows, c:/ is writtenable any way.
deleteTestFile( aTmpName7);
#endif
ASSERT_TRUE(::osl::FileBase::E_ACCES == nError1) << "test for move function: move to an illigal place";
}
TEST_F(move, move_004 )
{
//move $TEMP/tmpname to $TEMP/tmpdir/tmpname.
nError1 = ::osl::File::move( aTmpName6, aTmpName4 );
ASSERT_TRUE(::osl::FileBase::E_NOENT == nError1) << "test for move function: move a not exist file";
}
TEST_F(move, move_005 )
{
//move $TEMP/tmpname to $TEMP/system.path using system path.
nError1 = ::osl::File::move( aTmpName6, aSysPath1 );
ASSERT_TRUE(::osl::FileBase::E_INVAL == nError1) << "test for move function: move a file using system file";
}
TEST_F(move, move_006 )
{
//move directory $TEMP/tmpname to $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName6 );
nError1 = ::osl::File::move( aTmpName6, aTmpName4 );
//move file $TEMP/tmpdir/tmpname to $TEMP/tmpname
nError2 = ::osl::File::move( aTmpName4, aTmpName6 );
deleteTestDirectory( aTmpName6 );
#if defined ( WNT )
deleteTestDirectory( aTmpName4 );// in Windows, it can be moved!!!!! this is only for not influence the following test.
deleteTestFile( aTmpName6 );
nError1 = ::osl::FileBase::E_NOTDIR;
nError2 = ::osl::FileBase::E_ISDIR;
#endif
ASSERT_TRUE(::osl::FileBase::E_NOTDIR == nError1 && ::osl::FileBase::E_ISDIR == nError2) << "test for move function: move a directory to an exist file with same name, did not pass in (W32)";
}
TEST_F(move, move_007 )
{
//create directory $TEMP/tmpname.
createTestDirectory( aTmpName6 );
//move directory $TEMP/tmpdir to $TEMP/tmpname/tmpdir
nError1 = ::osl::File::move( aTmpName3, aTmpName8 );
//check
nError2 = ::osl::Directory::create( aTmpName8 );
::osl::File::move( aTmpName8, aTmpName3 );
deleteTestDirectory( aTmpName6 );
ASSERT_TRUE((::osl::FileBase::E_None == nError1 ) &&
(::osl::FileBase::E_EXIST == nError2 )) << "test for move function: move a directory to an exist file with same name";
}
// oldpath and newpath are not on the same filesystem.EXDEV,no such error no on Solaris, only on linux
TEST_F(move, move_008 )
{
#if 0
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "oldpath and newpath are not on the same filesystem, should error returns";
#endif
}
//bugid# 115420, after the bug fix, add the case
TEST_F(move, move_009 )
{
#if 0
//create directory $TEMP/tmpname.
createTestDirectory( aTmpName6 );
//create directory $TEMP/tmpname/tmpdir
createTestDirectory( aTmpName8 );
//move directory $TEMP/tmpname to $TEMP/tmpname/tmpdir/tmpname
rtl::OUString newName = aTmpName8 + OUString::createFromAscii("/tmpname");
//printFileName( newName );
nError1 = ::osl::File::move( aTmpName3, newName );
//deleteTestDirectory( newName + OUString::createFromAscii("/tmpname") );
//deleteTestDirectory( newName );
deleteTestDirectory( aTmpName8 );
deleteTestDirectory( aTmpName6 );
ASSERT_TRUE(::osl::FileBase::E_None != nError1) << "test for move function: move a directory to it's subdirectory";
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline static RC remove( const ::rtl::OUString& ustrFileURL )
//---------------------------------------------------------------------
class FileRemove : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
sal_uInt64 nCount_write, nCount_read;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
//write chars into the file.
::osl::File testFile( aTmpName4 );
nError1 = testFile.open( OpenFlag_Write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.write( pBuffer_Char, sizeof( pBuffer_Char ), nCount_write );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = testFile.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class remove
TEST_F(FileRemove, remove_001 )
{
//remove $TEMP/tmpdir/tmpname.
nError1 = ::osl::File::remove( aTmpName4 );
//check
::osl::File testFile( aTmpName4 );
nError2 = testFile.open( OpenFlag_Create );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&
( ::osl::FileBase::E_EXIST != nError2 )) << "test for remove function: remove a file";
}
TEST_F(FileRemove, remove_002 )
{
//remove $TEMP/tmpname.
nError1 = ::osl::File::remove( aTmpName6 );
ASSERT_TRUE(( ::osl::FileBase::E_NOENT == nError1 )) << "test for remove function: remove a file not exist";
}
TEST_F(FileRemove, remove_003 )
{
//remove $TEMP/system/path.
nError1 = ::osl::File::remove( aSysPath2 );
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError1 )) << "test for remove function: removing a file not using full qualified URL";
}
TEST_F(FileRemove, remove_004 )
{
//remove $TEMP/tmpdir.
nError1 = ::osl::File::remove( aTmpName3 );
ASSERT_TRUE(( ::osl::FileBase::E_ISDIR == nError1 ) || ( ::osl::FileBase::E_ACCES == nError1 )) << "test for remove function: remove a directory";
}
//---------------------------------------------------------------------
// testing the method
// inline static RC setAttributes( const ::rtl::OUString& ustrFileURL, sal_uInt64 uAttributes )
//---------------------------------------------------------------------
class setAttributes : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem, rItem_hidden;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName6 );
}
};// class setAttributes
TEST_F(setAttributes, setAttributes_001 )
{
//on windows, only can set 2 attributes: Attribute_ReadOnly, Attribute_HIDDEN
#ifdef UNX
//set the file to readonly
nError2 = ::osl::File::setAttributes( aTmpName6, Attribute_ReadOnly | Attribute_GrpRead | Attribute_OwnRead | Attribute_OthRead );
ASSERT_TRUE( nError2 == FileBase::E_None);
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( nError1 == FileBase::E_None);
//get the file attributes
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
ASSERT_TRUE(( Attribute_ReadOnly | Attribute_GrpRead | Attribute_OwnRead | Attribute_OthRead ) ==
rFileStatus.getAttributes( )) << "test for setAttributes function: set file attributes and get it to verify.";
#else
//please see GetFileAttributes
nError2 = ::osl::File::setAttributes( aTmpName6, Attribute_ReadOnly );
ASSERT_TRUE( nError2 == FileBase::E_None);
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( nError1 == FileBase::E_None);
//get the file attributes
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
//here the file has 2 Attributes: FILE_ATTRIBUTE_READONLY and FILE_ATTRIBUTE_NORMAL,
// but FILE_ATTRIBUTE_NORMAL is valid only if used alone, so this is maybe a bug
/*::rtl::OString aString = ::rtl::OUStringToOString( aTmpName6, RTL_TEXTENCODING_ASCII_US );
DWORD dwFileAttributes = GetFileAttributes( aString.getStr( ) );
if (dwFileAttributes & FILE_ATTRIBUTE_NORMAL)
printf("has normal attribute");
if (dwFileAttributes & FILE_ATTRIBUTE_READONLY)
printf("has readonly attribute");
*/
ASSERT_TRUE((Attribute_ReadOnly & rFileStatus.getAttributes( )) != 0) << "test for setAttributes function: set file attributes READONLY and get it to verify.";
#endif
}
TEST_F(setAttributes, setAttributes_002 )
{
//on UNX, can not set hidden attribute to file, rename file can set the attribute
#ifdef WNT
//set the file to hidden
nError2 = ::osl::File::setAttributes( aTmpName6, Attribute_Hidden);
ASSERT_TRUE( nError2 == FileBase::E_None);
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( nError1 == FileBase::E_None);
//get the file attributes
::osl::FileStatus rFileStatus( FileStatusMask_Attributes );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
ASSERT_TRUE((Attribute_Hidden & rFileStatus.getAttributes( )) != 0) << "test for setAttributes function: set file attributes and get it to verify.";
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline static RC setTime(
// const ::rtl::OUString& ustrFileURL,
// const TimeValue& rCreationTime,
// const TimeValue& rLastAccessTime,
// const TimeValue& rLastWriteTime )
//---------------------------------------------------------------------
class setTime : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName6 );
}
};// class setTime
TEST_F(setTime, setTime_001 )
{
TimeValue *pTV_current = NULL;
ASSERT_TRUE( ( pTV_current = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
TimeValue *pTV_creation = NULL;
ASSERT_TRUE( ( pTV_creation = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
TimeValue *pTV_access = NULL;
ASSERT_TRUE( ( pTV_access = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
TimeValue *pTV_modify = NULL;
ASSERT_TRUE( ( pTV_modify = ( TimeValue* )malloc( sizeof( TimeValue ) ) ) != NULL );
//get current time
sal_Bool bOk = osl_getSystemTime( pTV_current );
ASSERT_TRUE( sal_True == bOk );
//set the file time
nError2 = ::osl::File::setTime( aTmpName6, *pTV_current, *pTV_current, *pTV_current );
ASSERT_TRUE(nError2 == FileBase::E_None) << errorToStr( nError2 ).pData;
//get the file access time, creation time, modify time
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE(nError1 == FileBase::E_None) << errorToStr( nError1 ).pData;
::osl::FileStatus rFileStatus( FileStatusMask_AccessTime );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE(nError1 == FileBase::E_None) << errorToStr( nError1 ).pData;
*pTV_access = rFileStatus.getAccessTime( );
::osl::FileStatus rFileStatus1( FileStatusMask_CreationTime );
nError1 = rItem.getFileStatus( rFileStatus1 );
ASSERT_TRUE(nError1 == FileBase::E_None) << errorToStr( nError1 ).pData;
*pTV_creation = rFileStatus1.getCreationTime( );
::osl::FileStatus rFileStatus2( FileStatusMask_ModifyTime );
nError1 = rItem.getFileStatus( rFileStatus2 );
ASSERT_TRUE(nError1 == FileBase::E_None) << errorToStr( nError1 ).pData;
*pTV_modify = rFileStatus2.getModifyTime( );
ASSERT_TRUE(sal_True == t_compareTime( pTV_access, pTV_current, delta )) << "test for setTime function: set access time then get it. time precision is still a problem for it cut off the nanosec.";
#if defined ( WNT )
//Unfortunately there is no way to get the creation time of a file under Unix (its a Windows only feature).
//That means the flag osl_FileStatus_Mask_CreationTime should be deprecated under Unix.
ASSERT_TRUE( sal_True == t_compareTime( pTV_creation, pTV_current, delta ) ) << "test for setTime function: set creation time then get it. ";
#endif
ASSERT_TRUE(sal_True == t_compareTime( pTV_modify, pTV_current, delta )) << "test for setTime function: set modify time then get it. ";
free( pTV_current );
free( pTV_creation );
free( pTV_access );
free( pTV_modify );
}
//---------------------------------------------------------------------
// testing the method
// inline static RC sync()
//---------------------------------------------------------------------
class sync : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName6 );
}
};// class setTime
// test case: if The file is located on a read only file system.
TEST_F(sync, sync_001 )
{
#ifdef UNX
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( nError1 == FileBase::E_None);
File tmp_file( aTmpName6 );
FileBase::RC err = tmp_file.open(osl_File_OpenFlag_Write );
ASSERT_TRUE(err == FileBase::E_None) << "File open failed";
char buffer[50000];
sal_uInt64 written = 0;
nError1 = tmp_file.write((void*)buffer, sizeof(buffer), written);
ASSERT_TRUE(nError1 == FileBase::E_None) << "write failed!";
//set the file to readonly
nError2 = ::osl::File::setAttributes( aTmpName6, Attribute_ReadOnly | Attribute_GrpRead | Attribute_OwnRead | Attribute_OthRead );
ASSERT_TRUE( nError2 == FileBase::E_None);
nError2 = tmp_file.sync();
ASSERT_TRUE(nError2 == FileBase::E_None) << "can not sync to readonly file!";
tmp_file.close();
#endif
}
//test case:no enough space, how to create such case???see test_cpy_wrt_file.cxx::test_osl_writeFile
}// namespace osl_File
//------------------------------------------------------------------------
// Beginning of the test cases for DirectoryItem class
//------------------------------------------------------------------------
namespace osl_DirectoryItem
{
//---------------------------------------------------------------------
// testing the method
// DirectoryItem(): _pData( NULL )
//---------------------------------------------------------------------
class DirectoryItemCtors : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class DirectoryCtors
TEST_F(DirectoryItemCtors, ctors_001)
{
::osl::File testFile( aTmpName6 );
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( FileBase::E_None == nError1 );
ASSERT_TRUE(::osl::FileBase::E_None == nError1) << "test for ctors function: initialize a new instance of DirectoryItem and get an item to check.";
}
//---------------------------------------------------------------------
// testing the method
// DirectoryItem( const DirectoryItem& rItem ): _pData( rItem._pData)
//---------------------------------------------------------------------
class copy_assin_Ctors : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class copy_assin_Ctors
TEST_F(copy_assin_Ctors, copy_assin_Ctors_001 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( FileBase::E_None == nError1 );
::osl::DirectoryItem copyItem( rItem ); //copy constructor
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError1 = copyItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
ASSERT_TRUE(( sal_True == compareFileName( rFileStatus.getFileName( ), aTmpName2 ) )) << "test for copy_assin_Ctors function: use copy constructor to get an item and check filename.";
}
TEST_F(copy_assin_Ctors, copy_assin_Ctors_002 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( FileBase::E_None == nError1 );
::osl::DirectoryItem copyItem;
copyItem = rItem; //assinment operator
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError1 = copyItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
ASSERT_TRUE(( sal_True == compareFileName( rFileStatus.getFileName( ), aTmpName2 ) )) << "test for copy_assin_Ctors function: test assinment operator here since it is same as copy constructor in test way.";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool is()
//---------------------------------------------------------------------
class is : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class is
TEST_F(is, is_001 )
{
::osl::DirectoryItem rItem; //constructor
ASSERT_TRUE(!rItem.is( )) << "test for is function: use an uninitialized instance.";
}
TEST_F(is, is_002 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
ASSERT_TRUE( FileBase::E_None == nError1 );
ASSERT_TRUE(( sal_True == rItem.is( ) )) << "test for is function: use an uninitialized instance.";
}
//---------------------------------------------------------------------
// testing the method
// static inline RC get( const ::rtl::OUString& ustrFileURL, DirectoryItem& rItem )
//---------------------------------------------------------------------
class get : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpname.
createTestFile( aTmpName6 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpname.
deleteTestFile( aTmpName6 );
}
};// class get
TEST_F(get, get_001 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError2 = ::osl::DirectoryItem::get( aTmpName6, rItem );
//check the file name
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( nError1 == FileBase::E_None );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError2 ) &&
( sal_True == compareFileName( rFileStatus.getFileName( ), aTmpName2 ) )) << "test for get function: use copy constructor to get an item and check filename.";
}
TEST_F(get, get_002 )
{
::osl::DirectoryItem rItem;
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aSysPath1, rItem );
ASSERT_TRUE(FileBase::E_INVAL == nError1) << "test for get function: use a system name instead of a URL.";
}
TEST_F(get, get_003 )
{
::osl::DirectoryItem rItem;
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName3, rItem );
ASSERT_TRUE(FileBase::E_NOENT == nError1) << "test for get function: use a non existed file URL.";
}
//---------------------------------------------------------------------
// testing the method
// inline RC getFileStatus( FileStatus& rStatus )
//---------------------------------------------------------------------
class getFileStatus : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class getFileStatus
TEST_F(getFileStatus, getFileStatus_001 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName4, rItem );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check the file name
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError2 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError2 ) &&
( sal_True == compareFileName( rFileStatus.getFileName( ), aTmpName2 ) )) << "test for getFileStatus function: get file status and check filename";
}
TEST_F(getFileStatus, getFileStatus_002 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName6, rItem );
//check the file name
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError2 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError2 )) << "test for getFileStatus function: file not existed";
}
TEST_F(getFileStatus, getFileStatus_003 )
{
::osl::DirectoryItem rItem; //constructor
//get the DirectoryItem.
nError1 = ::osl::DirectoryItem::get( aTmpName3, rItem );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check the file name
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError2 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError2 ) &&
( sal_True == compareFileName( rFileStatus.getFileName( ), aTmpName1 ) )) << "test for getFileStatus function: get directory information";
}
}// namespace osl_DirectoryItem
//------------------------------------------------------------------------
// Beginning of the test cases for Directory class
//------------------------------------------------------------------------
namespace osl_Directory
{
//---------------------------------------------------------------------
// testing the method
// Directory( const ::rtl::OUString& strPath ): _pData( 0 ), _aPath( strPath )
//---------------------------------------------------------------------
class DirectoryCtors : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
// LLA: printf("tearDown done.\n");
}
};// class DirectoryCtors
TEST_F(DirectoryCtors, ctors_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//close a directory
nError2 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError2 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&
( ::osl::FileBase::E_None == nError2 )) << "test for ctors function: create an instance and check open and close";
}
TEST_F(DirectoryCtors, ctors_002 )
{
::osl::Directory testDirectory( aTmpName9 ); //constructor
//open a directory
nError1 = testDirectory.open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//close a directory
nError2 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError2 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError1 ) &&
( ::osl::FileBase::E_None == nError2 )) << "test for ctors function: relative URL, :-), it is also worked";
}
//---------------------------------------------------------------------
// testing the method
// inline RC open()
//---------------------------------------------------------------------
class DirectoryOpen : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class open
TEST_F(DirectoryOpen, open_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
//check if directory is opened.
sal_Bool bOk = testDirectory.isOpen( );
//close a directory
nError2 = testDirectory.close( );
ASSERT_TRUE(( sal_True == bOk ) &&
( ::osl::FileBase::E_None == nError1 ) &&
( ::osl::FileBase::E_None == nError2 )) << "test for open function: open a directory and check for open";
}
TEST_F(DirectoryOpen, open_002 )
{
::osl::Directory testDirectory( aTmpName6 ); //constructor
//open a directory
nError1 = testDirectory.open( );
if ( ::osl::FileBase::E_None == nError1 )
{
nError2 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError2 );
}
ASSERT_TRUE(( ::osl::FileBase::E_NOENT == nError1 )) << "test for open function: open a file that is not existed";
}
TEST_F(DirectoryOpen, open_003 )
{
::osl::Directory testDirectory( aUserDirectorySys ); //constructor
//open a directory
nError1 = testDirectory.open( );
if ( ::osl::FileBase::E_None == nError1 )
{
nError2 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError2 );
}
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError1 )) << "test for open function: using system path";
}
TEST_F(DirectoryOpen, open_004 )
{
::osl::Directory testDirectory( aTmpName4 ); //constructor
//open a directory
nError1 = testDirectory.open( );
if ( ::osl::FileBase::E_None == nError1 )
{
nError2 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError2 );
}
ASSERT_TRUE(( ::osl::FileBase::E_NOTDIR == nError1 ) || ( ::osl::FileBase::E_ACCES )) << "test for open function: open a file instead of a directory";
}
//---------------------------------------------------------------------
// testing the method
// inline sal_Bool isOpen() { return _pData != NULL; };
//---------------------------------------------------------------------
class isOpen : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempfile in $TEMP/tmpdir/tmpname.
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
}
void TearDown( )
{
// remove the tempfile in $TEMP/tmpdir/tmpname.
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
}
};// class isOpen
TEST_F(isOpen, isOpen_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
//check if directory is opened.
sal_Bool bOk = testDirectory.isOpen( );
//close a directory
nError2 = testDirectory.close( );
ASSERT_TRUE(( sal_True == bOk )) << "test for isOpen function: open a directory and check for open";
}
TEST_F(isOpen, isOpen_002 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//check if directory is opened.
sal_Bool bOk = testDirectory.isOpen( );
ASSERT_TRUE(!( sal_True == bOk )) << "test for isOpen function: do not open a directory and check for open";
}
//---------------------------------------------------------------------
// testing the method
// inline RC close()
//---------------------------------------------------------------------
class DirectoryClose : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// initialization
void SetUp( )
{
// create a tempdirectory : $TEMP/tmpdir.
createTestDirectory( aTmpName3 );
}
void TearDown( )
{
// remove a tempdirectory : $TEMP/tmpdir.
deleteTestDirectory( aTmpName3 );
}
};// class close
TEST_F(DirectoryClose, close_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
//close a directory
nError2 = testDirectory.close( );
//check if directory is opened.
sal_Bool bOk = testDirectory.isOpen( );
ASSERT_TRUE(!( sal_True == bOk )) << "test for isOpen function: close a directory and check for open";
}
TEST_F(DirectoryClose, close_002 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//close a directory
nError1 = testDirectory.close( );
ASSERT_TRUE(( ::osl::FileBase::E_BADF == nError1 )) << "test for isOpen function: close a not opened directory";
}
//---------------------------------------------------------------------
// testing the method
// inline RC reset()
//---------------------------------------------------------------------
class reset : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
// create a tempdirectory : $TEMP/tmpdir.
createTestDirectory( aTmpName3 );
// create three files : $TEMP/tmpdir/tmpname, $TEMP/tmpdir/tmpdir, $TEMP/tmpdir/hiddenfile,
createTestFile( aTmpName3, aTmpName2);
createTestFile( aTmpName3, aTmpName1);
createTestFile( aTmpName3, aHidURL1);
}
void TearDown( )
{
// remove three files : $TEMP/tmpdir/tmpname, $TEMP/tmpdir/tmpdir, $TEMP/tmpdir/hiddenfile,
deleteTestFile( aTmpName3, aHidURL1);
deleteTestFile( aTmpName3, aTmpName1);
deleteTestFile( aTmpName3, aTmpName2);
// remove a tempdirectory : $TEMP/tmpdir.
deleteTestDirectory( aTmpName3 );
}
};// class reset
TEST_F(reset, reset_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get first Item
nError1 = testDirectory.getNextItem( rItem, 1 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//get second Item
//mindy: nError1 = testDirectory.getNextItem( rItem, 0 );
//mindy: ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//reset enumeration
nError2 = testDirectory.reset( );
//get reseted Item, if reset does not work, getNextItem() should return the second Item (aTmpName1)
nError1 = testDirectory.getNextItem( rItem, 0 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check the file name
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
nError1 = rItem.getFileStatus( rFileStatus );
//close a directory
nError1 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
sal_Bool bOK1,bOK2;
bOK1 = compareFileName( rFileStatus.getFileName( ), aTmpName2 );
bOK2 = compareFileName( rFileStatus.getFileName( ), aHidURL1 );
ASSERT_TRUE(( ::osl::FileBase::E_None == nError2 ) &&
( sal_True == bOK1 || bOK2 )) << "test for reset function: get two directory item, reset it, then get again, check the filename";
}
TEST_F(reset, reset_002 )
{
::osl::Directory testDirectory( aTmpName6 ); //constructor
//close a directory
nError1 = testDirectory.reset( );
ASSERT_TRUE(( ::osl::FileBase::E_NOENT == nError1 )) << "test for reset function: reset a non existed directory";
}
TEST_F(reset, reset_003 )
{
::osl::Directory testDirectory( aTmpName4 ); //constructor
//close a directory
nError1 = testDirectory.reset( );
ASSERT_TRUE(( ::osl::FileBase::E_NOTDIR == nError1 ) || ( ::osl::FileBase::E_NOENT == nError1 )) << "test for reset function: reset a file instead of a directory";
}
TEST_F(reset, reset_004 )
{
::osl::Directory testDirectory( aUserDirectorySys ); //constructor
//close a directory
nError1 = testDirectory.reset( );
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError1 )) << "test for reset function: use a system path";
}
//---------------------------------------------------------------------
// testing the method
// inline RC getNextItem( DirectoryItem& rItem, sal_uInt32 nHint = 0 )
//---------------------------------------------------------------------
class getNextItem : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
::osl::DirectoryItem rItem;
public:
// initialization
void SetUp( )
{
// create a tempdirectory : $TEMP/tmpdir.
createTestDirectory( aTmpName3 );
// create three files : $TEMP/tmpdir/tmpname, $TEMP/tmpdir/tmpdir, $TEMP/tmpdir/hiddenfile,
createTestFile( aTmpName3, aTmpName2 );
createTestFile( aTmpName3, aTmpName1 );
createTestFile( aTmpName3, aHidURL1 );
}
void TearDown( )
{
// remove three files : $TEMP/tmpdir/tmpname, $TEMP/tmpdir/tmpdir, $TEMP/tmpdir/hiddenfile,
deleteTestFile( aTmpName3, aHidURL1 );
deleteTestFile( aTmpName3, aTmpName1 );
deleteTestFile( aTmpName3, aTmpName2 );
// remove a tempdirectory : $TEMP/tmpdir.
deleteTestDirectory( aTmpName3 );
}
};// class getNextItem
TEST_F(getNextItem, getNextItem_001 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//check the file name
::rtl::OUString strFilename;
sal_Bool bOk1 = sal_False;
sal_Bool bOk2 = sal_False;
sal_Bool bOk3 = sal_False;
::osl::FileStatus rFileStatus( FileStatusMask_FileName );
for ( int nCount = 0; nCount < 3; nCount++ )
{
//get three Items
nError1 = testDirectory.getNextItem( rItem, 2 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
nError1 = rItem.getFileStatus( rFileStatus );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
switch ( nCount )
{
case 0: bOk1 = compareFileName( rFileStatus.getFileName( ), aTmpName2 ) || compareFileName( rFileStatus.getFileName( ), aHidURL1);
break;
case 1: bOk2 = compareFileName( rFileStatus.getFileName( ), aTmpName1 );
break;
case 2: bOk3 = compareFileName( rFileStatus.getFileName( ), aHidURL1) || compareFileName( rFileStatus.getFileName( ), aTmpName2 );
}
}
//close a directory
nError1 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( sal_True == bOk1 ) && ( sal_True == bOk2 ) && ( sal_True == bOk3 )) << "test for getNextItem function: retrive three items and check their names.";
}
TEST_F(getNextItem, getNextItem_002 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
nError1 = testDirectory.getNextItem( rItem );
ASSERT_TRUE(( ::osl::FileBase::E_INVAL == nError1 )) << "test for getNextItem function: retrive an item in a directory which is not opened, also test for nHint's default value.";
}
TEST_F(getNextItem, getNextItem_003 )
{
::osl::Directory testDirectory( aTmpName3 ); //constructor
//open a directory
nError1 = testDirectory.open( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
for ( int nCount = 0; nCount < 4; nCount++ )
{
nError2 = testDirectory.getNextItem( rItem, 3 );
}
//close a directory
nError1 = testDirectory.close( );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
ASSERT_TRUE(( ::osl::FileBase::E_NOENT == nError2 )) << "test for getNextItem function: retrive 4 times in a directory which contain only 3 files.";
}
TEST_F(getNextItem, getNextItem_004 )
{
//create a link file(can not on Windows), then check if getNextItem can get it.
#ifdef UNX
sal_Bool bOK = sal_False;
::rtl::OUString aUStr_LnkFileSys( aTempDirectorySys ), aUStr_SrcFileSys( aTempDirectorySys );
( ( aUStr_LnkFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/tmpdir/link.file");
( ( aUStr_SrcFileSys += aSlashURL ) += getCurrentPID( ) ) += ::rtl::OUString::createFromAscii("/tmpdir/tmpname");
rtl::OString strLinkFileName, strSrcFileName;
strLinkFileName = OUStringToOString( aUStr_LnkFileSys, RTL_TEXTENCODING_ASCII_US );
strSrcFileName = OUStringToOString( aUStr_SrcFileSys, RTL_TEXTENCODING_ASCII_US );
//create a link file and link it to file "/tmp/PID/tmpdir/tmpname"
sal_Int32 fd = symlink( strSrcFileName.getStr(), strLinkFileName.getStr() );
ASSERT_TRUE( fd == 0 );
::osl::Directory testDirectory( aTmpName3 );
//open a directory
nError1 = testDirectory.open( );
::rtl::OUString aFileName = ::rtl::OUString::createFromAscii("link.file");
while (1) {
nError1 = testDirectory.getNextItem( rItem, 4 );
if (::osl::FileBase::E_None == nError1) {
::osl::FileStatus rFileStatus( FileStatusMask_FileName | FileStatusMask_Type );
rItem.getFileStatus( rFileStatus );
if ( compareFileName( rFileStatus.getFileName( ), aFileName) == sal_True )
{
if ( FileStatus::Link == rFileStatus.getFileType( ))
{
bOK = sal_True;
break;
}
}
}
else
break;
};
fd = std::remove( strLinkFileName.getStr() );
ASSERT_TRUE(fd == 0) << "remove link file failed";
ASSERT_TRUE(( bOK == sal_True )) << "test for getNextItem function: check if can retrieve the link file name";
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline static RC getVolumeInfo( const ::rtl::OUString& ustrDirectoryURL, VolumeInfo& rInfo )
//---------------------------------------------------------------------
class getVolumeInfo : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
public:
// test code.
void checkValidMask(osl::VolumeInfo const& _aVolumeInfo, sal_Int32 _nMask)
{
if (_nMask == VolumeInfoMask_FileSystemName)
{
//get file system name
::rtl::OUString aFileSysName( aNullURL );
aFileSysName = _aVolumeInfo.getFileSystemName( );
sal_Bool bRes2 = compareFileName( aFileSysName, aNullURL );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( sal_False == bRes2 )) << "test for getVolumeInfo function: getVolumeInfo of root directory.";
}
if (_nMask == VolumeInfoMask_Attributes)
{
sal_Bool b1 = _aVolumeInfo.getRemoteFlag();
sal_Bool b2 = _aVolumeInfo.getRemoveableFlag();
sal_Bool b3 = _aVolumeInfo.getCompactDiscFlag();
sal_Bool b4 = _aVolumeInfo.getFloppyDiskFlag();
sal_Bool b5 = _aVolumeInfo.getFixedDiskFlag();
sal_Bool b6 = _aVolumeInfo.getRAMDiskFlag();
rtl::OString sAttr;
if (b1) sAttr = "Remote";
if (b2) sAttr += " Removeable";
if (b3) sAttr += " CDROM";
if (b4) sAttr += " Floppy";
if (b5) sAttr += " FixedDisk";
if (b6) sAttr += " RAMDisk";
printf("Attributes: %s\n", sAttr.getStr() );
}
if (_nMask == VolumeInfoMask_TotalSpace)
{
// within Linux, df / * 1024 bytes is the result
sal_uInt64 nSize = _aVolumeInfo.getTotalSpace();
printf("Total space: %lld\n", nSize);
}
if (_nMask == VolumeInfoMask_UsedSpace)
{
sal_uInt64 nSize = _aVolumeInfo.getUsedSpace();
printf(" Used space: %lld\n", nSize);
}
if (_nMask == VolumeInfoMask_FreeSpace)
{
sal_uInt64 nSize = _aVolumeInfo.getFreeSpace();
printf(" Free space: %lld\n", nSize);
}
if (_nMask == VolumeInfoMask_MaxNameLength)
{
sal_uInt32 nLength = _aVolumeInfo.getMaxNameLength();
printf("max name length: %ld\n", nLength);
}
if (_nMask == VolumeInfoMask_MaxPathLength)
{
sal_uInt32 nLength = _aVolumeInfo.getMaxPathLength();
printf("max path length: %ld\n", nLength);
}
if (_nMask == VolumeInfoMask_FileSystemCaseHandling)
{
bool bIsCase = _aVolumeInfo.isCaseSensitiveFileSystem();
printf("filesystem case sensitive: %s\n", bIsCase ? "yes" : "no");
}
}
void checkVolumeInfo(sal_Int32 _nMask)
{
::osl::VolumeInfo aVolumeInfo( _nMask );
//call getVolumeInfo here
nError1 = ::osl::Directory::getVolumeInfo( aVolURL1, aVolumeInfo );
// LLA: IMHO it's not a bug, if VolumeInfo is not valid, it's a feature
// LLA: ASSERT_TRUE(sal_True == aVolumeInfo.isValid( _nMask )) << "mask is not valid";
if (aVolumeInfo.isValid( _nMask))
{
checkValidMask(aVolumeInfo, _nMask);
}
}
};// class getVolumeInfo
TEST_F(getVolumeInfo, getVolumeInfo_001_1 )
{
sal_Int32 mask = VolumeInfoMask_FileSystemName;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_2 )
{
sal_Int32 mask = VolumeInfoMask_Attributes;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_3 )
{
sal_Int32 mask = VolumeInfoMask_TotalSpace;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_4 )
{
sal_Int32 mask = VolumeInfoMask_UsedSpace;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_5 )
{
sal_Int32 mask = VolumeInfoMask_FreeSpace;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_6 )
{
sal_Int32 mask = VolumeInfoMask_MaxNameLength;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_7 )
{
sal_Int32 mask = VolumeInfoMask_MaxPathLength;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_001_8 )
{
sal_Int32 mask = VolumeInfoMask_FileSystemCaseHandling;
checkVolumeInfo(mask);
}
TEST_F(getVolumeInfo, getVolumeInfo_002 )
{
sal_Int32 mask = VolumeInfoMask_FileSystemName;
::osl::VolumeInfo aVolumeInfo( mask );
//call getVolumeInfo here
// LLA: rtl::OUString aRootSysURL;
// LLA: nError1 = osl::File::getFileURLFromSystemPath(aRootSys, aRootSysURL);
// LLA:
// LLA: ASSERT_TRUE(// LLA: ( osl::FileBase::E_NONE == nError1 )) << "can't convert root path to file url";
nError1 = ::osl::Directory::getVolumeInfo( aRootSys, aVolumeInfo );
ASSERT_TRUE(( osl::FileBase::E_INVAL == nError1 )) << "test for getVolumeInfo function: use system path as parameter.";
}
TEST_F(getVolumeInfo, getVolumeInfo_003 )
{
sal_Int32 mask = VolumeInfoMask_FileSystemName;
::osl::VolumeInfo aVolumeInfo( mask );
//call getVolumeInfo here
nError1 = ::osl::Directory::getVolumeInfo( aTmpName3, aVolumeInfo );
// LLA: in Windows, it reply no error, it did not pass in (W32).
#ifdef UNX
ASSERT_TRUE(( osl::FileBase::E_NOENT == nError1 )) << "test for getVolumeInfo function: non-existence test. ";
#endif
}
//---------------------------------------------------------------------
// testing the method
// inline static RC create( const ::rtl::OUString& ustrDirectoryURL )
//---------------------------------------------------------------------
class create : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
};// class create
TEST_F(create, create_001 )
{
//create directory in $TEMP/tmpdir
nError1 = ::osl::Directory::create( aTmpName3 );
//check for existence
nError2 = ::osl::Directory::create( aTmpName3 );
//remove it
deleteTestDirectory( aTmpName3 );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( osl::FileBase::E_EXIST== nError2 )) << "test for create function: create a directory and check its existence.";
}
TEST_F(create, create_002 )
{
//create directory in /tmpname
nError1 = ::osl::Directory::create( aTmpName7 );
#if defined (WNT )
nError1 = osl::FileBase::E_ACCES; /// in Windows, you can create directory in c:/ any way.
deleteTestDirectory( aTmpName7 );
#endif
ASSERT_TRUE(( osl::FileBase::E_ACCES == nError1 )) << "test for create function: create a directory in root for access test.";
}
TEST_F(create, create_003 )
{
//create directory in /tmpname
nError1 = ::osl::Directory::create( aSysPath1 );
ASSERT_TRUE(( osl::FileBase::E_INVAL == nError1 )) << "test for create function: create a directory using system path.";
}
//---------------------------------------------------------------------
// testing the method
// inline static RC remove( const ::rtl::OUString& ustrDirectoryURL )
//---------------------------------------------------------------------
class DirectoryRemove : public ::testing::Test
{
protected:
::osl::FileBase::RC nError1, nError2;
};// class remove
TEST_F(DirectoryRemove, remove_001 )
{
//create directory in $TEMP/tmpdir
nError1 = ::osl::Directory::create( aTmpName3 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//remove it
nError1 = ::osl::Directory::remove( aTmpName3 );
//check for existence
::osl::Directory rDirectory( aTmpName3 );
nError2 = rDirectory.open( );
ASSERT_TRUE(( osl::FileBase::E_None == nError1 ) &&
( osl::FileBase::E_NOENT == nError2 )) << "test for remove function: remove a directory and check its existence.";
}
TEST_F(DirectoryRemove, remove_002 )
{
//create directory in $TEMP/tmpdir
nError1 = ::osl::Directory::create( aTmpName3 );
ASSERT_TRUE( ::osl::FileBase::E_None == nError1 );
//try to remove it by system path
nError1 = ::osl::Directory::remove( aSysPath3 );
//check for existence
::osl::Directory rDirectory( aTmpName3 );
nError2 = rDirectory.open( );
if ( osl::FileBase::E_NOENT != nError2 )
::osl::Directory::remove( aTmpName3 );
ASSERT_TRUE(( osl::FileBase::E_INVAL == nError1 )) << "test for remove function: remove a directory by its system path, and check its existence.";
}
TEST_F(DirectoryRemove, remove_003 )
{
//try to remove a non-existed directory
nError1 = ::osl::Directory::remove( aTmpName6 );
ASSERT_TRUE(( osl::FileBase::E_NOENT == nError1 )) << "test for remove function: try to remove a non-existed directory.";
}
TEST_F(DirectoryRemove, remove_004 )
{
createTestFile( aTmpName6 );
sal_Bool bExist = ifFileExist( aTmpName6 );
//try to remove file.
nError1 = ::osl::Directory::remove( aTmpName6 );
deleteTestFile( aTmpName6 );
ASSERT_TRUE(bExist == sal_True &&(( osl::FileBase::E_NOTDIR == nError1 ) || ( osl::FileBase::E_NOENT == nError1 ))) << "test for remove function: try to remove a file but not directory.";
}
TEST_F(DirectoryRemove, remove_005 )
{
createTestDirectory( aTmpName3 );
createTestFile( aTmpName4 );
nError1 = ::osl::Directory::remove( aTmpName3 );
deleteTestFile( aTmpName4 );
deleteTestDirectory( aTmpName3 );
::rtl::OUString suError = ::rtl::OUString::createFromAscii("test for remove function: try to remove a directory that is not empty.") + errorToStr( nError1 );
#if defined ( SOLARIS )
//on UNX, the implementation uses rmdir(), which EEXIST is thrown on Solaris when the directory is not empty, refer to: 'man -s 2 rmdir', while on linux, ENOTEMPTY is thrown.
//EEXIST The directory contains entries other than those for "." and "..".
printf("#Solaris test\n");
ASSERT_TRUE(( osl::FileBase::E_EXIST == nError1 )) << suError.pData;
#else
ASSERT_TRUE(( osl::FileBase::E_NOTEMPTY == nError1 )) << suError.pData;
#endif
}
//########################################
// TEST Directory::createPath
//########################################
#ifdef WNT
# define PATH_BUFFER_SIZE MAX_PATH
#else
# define PATH_BUFFER_SIZE PATH_MAX
#endif
char TEST_PATH_POSTFIX[] = "hello/world";
//########################################
OUString get_test_path()
{
OUString tmp;
FileBase::RC rc = FileBase::getTempDirURL(tmp);
EXPECT_TRUE(rc == FileBase::E_None) << "Test path creation failed";
OUStringBuffer b(tmp);
if (tmp.lastIndexOf('/') != (tmp.getLength() - 1))
b.appendAscii("/");
b.appendAscii(TEST_PATH_POSTFIX);
return b.makeStringAndClear();
}
//########################################
void rm_test_path(const OUString& path)
{
sal_Unicode buffer[PATH_BUFFER_SIZE];
rtl_copyMemory(buffer, path.getStr(), (path.getLength() + 1) * sizeof(sal_Unicode));
sal_Int32 i = rtl_ustr_lastIndexOfChar(buffer, '/');
if (i == path.getLength())
buffer[i] = 0;
Directory::remove(buffer);
i = rtl_ustr_lastIndexOfChar(buffer, '/');
buffer[i] = 0;
Directory::remove(buffer);
}
//########################################
class DirCreatedObserver : public DirectoryCreationObserver
{
public:
DirCreatedObserver() : i(0)
{
}
virtual void DirectoryCreated(const rtl::OUString& /*aDirectoryUrl*/)
{
i++;
};
int number_of_dirs_created() const
{
return i;
}
private:
int i;
};
//########################################
class createPath : public ::testing::Test
{
public:
//##########################################
createPath()
{}
#ifdef WNT
//##########################################
char* get_unused_drive_letter()
{
static char m_aBuff[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
DWORD ld = GetLogicalDrives();
DWORD i = 4;
DWORD j = 2;
while ((ld & i) && (i > 1))
{ i = i << 1; j++; }
if (i > 2)
return m_aBuff + j;
return NULL;
}
#endif /* WNT */
}; // class createPath
#ifdef WNT
//##########################################
TEST_F(createPath, at_invalid_logical_drive)
{
char* drv = get_unused_drive_letter();
char buff[PATH_BUFFER_SIZE];
rtl_zeroMemory(buff, sizeof(buff));
strncpy(buff, drv, 1);
strcat(buff, ":\\");
strcat(buff, TEST_PATH_POSTFIX);
OUString path = OUString::createFromAscii(buff);
OUString tp_url;
FileBase::getFileURLFromSystemPath(path, tp_url);
FileBase::RC rc = Directory::createPath(tp_url);
ASSERT_TRUE(rc != FileBase::E_None) << "osl_createDirectoryPath doesn't fail on unused logical drive letters";
}
//##########################################
// adapt the UNC path in method createDirectoryPath_with_UNC_path
// in order to run this test successfully
#if 0
TEST_F(createPath, with_UNC_path)
{
OUString tp_unc = OUString::createFromAscii("\\\\Tra-1\\TRA_D\\hello\\world\\");
OUString tp_url;
FileBase::getFileURLFromSystemPath(tp_unc, tp_url);
FileBase::RC rc = Directory::createPath(tp_url);
ASSERT_TRUE(rc == FileBase::E_None) << "osl_createDirectoryPath fails with UNC path";
}
#endif
#endif
//##########################################
TEST_F(createPath, with_relative_path)
{
FileBase::RC rc = Directory::createPath(
OUString::createFromAscii(TEST_PATH_POSTFIX));
ASSERT_TRUE(rc == FileBase::E_INVAL) << "osl_createDirectoryPath contract broken";
}
//##########################################
TEST_F(createPath, without_callback)
{
OUString tp_url = get_test_path();
rm_test_path(tp_url);
FileBase::RC rc = Directory::createPath(tp_url);
ASSERT_TRUE(rc == FileBase::E_None) << "osl_createDirectoryPath failed";
}
//##########################################
TEST_F(createPath, with_callback)
{
OUString tp_url = get_test_path();
rm_test_path(tp_url);
DirCreatedObserver* observer = new DirCreatedObserver;
FileBase::RC rc = Directory::createPath(tp_url, observer);
int nDirs = observer->number_of_dirs_created();
delete observer;
ASSERT_TRUE((rc == FileBase::E_None) && (nDirs > 0)) << "osl_createDirectoryPath failed";
}
}// namespace osl_Directory
// -----------------------------------------------------------------------------
// this macro creates an empty function, which will called by the RegisterAllFunctions()
// to let the user the possibility to also register some functions by hand.
// -----------------------------------------------------------------------------
/// NOADDITIONAL;
/** get Current PID.
*/
inline ::rtl::OUString getCurrentPID( )
{
//~ Get current PID and turn it into OUString;
int nPID = 0;
#ifdef WNT
nPID = GetCurrentProcessId();
#else
nPID = getpid();
#endif
return ( ::rtl::OUString::valueOf( ( long )nPID ) );
}
/** Insert Current PID to the URL to avoid access violation between multiuser execution.
*/
inline void insertPID( ::rtl::OUString & pathname )
{
//~ check if the path contain the temp directory, do nothing changes if not;
if ( pathname.indexOf( aTempDirectoryURL ) && pathname.indexOf( aTempDirectorySys ) )
return;
//~ format pathname to TEMP/USERPID/URL style;
if ( !pathname.indexOf( aTempDirectoryURL ) )
{
::rtl::OUString strPID( getCurrentPID( ) );
::rtl::OUString pathLeft = aTempDirectoryURL.copy( 0 );
::rtl::OUString pathRight = pathname.copy( aTempDirectoryURL.getLength( ) );
pathname = pathLeft.copy( 0 );
( ( pathname += aSlashURL ) += strPID ) += pathRight;
}
else
{
::rtl::OUString strPID( getCurrentPID( ) );
::rtl::OUString pathLeft = aTempDirectorySys.copy( 0 );
::rtl::OUString pathRight = pathname.copy( aTempDirectorySys.getLength( ) );
pathname = pathLeft.copy( 0 );
( ( pathname += aSlashURL ) += strPID ) += pathRight;
}
}
int main(int argc, char **argv)
{
printf( "Initializing..." );
//~ make sure the c:\temp exist, if not, create it.
#if ( defined WNT )
if ( checkDirectory( aTempDirectoryURL, osl_Check_Mode_Exist ) != sal_True ) {
printf( "\n#C:\\temp is not exist, now creating\n" );
createTestDirectory( aTempDirectoryURL );
};
#endif
//~ make sure the c:\temp\PID or /tmp/PID exist, if not, create it. initialize the user directory.
( aUserDirectoryURL += aSlashURL ) += getCurrentPID( );
( aUserDirectorySys += aSlashURL ) += getCurrentPID( );
if ( checkDirectory( aUserDirectoryURL, osl_Check_Mode_Exist ) != sal_True ) {
createTestDirectory( aUserDirectoryURL );
}
//~ adapt all URL to the TEMP/USERPID/URL format;
insertPID( aCanURL1 );
insertPID( aTmpName3 );
insertPID( aTmpName4 );
insertPID( aTmpName5 );
insertPID( aTmpName6 );
insertPID( aTmpName8 );
insertPID( aTmpName9 );
insertPID( aLnkURL1 );
insertPID( aFifoSys );
insertPID( aSysPath1 );
insertPID( aSysPath2 );
insertPID( aSysPath3 );
insertPID( aSysPath4 );
printf( "Done.\n" );
::testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}
//~ do some clean up work after all test completed.
class GlobalObject
{
public:
~GlobalObject()
{
try
{
//~ make sure the c:\temp\PID or /tmp/PID exist, if yes, delete it.
printf( "\n#Do some clean-ups ...\n" );
if ( checkDirectory( aUserDirectoryURL, osl_Check_Mode_Exist ) == sal_True ) {
deleteTestDirectory( aUserDirectoryURL );
}
// LLA: printf("after deleteTestDirectory\n");
//~ special clean up task in Windows and Unix separately;
#if ( defined UNX ) || ( defined OS2 )
//~ some clean up task for UNIX OS
;
#else
//~ some clean up task for Windows OS
//~ check if some files are in the way, remove them if necessary.
if ( ifFileExist( aTmpName6 ) == sal_True )
deleteTestFile( aTmpName6 );
if ( ifFileExist( aTmpName4 ) == sal_True )
deleteTestFile( aTmpName4 );
if ( checkDirectory( aTmpName4, osl_Check_Mode_Exist ) == sal_True )
deleteTestDirectory( aTmpName4 );
if ( ifFileExist( aTmpName3 ) == sal_True )
deleteTestFile( aTmpName3 );
if ( checkDirectory( aTmpName3, osl_Check_Mode_Exist ) == sal_True )
deleteTestDirectory( aTmpName3 );
::rtl::OUString aUStr( aUserDirectoryURL );
concatURL( aUStr, aHidURL1 );
if ( ifFileExist( aUStr ) == sal_True )
deleteTestFile( aUStr );
::rtl::OUString aUStr1( aRootURL );
concatURL( aUStr1, aTmpName2 );
if ( ifFileExist( aUStr1 ) == sal_True )
deleteTestFile( aUStr1 );
#endif
}
catch (...)
{
printf("Exception caught (...) in GlobalObject dtor()\n");
}
}
};
GlobalObject theGlobalObject;