diff options
author | Matúš Kukan <matus.kukan@gmail.com> | 2012-07-25 22:48:42 +0200 |
---|---|---|
committer | Matúš Kukan <matus.kukan@gmail.com> | 2012-07-26 01:29:06 +0200 |
commit | 19f92976d8612b9b70264cc33151e944c52124e1 (patch) | |
tree | bc927f06d12e619c61cbbb6068b7e9e34f3f0a3a /tubes/qa | |
parent | 7ce4cc7c608399814005e5a7b465bd087077e161 (diff) |
tubes: resurrect unit test to serve again
- make it subsequent test to be less annoying
- we again inherit from CppUnit::TestFixture
- currently there is no test that we've received the sent packet
- nor any test for received file
- to prevent exporting more symbols we link directly tubes' object files
Change-Id: I79edf0c701f8c46eb45d507266f6dafc0c8eeea2
Diffstat (limited to 'tubes/qa')
-rw-r--r-- | tubes/qa/test_manager.cxx | 287 |
1 files changed, 97 insertions, 190 deletions
diff --git a/tubes/qa/test_manager.cxx b/tubes/qa/test_manager.cxx index 6f9a7ba0f768..81298d0c48e2 100644 --- a/tubes/qa/test_manager.cxx +++ b/tubes/qa/test_manager.cxx @@ -26,101 +26,75 @@ * instead of those above. */ -#include <sal/precppunit.hxx> +#include <sal/types.h> -#include <tubes/contact-list.hxx> -#include <tubes/manager.hxx> - -#include <cppunit/TestAssert.h> #include <cppunit/TestFixture.h> #include <cppunit/extensions/HelperMacros.h> #include <cppunit/plugin/TestPlugIn.h> + +#include <rtl/bootstrap.hxx> #include <rtl/string.hxx> #include <rtl/ustring.hxx> -#include <rtl/bootstrap.hxx> -#include <unotest/bootstrapfixturebase.hxx> +#include <tubes/conference.hxx> +#include <tubes/contact-list.hxx> +#include <tubes/manager.hxx> +#include <unotools/localfilehelper.hxx> + +#include <telepathy-glib/telepathy-glib.h> namespace { -class TestTeleTubes: public test::BootstrapFixtureBase +class TestTeleTubes: public CppUnit::TestFixture { public: - TestTeleTubes(); - ~TestTeleTubes(); - void testSetupManager1(); - void testSetupManager2(); - void testCreateAccountManager1(); - void testCreateAccountManager2(); - void testRegisterClients1(); - void testRegisterClients2(); + TestTeleTubes() {} + ~TestTeleTubes() {} + // This could happen in costructor wasn't there TestTeleTubes instance for each test: + void testInitialize(); + void testCreateAccountManager(); + void testRegisterClients(); void testContactList(); - void testPrepareAccountManager1(); - void testPrepareAccountManager2(); - void testStartBuddySession1(); - void testStartBuddySession2(); + void testPrepareAccountManager(); + void testStartBuddySession(); void testSendPacket(); void testReceivePacket(); void testSendFile(); - void testDestroyManager1(); - void testDestroyManager2(); - void testDestroyAccepterContact(); + void testDestroyTeleTubes(); void testFailAlways(); - void ReceiverCallback( TeleConference* pConference, const TelePacket &rPacket ); - - GMainLoop* mpMainLoop; - void spinMainLoop(); - + void ReceiverCallback( const OString &rPacket ); static void FileSent( bool success, void *user_data); - void FileReceived( rtl::OUString& aUri ); // Order is significant. CPPUNIT_TEST_SUITE( TestTeleTubes ); - CPPUNIT_TEST( testSetupManager1 ); - CPPUNIT_TEST( testSetupManager2 ); - CPPUNIT_TEST( testCreateAccountManager1 ); - CPPUNIT_TEST( testCreateAccountManager2 ); - CPPUNIT_TEST( testRegisterClients1 ); - CPPUNIT_TEST( testRegisterClients2 ); - CPPUNIT_TEST( testPrepareAccountManager1 ); - CPPUNIT_TEST( testPrepareAccountManager2 ); + CPPUNIT_TEST( testInitialize ); + CPPUNIT_TEST( testCreateAccountManager ); + CPPUNIT_TEST( testRegisterClients ); + CPPUNIT_TEST( testPrepareAccountManager ); CPPUNIT_TEST( testContactList ); - CPPUNIT_TEST( testStartBuddySession1 ); - CPPUNIT_TEST( testStartBuddySession2 ); + CPPUNIT_TEST( testStartBuddySession ); CPPUNIT_TEST( testSendPacket ); CPPUNIT_TEST( testReceivePacket ); CPPUNIT_TEST( testSendFile ); - CPPUNIT_TEST( testDestroyManager1 ); - CPPUNIT_TEST( testDestroyManager2 ); - CPPUNIT_TEST( testDestroyAccepterContact ); + CPPUNIT_TEST( testDestroyTeleTubes ); #if 0 CPPUNIT_TEST( testFailAlways ); // test failure displays SAL_LOG, uncomment for debugging #endif CPPUNIT_TEST_SUITE_END(); - -private: -// XXX The Jabber accounts specified in test-config.ini need to be setup in -// Empathy, enabled, connected, and on each other's rosters. - rtl::OUString maTestConfigIniURL; - rtl::Bootstrap maTestConfig; - - rtl::OString maOffererIdentifier; - rtl::OString maAccepterIdentifier; - - bool maFileSentSuccess; - rtl::OUString maFileReceivedUri; - - sal_uInt32 mnPacketReceivedEmissions; }; // static, not members, so they actually survive cppunit test iteration -static TeleManager* mpManager1 = NULL; -static TeleManager* mpManager2 = NULL; - -static TpContact* mpAccepterContact = NULL; - -static sal_uInt32 nSentPackets = 0; +static TeleConference* mpConference1 = NULL; +static TeleManager* mpManager = NULL; +static TpContact* mpAccepterContact = NULL; +static GMainLoop* mpMainLoop = NULL; +static bool maFileSentSuccess = false; +static sal_uInt32 mnSentPackets = 0; +static sal_uInt32 mnPacketReceivedEmissions = 0; +static OUString maTestConfigIniURL; +static OString maOffererIdentifier; +static OString maAccepterIdentifier; static gboolean timed_out (void *user_data) @@ -133,44 +107,37 @@ timed_out (void *user_data) return FALSE; } -TestTeleTubes::TestTeleTubes() - : maTestConfigIniURL(getURLFromSrc("/tubes/qa/test-config.ini")), - maTestConfig(maTestConfigIniURL), - mnPacketReceivedEmissions(0) +void TestTeleTubes::testInitialize() { + utl::LocalFileHelper::ConvertPhysicalNameToURL( + OUString::createFromAscii( getenv("SRCDIR") ) + "/tubes/qa/test-config.ini", + maTestConfigIniURL ); + rtl::Bootstrap aTestConfig( maTestConfigIniURL ); + TeleManager::addSuffixToNames( "TeleTest"); rtl::OUString aOffererIdentifier; CPPUNIT_ASSERT_MESSAGE( "See README for how to set up test-config.ini", - maTestConfig.getFrom("offerer", aOffererIdentifier)); + aTestConfig.getFrom("offerer", aOffererIdentifier)); maOffererIdentifier = OUStringToOString( aOffererIdentifier, RTL_TEXTENCODING_UTF8); rtl::OUString aAccepterIdentifier; CPPUNIT_ASSERT_MESSAGE( "See README for how to set up test-config.ini", - maTestConfig.getFrom("accepter", aAccepterIdentifier)); + aTestConfig.getFrom("accepter", aAccepterIdentifier)); maAccepterIdentifier = OUStringToOString( aAccepterIdentifier, RTL_TEXTENCODING_UTF8); mpMainLoop = g_main_loop_new (NULL, FALSE); g_timeout_add_seconds (10, timed_out, mpMainLoop); -} - -TestTeleTubes::~TestTeleTubes() -{ - g_main_loop_unref( mpMainLoop); - mpMainLoop = NULL; -} -void TestTeleTubes::spinMainLoop() -{ - g_main_loop_run( mpMainLoop); + mpManager = TeleManager::get(); } void TestTeleTubes::testContactList() { - CPPUNIT_ASSERT( mpManager1); - CPPUNIT_ASSERT( mpManager1->getAccountManagerStatus() == TeleManager::AMS_PREPARED); + CPPUNIT_ASSERT( mpManager); + CPPUNIT_ASSERT( mpManager->getAccountManagerStatus() == TeleManager::AMS_PREPARED); - ContactList *cl = mpManager1->getContactList(); + ContactList *cl = mpManager->getContactList(); AccountContactPairV pairs; @@ -211,173 +178,113 @@ void TestTeleTubes::testContactList() mpAccepterContact); } -void TestTeleTubes::testSetupManager1() +void TestTeleTubes::testPrepareAccountManager() { - mpManager1 = new TeleManager(true); -} - -void TestTeleTubes::testSetupManager2() -{ - mpManager2 = new TeleManager(); -} - -void TestTeleTubes::testPrepareAccountManager1() -{ - mpManager1->prepareAccountManager(); - TeleManager::AccountManagerStatus eStatus = mpManager1->getAccountManagerStatus(); + mpManager->prepareAccountManager(); + TeleManager::AccountManagerStatus eStatus = mpManager->getAccountManagerStatus(); CPPUNIT_ASSERT( eStatus == TeleManager::AMS_PREPARED); } -void TestTeleTubes::testPrepareAccountManager2() +void TestTeleTubes::ReceiverCallback( const OString & rPacket ) { - mpManager2->prepareAccountManager(); - TeleManager::AccountManagerStatus eStatus = mpManager2->getAccountManagerStatus(); - CPPUNIT_ASSERT( eStatus == TeleManager::AMS_PREPARED); -} - -void TestTeleTubes::ReceiverCallback( TeleConference* pConference, const TelePacket & ) -{ - SAL_INFO( "tubes", "TestTeleTubes::ReceiverCallback: " << pConference); - if (pConference) + SAL_INFO( "tubes", "TestTeleTubes::ReceiverCallback: " << rPacket.getStr()); + if (!rPacket.isEmpty()) { // we could pop a packet here mnPacketReceivedEmissions++; } } -void TestTeleTubes::testStartBuddySession1() +void TestTeleTubes::testStartBuddySession() { - TpAccount *pAcc1 = mpManager1->getAccount(maOffererIdentifier); + TpAccount *pAcc1 = mpManager->getAccount(maOffererIdentifier); CPPUNIT_ASSERT( pAcc1 != 0); /* This has to run after testContactList has run successfully. */ CPPUNIT_ASSERT( mpAccepterContact != 0); - bool bStarted = mpManager1->startBuddySession( pAcc1, mpAccepterContact); - CPPUNIT_ASSERT( bStarted == true); -} - -void TestTeleTubes::testStartBuddySession2() -{ - //bool bStarted = mpManager2->startBuddySession( sAcc2, sAcc1); - //CPPUNIT_ASSERT( bStarted == true); -} - -void TestTeleTubes::testCreateAccountManager1() -{ - bool bConnected = mpManager1->createAccountManager(); - CPPUNIT_ASSERT( bConnected == true); + mpConference1 = mpManager->startBuddySession( pAcc1, mpAccepterContact); + CPPUNIT_ASSERT( mpConference1 != NULL); } -void TestTeleTubes::testCreateAccountManager2() +void TestTeleTubes::testCreateAccountManager() { - bool bConnected = mpManager2->createAccountManager(); + bool bConnected = mpManager->createAccountManager(); CPPUNIT_ASSERT( bConnected == true); } -void TestTeleTubes::testRegisterClients1() -{ - bool bRegistered = mpManager1->registerClients(); - CPPUNIT_ASSERT( bRegistered == true); -} - -void TestTeleTubes::testRegisterClients2() +void TestTeleTubes::testRegisterClients() { - bool bRegistered = mpManager2->registerClients(); + bool bRegistered = mpManager->registerClients(); CPPUNIT_ASSERT( bRegistered == true); } void TestTeleTubes::testSendPacket() { - TelePacket aPacket( "", RTL_CONSTASCII_STRINGPARAM( "from 1 to 2")); + OString aPacket( "from 1 to 2" ); - mpManager1->sigPacketReceived.connect( boost::bind( &TestTeleTubes::ReceiverCallback, this, _1, _2 ) ); - nSentPackets = mpManager1->sendPacket( aPacket); - CPPUNIT_ASSERT( nSentPackets == 2); // expect out+in conference, as own instance accepted self - CPPUNIT_ASSERT( mnPacketReceivedEmissions == 2 ); + mpConference1->sigPacketReceived.connect( boost::bind( &TestTeleTubes::ReceiverCallback, this, _1 ) ); + bool bSentPacket = mpConference1->sendPacket( aPacket ); + CPPUNIT_ASSERT( bSentPacket ); + mnSentPackets++; + CPPUNIT_ASSERT( mnPacketReceivedEmissions == 1 ); } void TestTeleTubes::testReceivePacket() { - TelePacket aPacket( "", RTL_CONSTASCII_STRINGPARAM( "from 1 to 2")); - TelePacket aReceived; + /* We can't get to the TeleConference accepting our packets. + * It's stored in TeleManager but available only after receiving file + * and extracting UUID from the name. + */ + sal_uInt32 nReceivedPackets = 0; - /* We expect to get every packet we send pushed onto the queue to be echoed - * locally; and since we are also listening at the "other end", we expect - * to receive a copy of each packet as well. + /* We expect to get every packet we send pushed + * onto the queue to be echoed locally. */ - sal_uInt32 nExpectedPackets = nSentPackets * 2; bool bOk; - do { - do + OString aReceived; + bOk = mpConference1->popPacket( aReceived ); + if (bOk) { - bOk = mpManager1->popPacket( aReceived); - if (bOk) - { - ++nReceivedPackets; - CPPUNIT_ASSERT( aPacket == aReceived); - } - } while (bOk); - if (nReceivedPackets < nExpectedPackets) - mpManager1->iterateLoop(); - } while (nReceivedPackets < nExpectedPackets); - CPPUNIT_ASSERT( nReceivedPackets == nExpectedPackets); -} - -void TestTeleTubes::FileSent( bool success, void *user_data) -{ - TestTeleTubes *self = reinterpret_cast<TestTeleTubes *>(user_data); - - self->maFileSentSuccess = success; - g_main_loop_quit (self->mpMainLoop); + ++nReceivedPackets; + CPPUNIT_ASSERT( "from 1 to 2" == aReceived ); + } + } while (bOk); + CPPUNIT_ASSERT( nReceivedPackets == mnSentPackets ); } -void TestTeleTubes::FileReceived( rtl::OUString& aUri ) +void TestTeleTubes::FileSent( bool success, void * ) { - maFileReceivedUri = aUri; + maFileSentSuccess = success; g_main_loop_quit (mpMainLoop); } void TestTeleTubes::testSendFile() { - TpAccount *pAcc1 = mpManager1->getAccount(maOffererIdentifier); - CPPUNIT_ASSERT( pAcc1 != 0); /* This has to run after testContactList has run successfully. */ CPPUNIT_ASSERT( mpAccepterContact != 0); - mpManager1->sigFileReceived.connect( - boost::bind(&TestTeleTubes::FileReceived, this, _1)); - - mpManager1->sendFile( maTestConfigIniURL, - &TestTeleTubes::FileSent, this); - /* Waiting for two events: FileSent and FileReceived both quit the mainloop */ - spinMainLoop(); - spinMainLoop(); + mpConference1->sendFile( maTestConfigIniURL, + &TestTeleTubes::FileSent, NULL); + /* Waiting for event: FileSent quits the mainloop */ + g_main_loop_run( mpMainLoop); CPPUNIT_ASSERT( maFileSentSuccess); - CPPUNIT_ASSERT_MESSAGE( - OUStringToOString( maFileReceivedUri, RTL_TEXTENCODING_UTF8).getStr(), - maFileReceivedUri == "file:///tmp/LibreOffice-collab-test-config.ini"); -} - -void TestTeleTubes::testDestroyManager1() -{ - delete mpManager1; - mpManager1 = NULL; -} - -void TestTeleTubes::testDestroyManager2() -{ - delete mpManager2; - mpManager2 = NULL; + // Currently there is no way to check that the file was received ! } -void TestTeleTubes::testDestroyAccepterContact() +void TestTeleTubes::testDestroyTeleTubes() { if (mpAccepterContact) { g_object_unref(mpAccepterContact); mpAccepterContact = NULL; } + if (mpManager) + mpManager->unref(); + g_main_loop_unref( mpMainLoop ); + if (mpConference1) + mpConference1->close(); + delete mpConference1; } void TestTeleTubes::testFailAlways() |