/************************************************************************* * * 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: testHelperFunctions.cxx,v $ * $Revision: 1.6 $ * * 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" // This is a test of helperfunctions #include #include #include "stringhelper.hxx" #include // void isJaBloed() // { // t_print("Ist ja echt bloed.\n"); // } inline sal_Int64 t_abs64(sal_Int64 _nValue) { // std::abs() seems to have some ambiguity problems (so-texas) // return abs(_nValue); t_print("t_abs64(%ld)\n", _nValue); // CPPUNIT_ASSERT(_nValue < 2147483647); if (_nValue < 0) { _nValue = -_nValue; } return _nValue; } void t_print64(sal_Int64 n) { if (n < 0) { // negativ printf("-"); n = -n; } if (n > 2147483647) { sal_Int64 n64 = n >> 32; sal_uInt32 n32 = n64 & 0xffffffff; printf("0x%.8x ", n32); n32 = n & 0xffffffff; printf("%.8x (64bit)", n32); } else { sal_uInt32 n32 = n & 0xffffffff; printf("0x%.8x (32bit) ", n32); } printf("\n"); } // ----------------------------------------------------------------------------- namespace testOfHelperFunctions { class test_t_abs64 : public CppUnit::TestFixture { public: void test0(); void test1_0(); void test1(); void test1_1(); void test2(); void test3(); void test4(); CPPUNIT_TEST_SUITE( test_t_abs64 ); CPPUNIT_TEST( test0 ); CPPUNIT_TEST( test1_0 ); CPPUNIT_TEST( test1 ); CPPUNIT_TEST( test1_1 ); CPPUNIT_TEST( test2 ); CPPUNIT_TEST( test3 ); CPPUNIT_TEST( test4 ); CPPUNIT_TEST_SUITE_END( ); }; void test_t_abs64::test0() { // this values has an overrun! sal_Int32 n32 = 2147483648; t_print("n32 should be -2^31 is: %d\n", n32); CPPUNIT_ASSERT_MESSAGE("n32!=2147483648", n32 == -2147483648 ); } void test_t_abs64::test1_0() { sal_Int64 n; n = 1073741824; n <<= 9; t_print("Value of n is "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=2^30 << 9", t_abs64(n) > 0 ); } void test_t_abs64::test1() { sal_Int64 n; n = 2147483648 << 8; t_print("Value of n is "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=2^31 << 8", t_abs64(n) > 0 ); } void test_t_abs64::test1_1() { sal_Int64 n; n = sal_Int64(2147483648) << 8; t_print("Value of n is "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=2^31 << 8", t_abs64(n) > 0 ); } void test_t_abs64::test2() { sal_Int64 n; n = 2147483648 << 1; t_print("Value of n is "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("(2147483648 << 1) is != 0", n != 0 ); sal_Int64 n2 = 2147483648 * 2; CPPUNIT_ASSERT_MESSAGE("2147483648 * 2 is != 0", n2 != 0 ); sal_Int64 n3 = 4294967296LL; CPPUNIT_ASSERT_MESSAGE("4294967296 is != 0", n3 != 0 ); CPPUNIT_ASSERT_MESSAGE("n=2^31 << 1, n2 = 2^31 * 2, n3 = 2^32, all should equal!", n == n2 && n == n3 ); } void test_t_abs64::test3() { sal_Int64 n = 0; CPPUNIT_ASSERT_MESSAGE("n=0", t_abs64(n) == 0 ); n = 1; CPPUNIT_ASSERT_MESSAGE("n=1", t_abs64(n) > 0 ); n = 2147483647; CPPUNIT_ASSERT_MESSAGE("n=2^31 - 1", t_abs64(n) > 0 ); n = 2147483648; CPPUNIT_ASSERT_MESSAGE("n=2^31", t_abs64(n) > 0 ); } void test_t_abs64::test4() { sal_Int64 n = 0; n = -1; t_print("Value of n is -1 : "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=-1", t_abs64(n) > 0 ); n = -2147483648; t_print("Value of n is -2^31 : "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=-2^31", t_abs64(n) > 0 ); n = -8589934592LL; t_print("Value of n is -2^33 : "); t_print64(n); CPPUNIT_ASSERT_MESSAGE("n=-2^33", t_abs64(n) > 0 ); } // ----------------------------------------------------------------------------- class test_t_print : public CppUnit::TestFixture { public: void t_print_001(); CPPUNIT_TEST_SUITE( test_t_print ); CPPUNIT_TEST( t_print_001 ); CPPUNIT_TEST_SUITE_END( ); }; void test_t_print::t_print_001( ) { t_print("This is only a test of some helper functions\n"); sal_Int32 nValue = 12345; t_print("a value %d (should be 12345)\n", nValue); rtl::OString sValue("foo bar"); t_print("a String '%s' (should be 'foo bar')\n", sValue.getStr()); rtl::OUString suValue(rtl::OUString::createFromAscii("a unicode string")); sValue <<= suValue; t_print("a String '%s'\n", sValue.getStr()); } class StopWatch { TimeValue m_aStartTime; TimeValue m_aEndTime; bool m_bStarted; public: StopWatch() :m_bStarted(false) { } void start() { m_bStarted = true; osl_getSystemTime(&m_aStartTime); } void stop() { osl_getSystemTime(&m_aEndTime); OSL_ENSURE(m_bStarted, "Not Started."); m_bStarted = false; } rtl::OString makeTwoDigits(rtl::OString const& _sStr) { rtl::OString sBack; if (_sStr.getLength() == 0) { sBack = "00"; } else { if (_sStr.getLength() == 1) { sBack = "0" + _sStr; } else { sBack = _sStr; } } return sBack; } rtl::OString makeThreeDigits(rtl::OString const& _sStr) { rtl::OString sBack; if (_sStr.getLength() == 0) { sBack = "000"; } else { if (_sStr.getLength() == 1) { sBack = "00" + _sStr; } else { if (_sStr.getLength() == 2) { sBack = "0" + _sStr; } else { sBack = _sStr; } } } return sBack; } void showTime(const rtl::OString & aWhatStr) { OSL_ENSURE(!m_bStarted, "Not Stopped."); sal_Int32 nSeconds = m_aEndTime.Seconds - m_aStartTime.Seconds; sal_Int32 nNanoSec = sal_Int32(m_aEndTime.Nanosec) - sal_Int32(m_aStartTime.Nanosec); // printf("Seconds: %d Nanosec: %d ", nSeconds, nNanoSec); if (nNanoSec < 0) { nNanoSec = 1000000000 + nNanoSec; nSeconds--; // printf(" NEW Seconds: %d Nanosec: %d\n", nSeconds, nNanoSec); } rtl::OString aStr = "Time for "; aStr += aWhatStr; aStr += " "; aStr += makeTwoDigits(rtl::OString::valueOf(nSeconds / 3600)); aStr += ":"; aStr += makeTwoDigits(rtl::OString::valueOf((nSeconds % 3600) / 60)); aStr += ":"; aStr += makeTwoDigits(rtl::OString::valueOf((nSeconds % 60))); aStr += ":"; aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000000000) / 1000000)); aStr += ":"; aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000000) / 1000)); aStr += ":"; aStr += makeThreeDigits(rtl::OString::valueOf((nNanoSec % 1000))); printf("%s\n", aStr.getStr()); // cout << aStr.getStr() << endl; } }; static sal_Bool isEqualTimeValue ( const TimeValue* time1, const TimeValue* time2) { if( time1->Seconds == time2->Seconds && time1->Nanosec == time2->Nanosec) return sal_True; else return sal_False; } static sal_Bool isGreaterTimeValue( const TimeValue* time1, const TimeValue* time2) { sal_Bool retval= sal_False; if ( time1->Seconds > time2->Seconds) retval= sal_True; else if ( time1->Seconds == time2->Seconds) { if( time1->Nanosec > time2->Nanosec) retval= sal_True; } return retval; } static sal_Bool isGreaterEqualTimeValue( const TimeValue* time1, const TimeValue* time2) { if( isEqualTimeValue( time1, time2) ) return sal_True; else if( isGreaterTimeValue( time1, time2)) return sal_True; else return sal_False; } bool isBTimeGreaterATime(TimeValue const& A, TimeValue const& B) { if (B.Seconds > A.Seconds) return true; if (B.Nanosec > A.Nanosec) return true; // lower or equal return false; } // ----------------------------------------------------------------------------- class test_TimeValues : public CppUnit::TestFixture { public: void t_time1(); void t_time2(); void t_time3(); CPPUNIT_TEST_SUITE( test_TimeValues ); CPPUNIT_TEST( t_time1 ); CPPUNIT_TEST( t_time2 ); CPPUNIT_TEST( t_time3 ); CPPUNIT_TEST_SUITE_END( ); }; void test_TimeValues::t_time1() { StopWatch aWatch; aWatch.start(); TimeValue aTimeValue={3,0}; osl::Thread::wait(aTimeValue); aWatch.stop(); aWatch.showTime("Wait for 3 seconds"); } void test_TimeValues::t_time2() { t_print("Wait repeats 20 times.\n"); int i=0; while(i++<20) { StopWatch aWatch; aWatch.start(); TimeValue aTimeValue={0,1000 * 1000 * 500}; osl::Thread::wait(aTimeValue); aWatch.stop(); aWatch.showTime("wait for 500msec"); } } void test_TimeValues::t_time3() { t_print("Wait repeats 100 times.\n"); int i=0; while(i++<20) { StopWatch aWatch; aWatch.start(); TimeValue aTimeValue={0,1000*1000*100}; osl::Thread::wait(aTimeValue); aWatch.stop(); aWatch.showTime("wait for 100msec"); } } // void demoTimeValue() // { // TimeValue aStartTime, aEndTime; // osl_getSystemTime(&aStartTime); // // testSession(xORB, false); // osl_getSystemTime(&aEndTime); // // sal_Int32 nSeconds = aEndTime.Seconds - aStartTime.Seconds; // sal_Int32 nNanoSec = aEndTime.Nanosec - aStartTime.Nanosec; // if (nNanoSec < 0) // { // nNanoSec = 1000000000 - nNanoSec; // nSeconds++; // } // // // cout << "Time: " << nSeconds << ". " << nNanoSec << endl; // } } // namespace testOfHelperFunctions // ----------------------------------------------------------------------------- CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_t_print, "helperFunctions" ); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_t_abs64, "helperFunctions" ); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( testOfHelperFunctions::test_TimeValues, "helperFunctions" ); // ----------------------------------------------------------------------------- NOADDITIONAL;