/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: rtl_Bootstrap.cxx,v $ * $Revision: 1.10.20.2 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sal.hxx" // Documentation about bootstraping can be found at: // http://udk.openoffice.org/common/man/concept/micro_deployment.html #include #include #include #include // STL #include "testshl/stringhelper.hxx" #include //#include "stringhelper.hxx" //#include "valueequal.hxx" #include #include #include #include #include #include #include /* osl_getExecutableFile() */ #include // using namespace osl; using namespace rtl; #define TESTSHL2_INI "testshl2" #define PSEUDO_INI "pseudo" /** print a UNI_CODE String. And also print some comments of the string. */ inline void printUString( const ::rtl::OUString & str, const sal_Char * msg = "" ) { if (strlen(msg) > 0) { t_print("%s: ", msg ); } rtl::OString aString; aString = ::rtl::OUStringToOString( str, RTL_TEXTENCODING_ASCII_US ); t_print("%s\n", (char *)aString.getStr( ) ); } /** if the file exist */ bool t_fileExist(rtl::OUString const& _sFilename) { ::osl::FileBase::RC nError1; ::osl::File aTestFile( _sFilename ); nError1 = aTestFile.open ( OpenFlag_Read ); if ( ( ::osl::FileBase::E_NOENT != nError1 ) && ( ::osl::FileBase::E_ACCES != nError1 ) ) { aTestFile.close( ); return true; } return false; } /** get the exectutable path ( here is bootstrap_process), on Linux, such as "sal/unxlngi4.pro/bin/" */ inline ::rtl::OUString getModulePath( void ) { ::rtl::OUString suDirPath; ::osl::Module::getUrlFromAddress( ( oslGenericFunction ) &getModulePath, suDirPath ); suDirPath = suDirPath.copy( 0, suDirPath.lastIndexOf('/') ); suDirPath = suDirPath.copy( 0, suDirPath.lastIndexOf('/') + 1); suDirPath += rtl::OUString::createFromAscii("bin"); return suDirPath; } #define TESTSHL2_INI "testshl2" #define PSEUDO_INI "pseudo" static rtl::OUString getExecutableDirectory() { rtl::OUString fileName; osl_getExecutableFile(&fileName.pData); sal_Int32 nDirEnd = fileName.lastIndexOf('/'); OSL_ENSURE(nDirEnd >= 0, "Cannot locate executable directory"); rtl::OUString aDirURL = fileName.copy(0, nDirEnd); return aDirURL; } // get the URL of testshl2rc/rtlrc/pseudorc inline rtl::OUString t_getSourcePath(rtl::OString const& _sFilename) { rtl::OUString aDirURL(getExecutableDirectory()); aDirURL += OUString::createFromAscii( "/"); aDirURL += OUString::createFromAscii( _sFilename.getStr() ); #if defined(WNT) || defined(OS2) aDirURL += rtl::OUString::createFromAscii(".ini"); #else aDirURL += rtl::OUString::createFromAscii("rc"); #endif return aDirURL; // LLA: does not right work on my personal laptop, SRC_ROOT does not show where the source is :-(. /* sal_Char * pStr = getenv("SRC_ROOT"); rtl::OUString suPath; if (filename != "") { suPath = rtl::OUString::createFromAscii(pStr) + rtl::OUString::createFromAscii( "/sal/qa/rtl/bootstrap/" ) + rtl::OUString::createFromAscii( filename ); } else { suPath = rtl::OUString::createFromAscii(pStr) + rtl::OUString::createFromAscii( "/sal/qa/rtl/bootstrap" ); } rtl::OUString suURL; ::osl::FileBase::getFileURLFromSystemPath( suPath, suURL ); return suURL; */ } void thread_sleep_tenth_sec(sal_Int32 _nTenthSec) { #ifdef WNT //Windows Sleep(_nTenthSec * 100 ); #endif #if ( defined UNX ) || ( defined OS2 ) //Unix TimeValue nTV; nTV.Seconds = static_cast( _nTenthSec/10 ); nTV.Nanosec = ( (_nTenthSec%10 ) * 100000000 ); osl_waitThread(&nTV); #endif } // ----------------------------------------------------------------------------- namespace rtl_Bootstrap { class ctor : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } // ctor with ini name void ctor_001() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); printUString( suIniname ); Bootstrap aBootstrap( suIniname ); rtl::OUString suGetname; // = rtl::OUString::createFromAscii(""); aBootstrap.getIniName( suGetname ); printUString( suGetname ); // LLA: first: this seems to be a wrong test. // second: there seems to be a design hole, if I give a absolute path ini file, // but try to use ${file::KEYVALUE} than 'file' will only used out of the 'executable path'/file // not from the path given from the absolute path. // Due to the fact, we create at this position a file (createTestshl2rc() ), we check for existance bool bFileExist = t_fileExist( suGetname ); CPPUNIT_ASSERT_MESSAGE("ctor error with initial file.", bFileExist == true ); } void ctor_002() { rtl::Bootstrap aBootstrap; rtl::OUString suGetname; aBootstrap.getIniName( suGetname ); printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("ctor error without initial file.", suGetname.getLength() != 0 ); } CPPUNIT_TEST_SUITE(ctor); CPPUNIT_TEST(ctor_001); CPPUNIT_TEST(ctor_002); CPPUNIT_TEST_SUITE_END(); }; // class ctor class getFrom : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } // get the value of env variable void getFrom_001() { Bootstrap aBootstrap; rtl::OUString suValue; rtl::OUString suValuename = rtl::OUString::createFromAscii( "SOLAR_JAVA" ); //aBootstrap.getFrom( suValuename, suValue ); aBootstrap.getFrom( suValuename, suValue ); sal_Char * pStr = getenv("SOLAR_JAVA"); // printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("get the value of environment variable.", suValue.compareToAscii( pStr ) == 0 ); } /* Notes on Windows: void getFrom_001_1() { Bootstrap aBootstrap; rtl::OUString suValue; rtl::OUString suValuename = rtl::OUString::createFromAscii( "SRC_ROOT" ); //aBootstrap.getFrom( suValuename, suValue ); aBootstrap.getFrom( suValuename, suValue ); sal_Char * pStr = getenv("SRC_ROOT"); // printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("get the value of environment variable.", suValue.compareToAscii( pStr ) == 0 ); } The result on Windows: # # the SRC_ROOT is e:\Qadev\cvs\m19 # # suValue is e:Qadevcvsm19 reason: The problem is that the internally getenv()ed variable SRC_ROOT is macro expanded, thus every \ will introduce an escape. */ // get the value of a variable in ini file void getFrom_002() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname ); rtl::OUString suGetname; rtl::OUString suValuename = rtl::OUString::createFromAscii( "INHERITED_VALUE" ); aBootstrap.getFrom( suValuename, suGetname ); printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("get the value of a variable in ini file.", suGetname.getLength() != 0 ); } //use defaut value void getFrom_003() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname ); rtl::OUString suGetname; rtl::OUString suValuename = rtl::OUString::createFromAscii( "MY_VALUE" ); rtl::OUString myDefault = rtl::OUString::createFromAscii( "2" ); aBootstrap.getFrom( suValuename, suGetname, myDefault ); //printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("getFrom use default.", suGetname.compareTo( myDefault ) == 0 ); } void getFrom_004() { t_print("1\n"); // initialise Bootstrap with an own ini file // PSEUDO_INI is pseudo(rc|.ini) created be create_pseudorc() rtl::OUString suIniname = t_getSourcePath(PSEUDO_INI); Bootstrap aBootstrap( suIniname ); rtl::OUString suGetIniName; aBootstrap.getIniName( suGetIniName ); printUString(suGetIniName, "Current bootstrap file"); sal_Int32 nIndex = suGetIniName.indexOf(rtl::OUString::createFromAscii( "pseudo" )); CPPUNIT_ASSERT_MESSAGE("ini name must have 'pseudo' in name.", nIndex > 0); // rtlBootstrapHandle bsHandle = aBootstrap.getHandle(); // CPPUNIT_ASSERT_MESSAGE("getHandle return NULL!", bsHandle != 0); rtl::OUString suValue; rtl::OUString suKeyName = rtl::OUString::createFromAscii( "FILE" ); aBootstrap.getFrom( suKeyName, suValue ); printUString( suValue ); sal_Int32 nCompare = suValue.compareTo( rtl::OUString::createFromAscii("pseudo file") ); CPPUNIT_ASSERT_MESSAGE(".getFrom('FILE', ...) result is unexpected.", nCompare == 0); } void getFrom_004_1() { // get the same key out of the default context rtl::OUString suKeyName = rtl::OUString::createFromAscii( "FILE" ); rtl::OUString suGetValue; Bootstrap::get( suKeyName, suGetValue ); printUString( suGetValue ); CPPUNIT_ASSERT_MESSAGE("Bootstrap::get('FILE', ...)", suGetValue.compareTo( rtl::OUString::createFromAscii("testshl2 file") ) == 0 ); } /** helper function: return the child process's ret value( typedef sal_uInt32 oslProcessExitCode;) * param1 is the process's name(only file name, not include path) */ oslProcessExitCode ini_execProcess( const sal_Char* process_name, const sal_Char * flag ) { rtl::OUString suCWD = getModulePath(); oslProcess hProcess = NULL; rtl::OUString suFileURL = suCWD; suFileURL += rtl::OUString::createFromAscii("/") + rtl::OUString::createFromAscii(process_name) ; #if defined(WNT) || defined(OS2) suFileURL += rtl::OUString::createFromAscii(".exe"); #endif const int nParameterCount = 3; rtl_uString* pParameters[ nParameterCount ]; OUString suFlag( OUString::createFromAscii(flag) ); OUString suEnv1( OUString::createFromAscii("-env:UNO_SERVICES=service.rdb")); OUString suIniname = t_getSourcePath("rtl"); printUString( suIniname, "rtl path:"); //OUString suEnv2( OUString::createFromAscii("-env:MYENV=bootstrap_process")); pParameters[0] = suFlag.pData; pParameters[1] = suEnv1.pData; // the custom ini/rc file's URL pParameters[2] = suIniname.pData; oslProcessError osl_error = osl_executeProcess( suFileURL.pData, pParameters, nParameterCount, osl_Process_WAIT, 0, suCWD.pData, NULL, 0, &hProcess ); CPPUNIT_ASSERT_MESSAGE ( "osl_createProcess failed", osl_error == osl_Process_E_None ); osl_joinProcess(hProcess); oslProcessInfo* pInfo = new oslProcessInfo; pInfo->Size = sizeof( oslProcessInfo ); osl_error = osl_getProcessInfo( hProcess, osl_Process_EXITCODE, pInfo ); CPPUNIT_ASSERT_MESSAGE ( "osl_getProcessInfo returned with failure", osl_Process_E_None == osl_error ); t_print("the exit code is %d.\n", pInfo->Code ); oslProcessExitCode nCode = pInfo->Code; delete pInfo; return nCode; } void getFrom_005_1() { oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "1" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by command line can not be gotten!", nExitCode == 10 ); } void getFrom_005_2() { oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "2" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by .ini/rc file can not be gotten!", nExitCode == 20 ); } void getFrom_005_3() { #if (defined WNT) || (defined SOLARIS) putenv(const_cast< char * >("QADEV_BOOTSTRAP=sun&ms")); #else setenv("QADEV_BOOTSTRAP", "sun&ms", 0); #endif oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "3" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by environment variables can not be gotten!", nExitCode == 30 ); } void getFrom_005_4() { oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "4" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by customed .ini/rc file can not be gotten!", nExitCode == 40 ); } void getFrom_005_5() { oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "5" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by inheritance can not be gotten!", nExitCode == 50 ); } void getFrom_005_6() { oslProcessExitCode nExitCode = ini_execProcess( "bootstrap_process", "6" ); CPPUNIT_ASSERT_MESSAGE("Parameters passed by default can not be gotten!", nExitCode == 60 ); } CPPUNIT_TEST_SUITE(getFrom); CPPUNIT_TEST(getFrom_001); CPPUNIT_TEST(getFrom_002); CPPUNIT_TEST(getFrom_003); CPPUNIT_TEST(getFrom_004); CPPUNIT_TEST(getFrom_004_1); CPPUNIT_TEST(getFrom_005_1); CPPUNIT_TEST(getFrom_005_2); CPPUNIT_TEST(getFrom_005_3); CPPUNIT_TEST(getFrom_005_4); CPPUNIT_TEST(getFrom_005_5); CPPUNIT_TEST(getFrom_005_6); CPPUNIT_TEST_SUITE_END(); }; // class getFrom class setIniFilename : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } void setIniFilename_001() { Bootstrap aBootstrap; rtl::OUString suGetIniname; aBootstrap.getIniName( suGetIniname ); //which should be .....testshl2rc //printUString( suGetIniname ); rtl::OUString suIniname = t_getSourcePath(PSEUDO_INI); Bootstrap::setIniFilename( suIniname ); rtl::OUString suGetname; aBootstrap.getIniName( suGetname ); printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("setIniFilename then get it.", suGetname.compareTo( suIniname ) == 0 && suGetname.compareTo( suGetIniname ) != 0 ); } void setIniFilename_002() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); // CPPUNIT_ASSERT_MESSAGE("test failed, Bootstrap ini does not exist.", t_fileExist(suIniname ) == true); Bootstrap::setIniFilename( suIniname ); //rtl_bootstrap_args_open( suIniname.pData ); rtl::OUString suGetname; rtl::OUString suValuename = rtl::OUString::createFromAscii( "INHERITED_VALUE" ); //aBootstrap.getFrom( suValuename, suGetname ); Bootstrap::get( suValuename, suGetname ); printUString( suGetname ); CPPUNIT_ASSERT_MESSAGE("setIniFilename and get value of the argument.", suGetname.getLength() != 0 ); } CPPUNIT_TEST_SUITE(setIniFilename); CPPUNIT_TEST(setIniFilename_001); CPPUNIT_TEST(setIniFilename_002); CPPUNIT_TEST_SUITE_END(); }; // class setIniFilename class getHandle : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } void getHandle_001() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap; rtlBootstrapHandle bsHandle = aBootstrap.getHandle(); CPPUNIT_ASSERT_MESSAGE("getHandle should return 0 if the bootstrap has no ini file!", bsHandle == 0 ); } void getHandle_002() { rtl::OUString suIniname = t_getSourcePath(PSEUDO_INI); Bootstrap aBootstrap( suIniname ); rtlBootstrapHandle bsHandle = aBootstrap.getHandle(); CPPUNIT_ASSERT_MESSAGE("getHandle return NULL!", bsHandle != 0); //rtl::OUString iniName; //rtl_bootstrap_get_iniName_from_handle( bsHandle, &iniName.pData ); rtl::OUString suValue; rtl::OUString suKeyName = rtl::OUString::createFromAscii( "PSEUDOFILE" ); rtl_bootstrap_get_from_handle(bsHandle, suKeyName.pData, &suValue.pData, NULL); printUString( suValue); CPPUNIT_ASSERT_MESSAGE("Can not use the handle which is returned by getHandle!", suValue.equals( rtl::OUString::createFromAscii("be pseudo") ) == sal_True ); // CPPUNIT_ASSERT_MESSAGE("Can not use the handle which is returned by getHandle!", // suGetname.equalsIgnoreAsciiCase( iniName ) == sal_True ); } CPPUNIT_TEST_SUITE(getHandle); CPPUNIT_TEST(getHandle_001); CPPUNIT_TEST(getHandle_002); CPPUNIT_TEST_SUITE_END(); }; // class getHandle class set : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } void set_001() { //in ini fle, INHERITED_VALUE=inherited_value rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname); rtl::OUString suName = rtl::OUString::createFromAscii( "INHERITED_VALUE" ); rtl::OUString suValue = rtl::OUString::createFromAscii( "ok" ); // set to another value Bootstrap::set( suName, suValue ); rtl::OUString suGetValue; Bootstrap::get( suName, suGetValue); CPPUNIT_ASSERT_MESSAGE("set and get argument failed.", suGetValue.compareTo(suValue) == 0 ); } void set_002() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap myBootstrap( suIniname); rtl::OUString suName = rtl::OUString::createFromAscii( "INHERITED_VALUE" ); rtl::OUString suGetOrientValue; Bootstrap::get( suName, suGetOrientValue); // ?? INHERITED_VALUE = ok now, which is set in set_001 printUString( suGetOrientValue ); rtl::OUString suValue = rtl::OUString::createFromAscii( TESTSHL2_INI ); // set to another value Bootstrap::set( suName, suValue ); rtl::OUString suGetValue; Bootstrap::get( suName, suGetValue); CPPUNIT_ASSERT_MESSAGE("set and get argument failed.", suGetValue.compareTo(suValue) == 0 ); } CPPUNIT_TEST_SUITE(set); CPPUNIT_TEST(set_001); CPPUNIT_TEST(set_002); CPPUNIT_TEST_SUITE_END(); }; // class set class expandMacrosFrom : public CppUnit::TestFixture { public: void setUp() { } void tearDown() { } void expandMacrosFrom_001() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname); rtl::OUString suMacro = rtl::OUString::createFromAscii( "$MYVAR/expand1" ); //printUString( suMacro ); //expandMacro now aBootstrap.expandMacrosFrom( suMacro ); rtl::OUString suExpectedMacro = rtl::OUString::createFromAscii( "src680_test/expand1" ); //printUString( suMacro ); CPPUNIT_ASSERT_MESSAGE("expandMacrosFrom failed.", suMacro.compareTo(suExpectedMacro) == 0 ); } /** here a special macro should expand * if rtlrc is under sal/qa/rtl/bootstrap/, "${rtlrc:Bootstrap:RTLVALUE}" could be expanded * else rtlrc is under solver/680/unxlngi4.pro/bin/, "${file:/// ....solver/680/unxlngi4.pro/bin/rtlrc:Bootstrap:RTLVALUE}" * could not be expanded */ void expandMacrosFrom_002() { // Build a string with '${rtl.ini:RTLVALUE}' and try to expand it. // In function 'create_rtlrc() is the content of the rtl.ini file. rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); t_print("inifile is:"); printUString( suIniname ); Bootstrap aBootstrap( suIniname) ; rtl::OUString suMacro = rtl::OUString::createFromAscii( "${" ); //rtlrc:Bootstrap:RTLVALUE}"); rtl::OUString aDirURL = OUString::createFromAscii( "$ORIGIN"); aDirURL += OUString::createFromAscii( "/"); aDirURL += OUString::createFromAscii( "rtl" ); #if defined(WNT) || defined(OS2) aDirURL += rtl::OUString::createFromAscii(".ini"); #else aDirURL += rtl::OUString::createFromAscii("rc"); #endif suMacro += aDirURL;//t_getSourcePath("rtl"); suMacro += rtl::OUString::createFromAscii( "::RTLVALUE}"); t_print("created macro is: "); printUString( suMacro ); //expandMacro now aBootstrap.expandMacrosFrom( suMacro ); t_print("expanded macro is:"); printUString( suMacro ); rtl::OUString suExpectedMacro = rtl::OUString::createFromAscii( "qadev17" ); CPPUNIT_ASSERT_MESSAGE("failed, can't expand '${file:///.../" SAL_CONFIGFILE("rtl") "::RTLVALUE}' to 'qadev17'", suMacro.compareTo(suExpectedMacro) == 0 ); } void expandMacrosFrom_002_1() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); t_print("inifile is:"); printUString( suIniname ); Bootstrap aBootstrap( suIniname); rtl::OUString suMacro; // just a simple test, if this really work. aBootstrap.getFrom(rtl::OUString::createFromAscii( "SOFROMVALUE2" ), suMacro ); t_print("SOFROMVALUE2:"); printUString( suMacro ); CPPUNIT_ASSERT_MESSAGE("'SOFROMVALUE2' seems to do not exist.", suMacro.getLength() > 0 ); aBootstrap.getFrom(rtl::OUString::createFromAscii( "SOFROMVALUE" ), suMacro ); t_print("SOFROMVALUE:"); printUString( suMacro ); //expandMacro now // seems to be, that getFrom() already expand the string // t_print("expanded macro is:"); // aBootstrap.expandMacrosFrom( suMacro ); // printUString( suMacro ); rtl::OUString suExpectedMacro = rtl::OUString::createFromAscii( "src680_qadev" ); CPPUNIT_ASSERT_MESSAGE("failed, can't expand '${" SAL_CONFIGFILE("rtl") "::SOVALUE}' to 'src680_qadev'", suMacro.compareTo(suExpectedMacro) == 0 ); } void expandMacrosFrom_002_2() { // test, to read and expand SOFROMVALUE3 // SOFROMVALUE3 is 'rtl(.ini|rc)::TESTSHL_SOVALUE' which should expand to 'rtlfile' if all is ok. rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); t_print("inifile is:"); printUString( suIniname ); Bootstrap aBootstrap( suIniname); rtl::OUString suMacro; aBootstrap.getFrom(rtl::OUString::createFromAscii( "SOFROMVALUE3" ), suMacro ); t_print("SOFROMVALUE3:"); printUString( suMacro ); if (suMacro.equals(rtl::OUString::createFromAscii("testshl2_file") ) == sal_True) { CPPUNIT_ASSERT_MESSAGE("Value 'SOFROMVALUE3' is read from the wrong ini file.", 0 ); } else { CPPUNIT_ASSERT_MESSAGE("SOFROMVALUE3 should contain 'rtlfile'.", suMacro.equals(rtl::OUString::createFromAscii("rtlfile") ) == sal_True ); } } //? I don't know if this is a right test. // void expandMacrosFrom_002_3() // { // // test, to read and expand SOFROMVALUE4 // // SOFROMVALUE4 is 'rtl(.ini|rc):Other_Section:TESTSHL_SOVALUE' which should expand to '' if all is ok. // // rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); // t_print("inifile is:"); // printUString( suIniname ); // Bootstrap aBootstrap( suIniname); // // rtl::OUString suMacro; // aBootstrap.getFrom(rtl::OUString::createFromAscii( "SOFROMVALUE4" ), suMacro ); // // t_print("SOFROMVALUE4:"); // printUString( suMacro ); // // if (suMacro.equals(rtl::OUString::createFromAscii("testshl2_file") ) == sal_True) // { // CPPUNIT_ASSERT_MESSAGE("Value 'SOFROMVALUE4' is read from the wrong section out of the wrong ini file.", 0 ); // } // else if (suMacro.equals(rtl::OUString::createFromAscii("testshl2_file_other") ) == sal_True) // { // CPPUNIT_ASSERT_MESSAGE("Value 'SOFROMVALUE4' is read from the wrong ini file.", 0 ); // } // else // { // CPPUNIT_ASSERT_MESSAGE("Value 'SOFROMVALUE4' should contain 'rtlfile_other'.", suMacro.equals(rtl::OUString::createFromAscii("rtlfile_other") ) == sal_True ); // } // } void expandMacrosFrom_003() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname); rtl::OUString suMacro[4]; suMacro[0] = rtl::OUString::createFromAscii( "$SYSUSERCONFIG" ); suMacro[1] = rtl::OUString::createFromAscii( "$SYSUSERHOME" ); suMacro[2] = rtl::OUString::createFromAscii( "$SYSBINDIR" ); suMacro[3] = rtl::OUString::createFromAscii( "$ORIGIN" ); for ( int i = 0; i < 4; i++ ) { aBootstrap.expandMacrosFrom( suMacro[i] ); printUString(suMacro[i]); } // printUString( t_getSourcePath("") ); // CPPUNIT_ASSERT_MESSAGE("some integral variables.", suMacro[3].equalsIgnoreAsciiCase(t_getSourcePath("")) == sal_True ); CPPUNIT_ASSERT_MESSAGE("some integral variables.", suMacro[0].getLength() > 0 && suMacro[1].getLength() > 0 && suMacro[2].getLength() > 0 && suMacro[3].getLength() > 0); } void testRecursion() { rtl::OUString t(RTL_CONSTASCII_USTRINGPARAM("$RECURSIVE")); Bootstrap(t_getSourcePath(TESTSHL2_INI)).expandMacrosFrom(t); CPPUNIT_ASSERT_MESSAGE( "recursion detection", t.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM("***RECURSION DETECTED***"))); } void testLink() { rtl::OUString t(RTL_CONSTASCII_USTRINGPARAM("$LINKED")); Bootstrap(t_getSourcePath(TESTSHL2_INI)).expandMacrosFrom(t); CPPUNIT_ASSERT_MESSAGE( "link file", t.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("qadev17"))); } void testOverride() { rtl::OUString t1( RTL_CONSTASCII_USTRINGPARAM( "${.override:$ORIGIN/" SAL_CONFIGFILE("rtl") ":ORIGIN}")); Bootstrap(t_getSourcePath("rtl")).expandMacrosFrom(t1); CPPUNIT_ASSERT_MESSAGE( "override ORIGIN", t1.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("direct"))); rtl::OUString t2( RTL_CONSTASCII_USTRINGPARAM( "${.override:$ORIGIN/" SAL_CONFIGFILE("none") ":MYVAR}")); Bootstrap::expandMacros(t2); CPPUNIT_ASSERT_MESSAGE( "override MYVAR", t2.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("src680_test"))); } void testNonexisting() { rtl::OUString t( RTL_CONSTASCII_USTRINGPARAM( "${$ORIGIN/" SAL_CONFIGFILE("none") ":MYVAR}")); Bootstrap::expandMacros(t); CPPUNIT_ASSERT_MESSAGE( "nonexisting", t.equalsAsciiL(RTL_CONSTASCII_STRINGPARAM("src680_test"))); } void testSection() { rtl::OUStringBuffer b; b.appendAscii(RTL_CONSTASCII_STRINGPARAM("${")); rtl::OUString p(t_getSourcePath(TESTSHL2_INI)); for (sal_Int32 i = 0; i < p.getLength(); ++i) { if (p[i] != 'u') { b.append(static_cast< sal_Unicode >('\\')); } b.append(p[i]); } b.appendAscii(RTL_CONSTASCII_STRINGPARAM(":Other_Section:EXPAND}")); rtl::OUString t(b.makeStringAndClear()); Bootstrap(t_getSourcePath(TESTSHL2_INI)).expandMacrosFrom(t); CPPUNIT_ASSERT_MESSAGE( "section expansion", t.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM("$FILE"))); // the correct answer would be "testshl2 file" instead, but // expansion including a section currently erroneously does not // recursively expand macros in the resulting replacement text } CPPUNIT_TEST_SUITE(expandMacrosFrom); CPPUNIT_TEST(expandMacrosFrom_001); CPPUNIT_TEST(expandMacrosFrom_002); CPPUNIT_TEST(expandMacrosFrom_002_1); CPPUNIT_TEST(expandMacrosFrom_002_2); //? CPPUNIT_TEST(expandMacrosFrom_002_3); CPPUNIT_TEST(expandMacrosFrom_003); CPPUNIT_TEST(testRecursion); CPPUNIT_TEST(testLink); CPPUNIT_TEST(testOverride); CPPUNIT_TEST(testNonexisting); CPPUNIT_TEST(testSection); CPPUNIT_TEST_SUITE_END(); }; // class expandMacrosFrom class expandMacros : public CppUnit::TestFixture { public: // initialise your test code values here. void setUp() { } void tearDown() { } void expandMacros_001() { rtl::OUString suIniname = t_getSourcePath(TESTSHL2_INI); Bootstrap aBootstrap( suIniname) ; rtl::OUString suMacro = rtl::OUString::createFromAscii( "$INHERITED_VALUE/well" ); Bootstrap::expandMacros( suMacro ); rtl::OUString suName = rtl::OUString::createFromAscii( "INHERITED_VALUE" ); OUString suGetValue; Bootstrap::get( suName, suGetValue ); suGetValue += OUString::createFromAscii( "/well" ); CPPUNIT_ASSERT_MESSAGE("expandMacros failed.", suGetValue.compareTo(suMacro) == 0 ); } CPPUNIT_TEST_SUITE(expandMacros); CPPUNIT_TEST(expandMacros_001); // CPPUNIT_TEST(expandMacros_002); CPPUNIT_TEST_SUITE_END(); }; // class expandMacros CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::ctor, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::getFrom, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::setIniFilename, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::getHandle, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::set, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::expandMacrosFrom, "rtl_Bootstrap"); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(rtl_Bootstrap::expandMacros, "rtl_Bootstrap"); } // namespace rtl_Bootstrap // ----------------------------------------------------------------------------- // 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; // Here are some helpers, which create a new file 'rtlrc' at the executable path position // and fill the file with some information. // static rtl::OUString getExecutableDirectory() // { // rtl::OUString fileName; // osl_getExecutableFile(&fileName.pData); // // sal_Int32 nDirEnd = fileName.lastIndexOf('/'); // // OSL_ENSURE(nDirEnd >= 0, "Cannot locate executable directory"); // // rtl::OUString aDirURL = fileName.copy(0, nDirEnd); // return aDirURL; // } static void removeAndCreateFile(rtl::OUString const& _suFileURL, rtl::OString const& _sContent) { osl::File::remove(_suFileURL); ::std::auto_ptr pFile( new osl::File( _suFileURL ) ); ::osl::FileBase::RC nError = pFile->open( OpenFlag_Write | OpenFlag_Create ); if ( ::osl::FileBase::E_None == nError || ::osl::FileBase::E_EXIST == nError ) { t_print(T_VERBOSE, "%s\n" , OString(_suFileURL, _suFileURL.getLength(), RTL_TEXTENCODING_ASCII_US).getStr()); sal_uInt64 nWritenBytes; pFile->write(_sContent.getStr(), _sContent.getLength(), nWritenBytes); // t_print("nBytes: %ld\n", nBytes); rtl::OString sError = "can't write enough bytes to file"; sError += OString(_suFileURL, _suFileURL.getLength(), RTL_TEXTENCODING_ASCII_US); OSL_ENSURE(nWritenBytes == _sContent.getLength(), sError.getStr()); pFile->close(); } else { rtl::OString sError = "can't create file URL: '"; rtl::OString sFile; sFile <<= _suFileURL; sError += sFile; sError += "' maybe no write access. If it is true with no write access, please create a local environment and start these tests again. rtl::Bootstrap test must quit."; t_print("%s\n", sError.getStr() ); exit(1); } OSL_ASSERT(t_fileExist(_suFileURL) == true); } // ----------------------------------------------------------------------------- static void create_rtlrc() { rtl::OUString aFileURL(getExecutableDirectory()); #if defined(WNT) || defined(OS2) aFileURL += rtl::OUString::createFromAscii("/rtl.ini"); #else aFileURL += rtl::OUString::createFromAscii("/rtlrc"); #endif rtl::OString sLines; sLines += "[Bootstrap]\n"; sLines += "SOVALUE=src680_qadev\n"; sLines += "RTLVALUE=qadev17\n"; sLines += "TESTSHL_SOVALUE=rtlfile\n"; sLines += "RECURSIVE=${$ORIGIN/" SAL_CONFIGFILE("testshl2") ":RECURSIVE}\n"; sLines += "ORIGIN=direct\n"; sLines += "[Other_Section]\n"; sLines += "TESTSHL_SOVALUE=rtlfile_other\n"; removeAndCreateFile(aFileURL, sLines); } // ----------------------------------------------------------------------------- static void create_testshl2rc() { rtl::OUString aFileURL(getExecutableDirectory()); #if defined(WNT) || defined(OS2) aFileURL += rtl::OUString::createFromAscii("/testshl2.ini"); #else aFileURL += rtl::OUString::createFromAscii("/testshl2rc"); #endif rtl::OString sLines; sLines += "[Bootstrap]\n"; sLines += "FILE=testshl2 file\n"; sLines += "MYBOOTSTRAPTESTVALUE=file\n"; sLines += "INHERITED_VALUE=inherited_value\n"; sLines += "INHERITED_OVERWRITTEN_VALUE=not_overwritten\n"; sLines += "MYVAR=src680_test\n"; sLines += "SOFROMVALUE=${$ORIGIN/" SAL_CONFIGFILE("rtl") "::SOVALUE}\n"; sLines += "SOFROMVALUE2=test\n"; sLines += "SOFROMVALUE3=${$ORIGIN/" SAL_CONFIGFILE("rtl") "::TESTSHL_SOVALUE}\n"; sLines += "TESTSHL_SOVALUE=testshl2_file\n"; //? sLines += "SOFROMVALUE4=${" SAL_CONFIGFILE("rtl") ":Other_Section:TESTSHL_SOVALUE}\n"; sLines += "ILLEGAL VALUE=test\n"; sLines += "ILLEGAL.DOT=test\n"; sLines += "ILLEGAL;SEMICOLON=test\n"; sLines += "ILLEGAL:COLON=test\n"; sLines += " KEY_FOR_TRIM_TEST = value for trim test \n"; sLines += "RECURSIVE=${$ORIGIN/" SAL_CONFIGFILE("rtl") ":RECURSIVE}\n"; sLines += "LINKED=${${.link:$ORIGIN/testshl2-link}:RTLVALUE}\n"; sLines += "[Other_Section]\n"; sLines += "FILE=testshl2 file other\n"; sLines += "EXPAND=$FILE\n"; //? sLines += "TESTSHL_SOVALUE=testshl2_file_other\n"; removeAndCreateFile(aFileURL, sLines); removeAndCreateFile( (getExecutableDirectory() + rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("/testshl2-link"))), SAL_CONFIGFILE("rtl")); } // ----------------------------------------------------------------------------- static void create_pseudorc() { rtl::OUString aFileURL(getExecutableDirectory()); #if defined(WNT) || defined(OS2) aFileURL += rtl::OUString::createFromAscii("/pseudo.ini"); #else aFileURL += rtl::OUString::createFromAscii("/pseudorc"); #endif rtl::OString sLines; sLines += "[Bootstrap]\n"; sLines += "FILE=pseudo file\n"; sLines += "PSEUDOFILE=be pseudo\n"; removeAndCreateFile(aFileURL, sLines); } // ----------------------------------------------------------------------------- void create_bootstrap_processrc() { rtl::OUString aDirURL(getModulePath()); #if defined(WNT) || defined(OS2) aDirURL += rtl::OUString::createFromAscii("/bootstrap_process.ini"); #else aDirURL += rtl::OUString::createFromAscii("/bootstrap_processrc"); #endif rtl::OString sLines; sLines += "[Bootstrap]\n"; sLines += "EXECUTABLE_RC=true\n"; sLines += "IF_CUSTOM_RC=false\n"; removeAndCreateFile(aDirURL, sLines); } // ----------------------------------------------------------------------------- void RegisterAdditionalFunctions(FktRegFuncPtr _pFunc) { (void) _pFunc; // start message t_print(T_VERBOSE, "Initializing ...\n" ); create_rtlrc(); create_testshl2rc(); create_pseudorc(); create_bootstrap_processrc(); t_print(T_VERBOSE, "Initialization Done.\n" ); }