1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_sal.hxx" 30*cdf0e10cSrcweir 31*cdf0e10cSrcweir //------------------------------------------------------------------------ 32*cdf0e10cSrcweir // include files 33*cdf0e10cSrcweir //------------------------------------------------------------------------ 34*cdf0e10cSrcweir #include <osl_Module_Const.h> 35*cdf0e10cSrcweir 36*cdf0e10cSrcweir using namespace osl; 37*cdf0e10cSrcweir using namespace rtl; 38*cdf0e10cSrcweir 39*cdf0e10cSrcweir 40*cdf0e10cSrcweir //------------------------------------------------------------------------ 41*cdf0e10cSrcweir // helper functions and classes 42*cdf0e10cSrcweir //------------------------------------------------------------------------ 43*cdf0e10cSrcweir 44*cdf0e10cSrcweir /** print Boolean value. 45*cdf0e10cSrcweir */ 46*cdf0e10cSrcweir inline void printBool( sal_Bool bOk ) 47*cdf0e10cSrcweir { 48*cdf0e10cSrcweir t_print("#printBool# " ); 49*cdf0e10cSrcweir ( sal_True == bOk ) ? t_print("TRUE!\n" ): t_print("FALSE!\n" ); 50*cdf0e10cSrcweir } 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir /** print a UNI_CODE String. 53*cdf0e10cSrcweir */ 54*cdf0e10cSrcweir inline void printUString( const ::rtl::OUString & str ) 55*cdf0e10cSrcweir { 56*cdf0e10cSrcweir rtl::OString aString; 57*cdf0e10cSrcweir 58*cdf0e10cSrcweir t_print("#printUString_u# " ); 59*cdf0e10cSrcweir aString = ::rtl::OUStringToOString( str, RTL_TEXTENCODING_ASCII_US ); 60*cdf0e10cSrcweir t_print("%s\n", aString.getStr( ) ); 61*cdf0e10cSrcweir } 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir /** get dll file URL. 64*cdf0e10cSrcweir */ 65*cdf0e10cSrcweir inline ::rtl::OUString getDllURL( void ) 66*cdf0e10cSrcweir { 67*cdf0e10cSrcweir #if ( defined WNT ) // lib in Unix and lib in Windows are not same in file name. 68*cdf0e10cSrcweir ::rtl::OUString libPath( rtl::OUString::createFromAscii( "Module_DLL.dll" ) ); 69*cdf0e10cSrcweir #else 70*cdf0e10cSrcweir ::rtl::OUString libPath( rtl::OUString::createFromAscii( "libModule_DLL.so" ) ); 71*cdf0e10cSrcweir #endif 72*cdf0e10cSrcweir 73*cdf0e10cSrcweir ::rtl::OUString dirPath, dllPath; 74*cdf0e10cSrcweir osl::Module::getUrlFromAddress( ( void* ) &getDllURL, dirPath ); 75*cdf0e10cSrcweir dirPath = dirPath.copy( 0, dirPath.lastIndexOf('/') + 1); 76*cdf0e10cSrcweir osl::FileBase::getAbsoluteFileURL( dirPath, libPath, dllPath ); 77*cdf0e10cSrcweir 78*cdf0e10cSrcweir return dllPath; 79*cdf0e10cSrcweir } 80*cdf0e10cSrcweir 81*cdf0e10cSrcweir /** print a UNI_CODE file name. 82*cdf0e10cSrcweir */ 83*cdf0e10cSrcweir inline void printFileName( const ::rtl::OUString & str ) 84*cdf0e10cSrcweir { 85*cdf0e10cSrcweir rtl::OString aString; 86*cdf0e10cSrcweir 87*cdf0e10cSrcweir t_print("#printFileName_u# " ); 88*cdf0e10cSrcweir aString = ::rtl::OUStringToOString( str, RTL_TEXTENCODING_ASCII_US ); 89*cdf0e10cSrcweir t_print("%s\n", aString.getStr( ) ); 90*cdf0e10cSrcweir } 91*cdf0e10cSrcweir 92*cdf0e10cSrcweir inline sal_Bool isURL( const ::rtl::OUString pathname ) 93*cdf0e10cSrcweir { 94*cdf0e10cSrcweir ::rtl::OUString aPreURL( rtl::OUString::createFromAscii( "file:///" ) ); 95*cdf0e10cSrcweir return ( ( pathname.indexOf( aPreURL ) == 0 ) ? sal_True : sal_False ); 96*cdf0e10cSrcweir } 97*cdf0e10cSrcweir 98*cdf0e10cSrcweir /** create a temp test directory using OUString name of full qualified URL or system path. 99*cdf0e10cSrcweir */ 100*cdf0e10cSrcweir inline void createTestDirectory( const ::rtl::OUString dirname ) 101*cdf0e10cSrcweir { 102*cdf0e10cSrcweir ::rtl::OUString aPathURL = dirname.copy( 0 ); 103*cdf0e10cSrcweir ::osl::FileBase::RC nError; 104*cdf0e10cSrcweir 105*cdf0e10cSrcweir if ( !isURL( dirname ) ) 106*cdf0e10cSrcweir ::osl::FileBase::getFileURLFromSystemPath( dirname, aPathURL ); //convert if not full qualified URL 107*cdf0e10cSrcweir nError = ::osl::Directory::create( aPathURL ); 108*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "In createTestDirectory Function: creation: ", ( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_EXIST ) ); 109*cdf0e10cSrcweir } 110*cdf0e10cSrcweir 111*cdf0e10cSrcweir /** delete a temp test directory using OUString name of full qualified URL or system path. 112*cdf0e10cSrcweir */ 113*cdf0e10cSrcweir inline void deleteTestDirectory( const ::rtl::OUString dirname ) 114*cdf0e10cSrcweir { 115*cdf0e10cSrcweir ::rtl::OUString aPathURL = dirname.copy( 0 ); 116*cdf0e10cSrcweir ::osl::FileBase::RC nError; 117*cdf0e10cSrcweir if ( !isURL( dirname ) ) 118*cdf0e10cSrcweir ::osl::FileBase::getFileURLFromSystemPath( dirname, aPathURL ); //convert if not full qualified URL 119*cdf0e10cSrcweir 120*cdf0e10cSrcweir ::osl::Directory testDir( aPathURL ); 121*cdf0e10cSrcweir if ( testDir.isOpen( ) == sal_True ) 122*cdf0e10cSrcweir { 123*cdf0e10cSrcweir testDir.close( ); //close if still open. 124*cdf0e10cSrcweir } 125*cdf0e10cSrcweir 126*cdf0e10cSrcweir nError = ::osl::Directory::remove( aPathURL ); 127*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "In deleteTestDirectory function: remove ", ( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_NOENT ) ); 128*cdf0e10cSrcweir } 129*cdf0e10cSrcweir 130*cdf0e10cSrcweir //check if the file exist 131*cdf0e10cSrcweir inline sal_Bool ifFileExist( const ::rtl::OUString & str ) 132*cdf0e10cSrcweir { 133*cdf0e10cSrcweir ::rtl::OUString aUStr; 134*cdf0e10cSrcweir if ( isURL( str ) ) 135*cdf0e10cSrcweir ::osl::FileBase::getSystemPathFromFileURL( str, aUStr ); 136*cdf0e10cSrcweir else 137*cdf0e10cSrcweir return sal_False; 138*cdf0e10cSrcweir 139*cdf0e10cSrcweir ::osl::File strFile( aUStr ); 140*cdf0e10cSrcweir ::osl::FileBase::RC nError = strFile.open( OpenFlag_Read ); 141*cdf0e10cSrcweir if ( ::File::E_NOENT == nError ) 142*cdf0e10cSrcweir return sal_False; 143*cdf0e10cSrcweir else{ 144*cdf0e10cSrcweir strFile.close( ); 145*cdf0e10cSrcweir return sal_True; 146*cdf0e10cSrcweir } 147*cdf0e10cSrcweir } 148*cdf0e10cSrcweir 149*cdf0e10cSrcweir /** detete a temp test file using OUString name. 150*cdf0e10cSrcweir */ 151*cdf0e10cSrcweir inline void deleteTestFile( const ::rtl::OUString filename ) 152*cdf0e10cSrcweir { 153*cdf0e10cSrcweir ::rtl::OUString aPathURL = filename.copy( 0 ); 154*cdf0e10cSrcweir ::osl::FileBase::RC nError; 155*cdf0e10cSrcweir 156*cdf0e10cSrcweir if ( !isURL( filename ) ) 157*cdf0e10cSrcweir ::osl::FileBase::getFileURLFromSystemPath( filename, aPathURL ); //convert if not full qualified URL 158*cdf0e10cSrcweir 159*cdf0e10cSrcweir nError = ::osl::File::setAttributes( aPathURL, Attribute_GrpWrite| Attribute_OwnWrite| Attribute_OthWrite ); // if readonly, make writtenable. 160*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "In deleteTestFile Function: set writtenable ", ( ::osl::FileBase::E_None == nError ) || ( ::osl::FileBase::E_NOENT == nError ) ); 161*cdf0e10cSrcweir 162*cdf0e10cSrcweir nError = ::osl::File::remove( aPathURL ); 163*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "In deleteTestFile Function: remove ", ( ::osl::FileBase::E_None == nError ) || ( nError == ::osl::FileBase::E_NOENT ) ); 164*cdf0e10cSrcweir } 165*cdf0e10cSrcweir 166*cdf0e10cSrcweir 167*cdf0e10cSrcweir //------------------------------------------------------------------------ 168*cdf0e10cSrcweir // test code start here 169*cdf0e10cSrcweir //------------------------------------------------------------------------ 170*cdf0e10cSrcweir 171*cdf0e10cSrcweir namespace osl_Module 172*cdf0e10cSrcweir { 173*cdf0e10cSrcweir 174*cdf0e10cSrcweir /** class and member function that is available for module test : 175*cdf0e10cSrcweir */ 176*cdf0e10cSrcweir 177*cdf0e10cSrcweir class testClass 178*cdf0e10cSrcweir { 179*cdf0e10cSrcweir public: 180*cdf0e10cSrcweir static void myFunc() 181*cdf0e10cSrcweir { 182*cdf0e10cSrcweir t_print("#Sun Microsystem\n"); 183*cdf0e10cSrcweir }; 184*cdf0e10cSrcweir }; 185*cdf0e10cSrcweir 186*cdf0e10cSrcweir 187*cdf0e10cSrcweir /** testing the methods: 188*cdf0e10cSrcweir Module(); 189*cdf0e10cSrcweir Module( const ::rtl::OUString& strModuleName, sal_Int32 nRtldMode = SAL_LOADMODULE_DEFAULT); 190*cdf0e10cSrcweir */ 191*cdf0e10cSrcweir class ctors : public CppUnit::TestFixture 192*cdf0e10cSrcweir { 193*cdf0e10cSrcweir public: 194*cdf0e10cSrcweir sal_Bool bRes, bRes1; 195*cdf0e10cSrcweir 196*cdf0e10cSrcweir void ctors_none( ) 197*cdf0e10cSrcweir { 198*cdf0e10cSrcweir ::osl::Module aMod; 199*cdf0e10cSrcweir bRes = aMod.is(); 200*cdf0e10cSrcweir 201*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: test constructor without parameter.", 202*cdf0e10cSrcweir sal_False == bRes ); 203*cdf0e10cSrcweir } 204*cdf0e10cSrcweir 205*cdf0e10cSrcweir void ctors_name_mode( ) 206*cdf0e10cSrcweir { 207*cdf0e10cSrcweir OUString aFileURL; 208*cdf0e10cSrcweir bRes = osl::Module::getUrlFromAddress( ( void* ) &::osl_Module::testClass::myFunc, aFileURL ); 209*cdf0e10cSrcweir 210*cdf0e10cSrcweir if ( !( bRes ) ) 211*cdf0e10cSrcweir { 212*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE("Cannot locate current module.", sal_False ); 213*cdf0e10cSrcweir } 214*cdf0e10cSrcweir 215*cdf0e10cSrcweir ::osl::Module aMod( aFileURL ); 216*cdf0e10cSrcweir bRes = aMod.is( ); 217*cdf0e10cSrcweir aMod.unload( ); 218*cdf0e10cSrcweir 219*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: test constructor with load action.", 220*cdf0e10cSrcweir sal_True == bRes ); 221*cdf0e10cSrcweir } 222*cdf0e10cSrcweir 223*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( ctors ); 224*cdf0e10cSrcweir CPPUNIT_TEST( ctors_none ); 225*cdf0e10cSrcweir CPPUNIT_TEST( ctors_name_mode ); 226*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 227*cdf0e10cSrcweir }; // class ctors 228*cdf0e10cSrcweir 229*cdf0e10cSrcweir 230*cdf0e10cSrcweir /** testing the methods: 231*cdf0e10cSrcweir static sal_Bool getUrlFromAddress(void * addr, ::rtl::OUString & libraryUrl) 232*cdf0e10cSrcweir */ 233*cdf0e10cSrcweir class getUrlFromAddress : public CppUnit::TestFixture 234*cdf0e10cSrcweir { 235*cdf0e10cSrcweir public: 236*cdf0e10cSrcweir sal_Bool bRes, bRes1; 237*cdf0e10cSrcweir 238*cdf0e10cSrcweir void getUrlFromAddress_001( ) 239*cdf0e10cSrcweir { 240*cdf0e10cSrcweir OUString aFileURL; 241*cdf0e10cSrcweir bRes = osl::Module::getUrlFromAddress( ( void* ) &::osl_Module::testClass::myFunc, aFileURL ) ; 242*cdf0e10cSrcweir if ( !( bRes ) ) 243*cdf0e10cSrcweir { 244*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE("Cannot locate current module.", sal_False ); 245*cdf0e10cSrcweir } 246*cdf0e10cSrcweir 247*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: test get Module URL from address.", 248*cdf0e10cSrcweir sal_True == bRes && 0 < aFileURL.lastIndexOf('/') ); 249*cdf0e10cSrcweir } 250*cdf0e10cSrcweir 251*cdf0e10cSrcweir void getUrlFromAddress_002( ) 252*cdf0e10cSrcweir { 253*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 254*cdf0e10cSrcweir FuncPtr pFunc = ( FuncPtr ) aMod.getSymbol( rtl::OUString::createFromAscii( "firstfunc" ) ); 255*cdf0e10cSrcweir 256*cdf0e10cSrcweir OUString aFileURL; 257*cdf0e10cSrcweir bRes = osl::Module::getUrlFromAddress( ( void* )pFunc, aFileURL ); 258*cdf0e10cSrcweir if ( !( bRes ) ) 259*cdf0e10cSrcweir { 260*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE("Cannot locate current module.", sal_False ); 261*cdf0e10cSrcweir } 262*cdf0e10cSrcweir aMod.unload( ); 263*cdf0e10cSrcweir 264*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: load an external library, get its function address and get its URL.", 265*cdf0e10cSrcweir sal_True == bRes && 0 < aFileURL.lastIndexOf('/') && aFileURL.equalsIgnoreAsciiCase( getDllURL( ) ) ); 266*cdf0e10cSrcweir } 267*cdf0e10cSrcweir 268*cdf0e10cSrcweir /* tester comments: another case is getFunctionSymbol_001*/ 269*cdf0e10cSrcweir 270*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( getUrlFromAddress ); 271*cdf0e10cSrcweir CPPUNIT_TEST( getUrlFromAddress_001 ); 272*cdf0e10cSrcweir CPPUNIT_TEST( getUrlFromAddress_002 ); 273*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 274*cdf0e10cSrcweir }; // class getUrlFromAddress 275*cdf0e10cSrcweir 276*cdf0e10cSrcweir 277*cdf0e10cSrcweir /** testing the method: 278*cdf0e10cSrcweir sal_Bool SAL_CALL load( const ::rtl::OUString& strModuleName, 279*cdf0e10cSrcweir sal_Int32 nRtldMode = SAL_LOADMODULE_DEFAULT) 280*cdf0e10cSrcweir */ 281*cdf0e10cSrcweir class load : public CppUnit::TestFixture 282*cdf0e10cSrcweir { 283*cdf0e10cSrcweir public: 284*cdf0e10cSrcweir sal_Bool bRes, bRes1; 285*cdf0e10cSrcweir 286*cdf0e10cSrcweir void load_001( ) 287*cdf0e10cSrcweir { 288*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 289*cdf0e10cSrcweir ::osl::Module aMod1; 290*cdf0e10cSrcweir 291*cdf0e10cSrcweir aMod1.load( getDllURL( ) ); 292*cdf0e10cSrcweir bRes = oslModule(aMod) == oslModule(aMod1); 293*cdf0e10cSrcweir aMod.unload( ); 294*cdf0e10cSrcweir aMod1.unload( ); 295*cdf0e10cSrcweir 296*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: load function should do the same thing as constructor with library name.", 297*cdf0e10cSrcweir sal_True == bRes ); 298*cdf0e10cSrcweir } 299*cdf0e10cSrcweir // load lib which is under a CJK directory 300*cdf0e10cSrcweir void load_002( ) 301*cdf0e10cSrcweir { 302*cdf0e10cSrcweir #ifdef UNX 303*cdf0e10cSrcweir //Can not get a CJK directory already exist, so here create one. Perhaps reason is encoding problem. 304*cdf0e10cSrcweir ::rtl::OUString aPidDirURL = rtl::OUString::createFromAscii( "file:///tmp/" ) + ::rtl::OUString::valueOf( ( long )getpid( ) ); 305*cdf0e10cSrcweir ::rtl::OUString aMyDirURL = aPidDirURL + aKname; 306*cdf0e10cSrcweir createTestDirectory( aPidDirURL ); 307*cdf0e10cSrcweir createTestDirectory( aMyDirURL ); 308*cdf0e10cSrcweir 309*cdf0e10cSrcweir ::rtl::OUString aDLLURL = aMyDirURL + rtl::OUString::createFromAscii( "/libModule_DLL.so" ); 310*cdf0e10cSrcweir //check if the lib exist. 311*cdf0e10cSrcweir //FIXME: if assert condition is false, the case will return, so the directory will not be clean-up 312*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#Source file is not exist. please manually clean-up directory and file under /tmp", ifFileExist( getDllURL( ) ) == sal_True ); 313*cdf0e10cSrcweir ::osl::FileBase::RC nError = ::osl::File::copy( getDllURL( ), aDLLURL ); 314*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#copy failed. please manually clean-up directory and file under /tmp", nError == ::osl::FileBase::E_None ); 315*cdf0e10cSrcweir //ifFileExist returned false but the file exist 316*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#This file is not exist, copy failed. please manually clean-up directory and file under /tmp", ifFileExist( aDLLURL ) == sal_True ); 317*cdf0e10cSrcweir 318*cdf0e10cSrcweir //test if can create a normal file 319*cdf0e10cSrcweir ::rtl::OUString aFileURL = aMyDirURL + rtl::OUString::createFromAscii( "/test_file" ); 320*cdf0e10cSrcweir ::osl::File testFile( aFileURL ); 321*cdf0e10cSrcweir nError = testFile.open( OpenFlag_Create ); 322*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#create failed. please manually clean-up directory and file under /tmp", nError == ::osl::FileBase::E_None ); 323*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#This file is not exist, create failed. please manually clean-up directory and file under /tmp", ifFileExist( aFileURL ) == sal_True ); 324*cdf0e10cSrcweir 325*cdf0e10cSrcweir //load the copied dll 326*cdf0e10cSrcweir ::osl::Module aMod( aDLLURL ); 327*cdf0e10cSrcweir ::osl::Module aMod1; 328*cdf0e10cSrcweir 329*cdf0e10cSrcweir sal_Bool bOK = aMod1.load( aDLLURL ); 330*cdf0e10cSrcweir bRes = oslModule(aMod) == oslModule(aMod1); 331*cdf0e10cSrcweir aMod.unload( ); 332*cdf0e10cSrcweir aMod1.unload( ); 333*cdf0e10cSrcweir deleteTestFile( aFileURL ); 334*cdf0e10cSrcweir deleteTestFile( aDLLURL ); 335*cdf0e10cSrcweir deleteTestDirectory( aMyDirURL ); 336*cdf0e10cSrcweir deleteTestDirectory( aPidDirURL ); 337*cdf0e10cSrcweir 338*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: load lib which is under a CJK directory.", 339*cdf0e10cSrcweir sal_True == bRes && bOK == sal_True ); 340*cdf0e10cSrcweir #endif 341*cdf0e10cSrcweir } 342*cdf0e10cSrcweir 343*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( load ); 344*cdf0e10cSrcweir CPPUNIT_TEST( load_001 ); 345*cdf0e10cSrcweir CPPUNIT_TEST( load_002 ); 346*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 347*cdf0e10cSrcweir }; // class load 348*cdf0e10cSrcweir 349*cdf0e10cSrcweir 350*cdf0e10cSrcweir /** testing the method: 351*cdf0e10cSrcweir void SAL_CALL unload() 352*cdf0e10cSrcweir */ 353*cdf0e10cSrcweir class unload : public CppUnit::TestFixture 354*cdf0e10cSrcweir { 355*cdf0e10cSrcweir public: 356*cdf0e10cSrcweir sal_Bool bRes, bRes1; 357*cdf0e10cSrcweir 358*cdf0e10cSrcweir void unload_001( ) 359*cdf0e10cSrcweir { 360*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 361*cdf0e10cSrcweir 362*cdf0e10cSrcweir aMod.unload( ); 363*cdf0e10cSrcweir bRes = oslModule(aMod) ==NULL; 364*cdf0e10cSrcweir 365*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: unload function should do the same thing as destructor.", 366*cdf0e10cSrcweir sal_True == bRes ); 367*cdf0e10cSrcweir } 368*cdf0e10cSrcweir 369*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( unload ); 370*cdf0e10cSrcweir CPPUNIT_TEST( unload_001 ); 371*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 372*cdf0e10cSrcweir }; // class unload 373*cdf0e10cSrcweir 374*cdf0e10cSrcweir 375*cdf0e10cSrcweir /** testing the methods: 376*cdf0e10cSrcweir sal_Bool SAL_CALL is() const 377*cdf0e10cSrcweir */ 378*cdf0e10cSrcweir class is : public CppUnit::TestFixture 379*cdf0e10cSrcweir { 380*cdf0e10cSrcweir public: 381*cdf0e10cSrcweir sal_Bool bRes, bRes1; 382*cdf0e10cSrcweir 383*cdf0e10cSrcweir void is_001( ) 384*cdf0e10cSrcweir { 385*cdf0e10cSrcweir OUString aFileURL; 386*cdf0e10cSrcweir bRes = osl::Module::getUrlFromAddress( ( void* ) &::osl_Module::testClass::myFunc, aFileURL ); 387*cdf0e10cSrcweir if ( !( bRes ) ) 388*cdf0e10cSrcweir { 389*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE("Cannot locate current module - using executable instead", sal_False ); 390*cdf0e10cSrcweir } 391*cdf0e10cSrcweir 392*cdf0e10cSrcweir ::osl::Module aMod; 393*cdf0e10cSrcweir bRes = aMod.is( ); 394*cdf0e10cSrcweir aMod.load( aFileURL ); 395*cdf0e10cSrcweir bRes1 = aMod.is( ); 396*cdf0e10cSrcweir aMod.unload( ); 397*cdf0e10cSrcweir 398*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: test if a module is a loaded module.", 399*cdf0e10cSrcweir sal_False == bRes && sal_True == bRes1); 400*cdf0e10cSrcweir } 401*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( is ); 402*cdf0e10cSrcweir CPPUNIT_TEST( is_001 ); 403*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 404*cdf0e10cSrcweir }; // class is 405*cdf0e10cSrcweir 406*cdf0e10cSrcweir 407*cdf0e10cSrcweir /** testing the methods: 408*cdf0e10cSrcweir void* SAL_CALL getSymbol( const ::rtl::OUString& strSymbolName) 409*cdf0e10cSrcweir */ 410*cdf0e10cSrcweir class getSymbol : public CppUnit::TestFixture 411*cdf0e10cSrcweir { 412*cdf0e10cSrcweir public: 413*cdf0e10cSrcweir sal_Bool bRes; 414*cdf0e10cSrcweir 415*cdf0e10cSrcweir void getSymbol_001( ) 416*cdf0e10cSrcweir { 417*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 418*cdf0e10cSrcweir FuncPtr pFunc = ( FuncPtr ) aMod.getSymbol( rtl::OUString::createFromAscii( "firstfunc" ) ); 419*cdf0e10cSrcweir bRes = sal_False; 420*cdf0e10cSrcweir if ( pFunc ) 421*cdf0e10cSrcweir bRes = pFunc( bRes ); 422*cdf0e10cSrcweir aMod.unload(); 423*cdf0e10cSrcweir 424*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: load a dll and call one function in it.", 425*cdf0e10cSrcweir sal_True == bRes ); 426*cdf0e10cSrcweir } 427*cdf0e10cSrcweir 428*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( getSymbol ); 429*cdf0e10cSrcweir CPPUNIT_TEST( getSymbol_001 ); 430*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 431*cdf0e10cSrcweir }; // class getSymbol 432*cdf0e10cSrcweir 433*cdf0e10cSrcweir 434*cdf0e10cSrcweir /** testing the methods: 435*cdf0e10cSrcweir operator oslModule() const 436*cdf0e10cSrcweir */ 437*cdf0e10cSrcweir class optr_oslModule : public CppUnit::TestFixture 438*cdf0e10cSrcweir { 439*cdf0e10cSrcweir public: 440*cdf0e10cSrcweir sal_Bool bRes, bRes1; 441*cdf0e10cSrcweir 442*cdf0e10cSrcweir void optr_oslModule_001( ) 443*cdf0e10cSrcweir { 444*cdf0e10cSrcweir ::osl::Module aMod; 445*cdf0e10cSrcweir bRes = ( (oslModule)aMod == NULL ); 446*cdf0e10cSrcweir 447*cdf0e10cSrcweir aMod.load( getDllURL( ) ); 448*cdf0e10cSrcweir bRes1 = (oslModule)aMod != NULL; 449*cdf0e10cSrcweir 450*cdf0e10cSrcweir aMod.unload( ); 451*cdf0e10cSrcweir 452*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: the m_Module of a Module instance will be NULL when is not loaded, it will not be NULL after loaded.", 453*cdf0e10cSrcweir sal_True == bRes && sal_True == bRes1); 454*cdf0e10cSrcweir } 455*cdf0e10cSrcweir 456*cdf0e10cSrcweir void optr_oslModule_002( ) 457*cdf0e10cSrcweir { 458*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 459*cdf0e10cSrcweir ::rtl::OUString funcName(::rtl::OUString::createFromAscii( "firstfunc" ) ); 460*cdf0e10cSrcweir 461*cdf0e10cSrcweir FuncPtr pFunc = ( FuncPtr ) osl_getSymbol( (oslModule)aMod, funcName.pData ); 462*cdf0e10cSrcweir bRes = sal_False; 463*cdf0e10cSrcweir if ( pFunc ) 464*cdf0e10cSrcweir bRes = pFunc( bRes ); 465*cdf0e10cSrcweir 466*cdf0e10cSrcweir aMod.unload(); 467*cdf0e10cSrcweir 468*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: use m_Module to call osl_getSymbol() function.", 469*cdf0e10cSrcweir sal_True == bRes ); 470*cdf0e10cSrcweir } 471*cdf0e10cSrcweir 472*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( optr_oslModule ); 473*cdf0e10cSrcweir CPPUNIT_TEST( optr_oslModule_001 ); 474*cdf0e10cSrcweir CPPUNIT_TEST( optr_oslModule_002 ); 475*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 476*cdf0e10cSrcweir }; // class optr_oslModule 477*cdf0e10cSrcweir 478*cdf0e10cSrcweir /** testing the methods: 479*cdf0e10cSrcweir oslGenericFunction SAL_CALL getFunctionSymbol( const ::rtl::OUString& ustrFunctionSymbolName ) 480*cdf0e10cSrcweir */ 481*cdf0e10cSrcweir class getFunctionSymbol : public CppUnit::TestFixture 482*cdf0e10cSrcweir { 483*cdf0e10cSrcweir public: 484*cdf0e10cSrcweir sal_Bool bRes, bRes1; 485*cdf0e10cSrcweir 486*cdf0e10cSrcweir void getFunctionSymbol_001( ) 487*cdf0e10cSrcweir { 488*cdf0e10cSrcweir ::osl::Module aMod( getDllURL( ) ); 489*cdf0e10cSrcweir oslGenericFunction oslFunc = aMod.getFunctionSymbol( rtl::OUString::createFromAscii( "firstfunc" ) ); 490*cdf0e10cSrcweir ::rtl::OUString aLibraryURL; 491*cdf0e10cSrcweir bRes = ::osl::Module::getUrlFromAddress( oslFunc, aLibraryURL); 492*cdf0e10cSrcweir aMod.unload(); 493*cdf0e10cSrcweir printFileName( aLibraryURL ); 494*cdf0e10cSrcweir 495*cdf0e10cSrcweir CPPUNIT_ASSERT_MESSAGE( "#test comment#: load a dll and get its function addr and get its URL.", 496*cdf0e10cSrcweir sal_True == bRes && aLibraryURL.equalsIgnoreAsciiCase( getDllURL() ) ); 497*cdf0e10cSrcweir } 498*cdf0e10cSrcweir 499*cdf0e10cSrcweir CPPUNIT_TEST_SUITE( getFunctionSymbol ); 500*cdf0e10cSrcweir CPPUNIT_TEST( getFunctionSymbol_001 ); 501*cdf0e10cSrcweir //CPPUNIT_TEST( getFunctionSymbol_002 ); 502*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_END( ); 503*cdf0e10cSrcweir }; // class getFunctionSymbol 504*cdf0e10cSrcweir 505*cdf0e10cSrcweir // ----------------------------------------------------------------------------- 506*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::ctors, "osl_Module"); 507*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::getUrlFromAddress, "osl_Module"); 508*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::load, "osl_Module"); 509*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::unload, "osl_Module"); 510*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::is, "osl_Module"); 511*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::getSymbol, "osl_Module"); 512*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::optr_oslModule, "osl_Module"); 513*cdf0e10cSrcweir CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(osl_Module::getFunctionSymbol, "osl_Module"); 514*cdf0e10cSrcweir // ----------------------------------------------------------------------------- 515*cdf0e10cSrcweir 516*cdf0e10cSrcweir } // namespace osl_Module 517*cdf0e10cSrcweir 518*cdf0e10cSrcweir // ----------------------------------------------------------------------------- 519*cdf0e10cSrcweir 520*cdf0e10cSrcweir // this macro creates an empty function, which will called by the RegisterAllFunctions() 521*cdf0e10cSrcweir // to let the user the possibility to also register some functions by hand. 522*cdf0e10cSrcweir NOADDITIONAL; 523