summaryrefslogtreecommitdiff
path: root/postprocess/qa/services.cxx
diff options
context:
space:
mode:
authorChris Sherlock <chris.sherlock79@gmail.com>2014-04-05 00:36:03 +1100
committerChris Sherlock <chris.sherlock79@gmail.com>2014-04-04 08:53:05 -0500
commitc05ef7eeb1c6d5f797103e9edda3896f8eb87536 (patch)
treed14d3aaa0b6c2d14561e2ca4fa44cf654d84b7df /postprocess/qa/services.cxx
parent32f301f5a64d8ff7815cf88858fc8a87cb9ad76a (diff)
Make service unit test easier to debug
It's sort of hard to break into this function with gdb. Seperating it out makes it a lot easier to work out where things are breaking. Change-Id: If99effd44fe677452ac3c1012b99da7da80c720e Reviewed-on: https://gerrit.libreoffice.org/8844 Reviewed-by: Chris Sherlock <chris.sherlock79@gmail.com> Tested-by: Chris Sherlock <chris.sherlock79@gmail.com>
Diffstat (limited to 'postprocess/qa/services.cxx')
-rw-r--r--postprocess/qa/services.cxx24
1 files changed, 13 insertions, 11 deletions
diff --git a/postprocess/qa/services.cxx b/postprocess/qa/services.cxx
index 654a9ef032bd..680ad637686f 100644
--- a/postprocess/qa/services.cxx
+++ b/postprocess/qa/services.cxx
@@ -48,7 +48,7 @@ void ServicesTest::test()
}
SAL_WARN(
"postprocess.cppunit",
- "trying \"" << s[i] << "\"");
+ "trying (index: " << i << ") \"" << s[i] << "\"");
Reference< XServiceTypeDescription2 > xDesc(
xTypeManager->getByHierarchicalName(s[i]), UNO_QUERY_THROW);
Sequence< Reference< XServiceConstructorDescription > > xseq = xDesc->getConstructors();
@@ -56,16 +56,18 @@ void ServicesTest::test()
if (!xseq[c]->getParameters().hasElements())
try
{
- CPPUNIT_ASSERT_MESSAGE(
- OUStringToOString(s[i], RTL_TEXTENCODING_UTF8).getStr(),
- ((xseq[c]->isDefaultConstructor()
- ? (m_xContext->getServiceManager()
- ->createInstanceWithContext(s[i], m_xContext))
- : (m_xContext->getServiceManager()
- ->createInstanceWithArgumentsAndContext(
- s[i], css::uno::Sequence<css::uno::Any>(),
- m_xContext)))
- .is()));
+ OString message = OUStringToOString(s[i], RTL_TEXTENCODING_UTF8);
+ sal_Bool bDefConstructor = xseq[c]->isDefaultConstructor();
+ Reference< css::lang::XMultiComponentFactory > serviceManager = m_xContext->getServiceManager();
+ Reference< XInterface > instance;
+
+ if( bDefConstructor )
+ instance = serviceManager->createInstanceWithContext(s[i], m_xContext);
+ else
+ instance = serviceManager->createInstanceWithArgumentsAndContext(
+ s[i], css::uno::Sequence<css::uno::Any>(), m_xContext);
+
+ CPPUNIT_ASSERT_MESSAGE( message.getStr(), instance.is() );
}
catch(const Exception & e)
{