/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ #include #include "connectivity/sqliterator.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "connectivity/sqlnode.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace comphelper; using namespace cppu; using namespace com::sun::star::uno; using namespace com::sun::star::lang; using namespace com::sun::star::registry; using namespace com::sun::star::ucb; using namespace com::sun::star::beans; using namespace connectivity; using namespace com::sun::star::sdb; using namespace com::sun::star::sdbc; using namespace com::sun::star::sdbcx; using namespace ::com::sun::star::container; using ::rtl::OUString; using ::rtl::OUStringToOString; extern Reference< XMultiServiceFactory > InitializeFac( void ); Reference< XMultiServiceFactory > mMgr; #define OUtoCStr( x ) (OUStringToOString ( (x), RTL_TEXTENCODING_ASCII_US ).getStr()) #define PRINTSTR(x) printf("%s",x); #define PRINTLN(x) printf("%s\n",x); const int testLDAP=0; const int testMozilla=1; const int testOp=2; const int testOe=3; static int testCount = 0; static int testList[4] = {0,0,0,0}; int autoTest(Reference &xRes); void printColumns( Reference &xRes ) { if(xRes.is()) { char* aPat = " %-22s "; char* aPat_Short = " %-12s "; Reference xMeta = Reference(xRes,UNO_QUERY)->getMetaData(); OSL_TRACE( "ColumnCount = %d", xMeta->getColumnCount()); for(sal_Int32 i=1;i<=xMeta->getColumnCount();++i) { const char *str = OUtoCStr(xMeta->getColumnName(i)); OSL_TRACE( aPat, str ); } OSL_TRACE("\n"); OSL_TRACE("------------------------------------------------------------------------------------------"); } else { OSL_TRACE(": FAILED to get a ResultSet"); } } void printXResultSet( Reference &xRes ) { if(xRes.is()) { char* aPat = " %-22s "; char* aPat_Short = " %-12s "; Reference xRow(xRes,UNO_QUERY); Reference xMeta = Reference(xRes,UNO_QUERY)->getMetaData(); for(sal_Int32 j=1;j<=xMeta->getColumnCount();++j) { try { const char *str = OUtoCStr(xRow->getString(j)); OSL_TRACE( aPat_Short, str ); } catch (...) { OSL_TRACE(" Ex "); } } OSL_TRACE("\n"); } else OSL_TRACE("FAILED to get a ResultSet"); } void printXResultSets( Reference &xRes ) { if(xRes.is()) { printColumns(xRes); sal_Int32 nRows = 0; while( xRes.is() && xRes->next()) { printXResultSet(xRes); nRows++; } OSL_TRACE( "%d Row(s)", nRows); }else OSL_TRACE("FAILED to get a ResultSet"); } int TestMetaData(Reference< ::com::sun::star::sdbc::XConnection> &pConnection) { // Test some metadata Reference< XDatabaseMetaData > xDmd = pConnection->getMetaData(); if ( xDmd.is() ) { OSL_TRACE(": got DatabaseMetaData"); OUString sQuoteStr = xDmd->getIdentifierQuoteString(); OSL_TRACE( "Quote String : '%s'", OUtoCStr( sQuoteStr ) ); OUString sSQLCmds = xDmd->getSQLKeywords(); OSL_TRACE( "SQL Commands : '%s'", OUtoCStr( sSQLCmds ) ); OSL_TRACE("Testing getColumns() : START"); { Reference xRes = xDmd->getColumns( makeAny(OUString("")), // Catalog OUString("%"), // Schema OUString("%"), // TabName OUString("%") ); printXResultSets( xRes ); } OSL_TRACE("Testing getColumns() : END"); OSL_TRACE("Testing getTypeInfo() : START"); { Reference xRes = xDmd-> getTypeInfo(); printXResultSets( xRes ); } OSL_TRACE("Testing getTypeInfo() : END"); OSL_TRACE("Testing getTables() : START"); { Reference xRes = xDmd->getTables( makeAny(OUString("")), // Catalog OUString("%"), // Schema OUString("%"), // TabName Sequence() ); printXResultSets( xRes ); } OSL_TRACE("Testing getTables() : END"); } else OSL_TRACE(": FAILED to get DatabaseMetaData"); return 0; } void TestQuery(Reference< ::com::sun::star::sdbc::XConnection> &pConnection) { // Try a query OSL_TRACE("Testing createStatement() & executeQuery() : START"); Reference xStmt = pConnection->createStatement(); Reference xRes; if(xStmt.is()) { OSL_TRACE(": got statement"); OSL_TRACE(": excuteQuery() : START \n"); // SELECT "First Name", "Display Name", "E-mail" FROM tablename OUString sqlPrefix("SELECT \"First Name\", \"Display Name\", \"E-mail\" FROM "); try { sal_Int32 times=0; Reference< XDatabaseMetaData > xDmd = pConnection->getMetaData(); if ( xDmd.is() ) { OSL_TRACE("getTables() : START"); OUString qut = xDmd->getIdentifierQuoteString(); Reference xRes = xDmd->getTables( makeAny(OUString("")), // Catalog OUString("%"), // Schema OUString("%"), // TabName Sequence() ); sal_Int32 nTables = 0; while( xRes.is() && xRes->next()) { Reference xRow(xRes,UNO_QUERY); const char *strTableName = OUtoCStr(xRow->getString(3)); OSL_TRACE("Testing Table:%s",strTableName); Reference tmpRes = xStmt->executeQuery(sqlPrefix + qut + xRow->getString(3) + qut); autoTest( tmpRes ); Reference clsRes(tmpRes,UNO_QUERY); clsRes->close(); nTables++; } OSL_TRACE("Tested Tables:%d",nTables); } } catch ( Exception &e ) { OSL_TRACE( "Exception caught : %s", OUtoCStr( e.Message) ); } // catch (...) { // OSL_TRACE( "Non-UNO Exception caught\n" ); // } OSL_TRACE("excuteQuery() : END"); } else { OSL_TRACE(": FAILED to get statement"); } OSL_TRACE("Testing createStatement() & executeQuery() : END"); } Reference< ::com::sun::star::sdbc::XConnection> TestConnected (Reference< ::com::sun::star::sdbc::XDriver> &pDriver) { ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection> pConnection; OSL_TRACE("Begin Connect!"); OUString url; Sequence aValue; int nType=0; srand( (unsigned)time( NULL ) ); nType = rand() % testCount + 1; int nIndex=0,nCount=0; for ( nIndex = 0; nIndex< 4;nIndex++) { if (testList[nIndex]) nCount++; if (nCount == nType) break; } switch( nIndex) { case testLDAP: url=OUString("sdbc:address:ldap://"); aValue.realloc(2); aValue[0].Name = ::rtl::OUString("HostName"); aValue[0].Value <<= rtl::OUString("sun-ds"); aValue[1].Name = ::rtl::OUString("BaseDN"); aValue[1].Value <<= rtl::OUString("dc=sun,dc=com"); break; case testMozilla: url=OUString("sdbc:address:mozilla://"); break; case testOp: url=OUString("sdbc:address:outlook://"); break; case testOe: url=OUString("sdbc:address:outlookexp://"); break; default: url=OUString("sdbc:address:mozilla://"); break; } pConnection = pDriver->connect(url,aValue); return pConnection; } int autoTest(Reference &xRes) { sal_Int32 nRows = 0; printColumns(xRes); if(xRes.is()) { while( xRes.is() && xRes->next()) { nRows++; } OSL_TRACE( "%d Row(s)", nRows); sal_Int32 times; sal_Int32 pos; if (nRows) { for(times = 1;times < 10; times ++) { pos= rand() % nRows+1; OSL_TRACE("pos:%d",pos); xRes->absolute(pos); printXResultSet(xRes); } } } else { OSL_TRACE(": FAILED to get a ResultSet"); } TimeValue timeValue = { 1, 0 }; //sleep 1 Seconds to give time to other threads osl_waitThread(&timeValue); return 0; } void SAL_CALL mozThread(void*) { ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XConnection> m_xConnection; try { Reference< ::com::sun::star::sdbc::XDriver> m_xDriver(mMgr->createInstance( OUString("com.sun.star.comp.sdbc.MozabDriver")), UNO_QUERY); if(m_xDriver.is()) { m_xConnection = TestConnected(m_xDriver); if(m_xConnection.is()) { if (!TestMetaData(m_xConnection)) { TestQuery(m_xConnection); } } else OSL_TRACE("Can't connected!"); } else { OSL_TRACE("No driver!"); } } catch ( Exception &e ) { OSL_TRACE( "Exception caught : %s", OUtoCStr( e.Message) ); } // catch (...) { // OSL_TRACE( "Non-UNO Exception caught\n" ); // } } const int THREAD_COUNT=100; void usage() { PRINTLN("mozThread [opts] threadcount"); PRINTLN("opts:"); PRINTLN("-l test ldap"); PRINTLN("-m test mozilla"); PRINTLN("-p test outlook"); PRINTLN("-e test outlook express"); PRINTLN("0 < threadcount <= 100, default 100"); } #if (defined UNX) int main( int argc, char * argv[] ) #else int _cdecl main( int argc, char * argv[] ) #endif { OSL_TRACE("Init UNO"); Reference< XMultiServiceFactory > xMgr =InitializeFac(); int threadCount=THREAD_COUNT; int nAc; for (nAc = 1; nAc < argc; nAc ++) { if (strcmp(argv[nAc],"-l") ==0) { testList[testLDAP] = 1; }else if(strcmp(argv[nAc],"-m") ==0) { testList[testMozilla]=1; }else if(strcmp(argv[nAc],"-p") ==0) { testList[testOp]=1; }else if(strcmp(argv[nAc],"-e") ==0) { testList[testOe]=1; }else if(strcmp(argv[nAc],"-h") ==0 || strcmp(argv[nAc],"--help") ==0) { usage(); return 0; }else { int tmpCount = atoi(argv[nAc]); if (tmpCount > 0 && tmpCount < threadCount) { threadCount = tmpCount; } } } testCount = testList[testLDAP] + testList[testMozilla] + testList[testOp] + testList[testOe]; if ( testCount == 0) { testList[testLDAP] = 1; testCount = 1; } if (!xMgr.is()) { OSL_TRACE("Error init UNO"); return 1; } else OSL_TRACE("UNO initted"); mMgr = xMgr; oslThread xThreads[THREAD_COUNT]; int index=0; for(index=0;index < threadCount; index++) { xThreads[index] = osl_createThread(mozThread,(void*)NULL); TimeValue timeValue = { 1, 0 }; //sleep 1 Seconds to give time to other threads osl_waitThread(&timeValue); } for(index=0;index < threadCount; index++) { if (osl_isThreadRunning(xThreads[index])) osl_joinWithThread(xThreads[index]); } OSL_TRACE("Exiting..."); return 0; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */