summaryrefslogtreecommitdiff
path: root/tubes/qa/test_manager.cxx
diff options
context:
space:
mode:
authorWill Thompson <will.thompson@collabora.co.uk>2012-03-22 16:44:13 +0000
committerMatúš Kukan <matus.kukan@gmail.com>2012-07-17 16:39:34 +0200
commit9bcf81c5645b1fffe6c0253533fe92ee488e60ad (patch)
tree65bbb12e483a0e1d97fcfa3e820f413ced3b446e /tubes/qa/test_manager.cxx
parentd7ed9151c074b6432ab554beeef7b5990d420c6f (diff)
tubes test: refactor spinning mainloop
Diffstat (limited to 'tubes/qa/test_manager.cxx')
-rw-r--r--tubes/qa/test_manager.cxx34
1 files changed, 20 insertions, 14 deletions
diff --git a/tubes/qa/test_manager.cxx b/tubes/qa/test_manager.cxx
index b053652fbae2..b1ee074d5fb8 100644
--- a/tubes/qa/test_manager.cxx
+++ b/tubes/qa/test_manager.cxx
@@ -66,6 +66,7 @@ public:
void testFailAlways();
GMainLoop* mpMainLoop;
+ void spinMainLoop();
// Order is significant.
CPPUNIT_TEST_SUITE( TestTeleTubes );
@@ -105,6 +106,17 @@ static TpContact* mpAccepterContact = NULL;
static sal_uInt32 nSentPackets = 0;
+static gboolean
+timed_out (void *user_data)
+{
+ CPPUNIT_ASSERT_MESSAGE( "Test took longer than ten seconds!", false);
+
+ GMainLoop *loop = reinterpret_cast<GMainLoop *>(user_data);
+
+ g_main_loop_quit (loop);
+ return FALSE;
+}
+
TestTeleTubes::TestTeleTubes()
: maTestConfigIniURL(getURLFromSrc("/tubes/qa/test-config.ini")),
maTestConfig(maTestConfigIniURL)
@@ -120,10 +132,15 @@ TestTeleTubes::TestTeleTubes()
CPPUNIT_ASSERT_MESSAGE( "See README for how to set up test-config.ini",
maTestConfig.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;
}
static void TeleTestTubes_ContactListPrepared( GError *errorOr0, void *user_data )
@@ -135,27 +152,16 @@ static void TeleTestTubes_ContactListPrepared( GError *errorOr0, void *user_data
g_main_loop_quit (self->mpMainLoop);
}
-static gboolean
-timed_out (void *user_data)
+void TestTeleTubes::spinMainLoop()
{
- CPPUNIT_ASSERT( false);
-
- GMainLoop *loop = reinterpret_cast<GMainLoop *>(user_data);
-
- g_main_loop_quit (loop);
- return FALSE;
+ g_main_loop_run( mpMainLoop);
}
void TestTeleTubes::testContactList()
{
- mpMainLoop = g_main_loop_new (NULL, FALSE);
-
ContactList cl;
cl.prepare( TeleTestTubes_ContactListPrepared, this );
- g_timeout_add_seconds (5, timed_out, mpMainLoop);
- g_main_loop_run (mpMainLoop);
- g_main_loop_unref (mpMainLoop);
- mpMainLoop = NULL;
+ spinMainLoop();
/* Okay, now everything's prepared, we can get contacts synchronously. */
AccountContactPairV pairs;