ctkPluginFrameworkTestSuite.cpp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720
  1. /*=============================================================================
  2. Library: CTK
  3. Copyright (c) 2010 German Cancer Research Center,
  4. Division of Medical and Biological Informatics
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #include "ctkPluginFrameworkTestSuite_p.h"
  16. #include <ctkPluginFrameworkTestUtil.h>
  17. #include <ctkPluginContext.h>
  18. #include <ctkPluginConstants.h>
  19. #include <ctkPluginException.h>
  20. #include <ctkServiceException.h>
  21. #include <QTest>
  22. #include <QDebug>
  23. int ctkPluginFrameworkTestSuite::nRunCount = 0;
  24. ctkPluginFrameworkTestSuite::ctkPluginFrameworkTestSuite(ctkPluginContext* pc)
  25. : eventDelay(500), pc(pc), p(pc->getPlugin())
  26. {
  27. }
  28. void ctkPluginFrameworkTestSuite::initTestCase()
  29. {
  30. qDebug() << "### plugin framework test suite: SETUP start";
  31. if (nRunCount > 0)
  32. {
  33. QFAIL("The ctkPluginFrameworkTestSuite CANNOT be run reliably more than once. Other test results in this suite are/may not be valid. Restart framework to retest: CLEANUP:FAIL");
  34. }
  35. ++nRunCount;
  36. try
  37. {
  38. bool success = pc->connectFrameworkListener(this, SLOT(frameworkListener(ctkPluginFrameworkEvent)));
  39. if (!success)
  40. {
  41. QFAIL("plugin framework test suite: SETUP:FAIL");
  42. }
  43. }
  44. catch (const std::logic_error& e)
  45. {
  46. QString msg = QString("plugin framework test suite ") + e.what() + ": SETUP:FAIL";
  47. QFAIL(msg.toAscii());
  48. }
  49. try
  50. {
  51. bool success = pc->connectPluginListener(this, SLOT(pluginListener(ctkPluginEvent)));
  52. if (!success)
  53. {
  54. QFAIL("plugin framework test suite: SETUP:FAIL");
  55. }
  56. }
  57. catch (const std::logic_error& e)
  58. {
  59. QString msg = QString("plugin framework test suite ") + e.what() + ": SETUP:FAIL";
  60. QFAIL(msg.toAscii());
  61. }
  62. try
  63. {
  64. bool success = pc->connectPluginListener(this, SLOT(syncPluginListener(ctkPluginEvent)), Qt::DirectConnection);
  65. if (!success)
  66. {
  67. QFAIL("plugin framework test suite: SETUP:FAIL");
  68. }
  69. }
  70. catch (const std::logic_error& e)
  71. {
  72. QString msg = QString("plugin framework test suite ") + e.what() + ": SETUP:FAIL";
  73. QFAIL(msg.toAscii());
  74. }
  75. try
  76. {
  77. pc->connectServiceListener(this, "serviceListener");
  78. }
  79. catch (const std::logic_error& e)
  80. {
  81. QString msg = QString("plugin framework test suite ") + e.what() + ": SETUP:FAIL";
  82. QFAIL(msg.toAscii());
  83. }
  84. qDebug() << "### plugin framework test suite: SETUP:PASS";
  85. }
  86. void ctkPluginFrameworkTestSuite::cleanupTestCase()
  87. {
  88. }
  89. // Verify information from the getHeaders() method
  90. void ctkPluginFrameworkTestSuite::frame005a()
  91. {
  92. QHash<QString, QString> headers = p->getHeaders();
  93. // check expected headers
  94. QString k = "Plugin-Name";
  95. QCOMPARE(QString("framework_test"), headers.value(k));
  96. k = "Plugin-Version";
  97. QCOMPARE(QString("1.0.1"), headers.value(k));
  98. k = "Plugin-Description";
  99. QCOMPARE(QString("Test bundle for the CTK plugin framework"), headers.value(k));
  100. k = "Plugin-Vendor";
  101. QCOMPARE(QString("CommonTK"), headers.value(k));
  102. k = "Plugin-DocURL";
  103. QCOMPARE(QString("http://www.commontk.org"), headers.value(k));
  104. k = "Plugin-ContactAddress";
  105. QCOMPARE(QString("http://www.commontk.org"), headers.value(k));
  106. k = "Plugin-Category";
  107. QCOMPARE(QString("test"), headers.value(k));
  108. k = "Plugin-Copyright";
  109. QCOMPARE(QString("German Cancer Research Center, Division of Medical and Biological Informatics"), headers.value(k));
  110. k = "Plugin-License";
  111. QCOMPARE(QString("http://www.apache.org/licenses/LICENSE-2.0.html"), headers.value(k));
  112. }
  113. // Extract all information from the getProperty in the ctkPluginContext class
  114. void ctkPluginFrameworkTestSuite::frame007a()
  115. {
  116. QList<QString> NNList;
  117. NNList << ctkPluginConstants::FRAMEWORK_VERSION
  118. << ctkPluginConstants::FRAMEWORK_VENDOR;
  119. foreach(QString k, NNList)
  120. {
  121. QVariant v = pc->getProperty(k);
  122. if(!v.isValid())
  123. {
  124. QString msg("'%1' not set");
  125. QFAIL(qPrintable(msg.arg(k)));
  126. }
  127. }
  128. }
  129. // Get context id, location and status of the plugin
  130. void ctkPluginFrameworkTestSuite::frame010a()
  131. {
  132. qlonglong contextid = p->getPluginId();
  133. qDebug() << "CONTEXT ID:" << contextid;
  134. QString location = p->getLocation();
  135. qDebug() << "LOCATION:" << location;
  136. ctkPlugin::State pstate = p->getState();
  137. qDebug() << "PCACTIVE:" << pstate;
  138. }
  139. //Test result of getServiceReference(). Should throw ctkServiceException
  140. void ctkPluginFrameworkTestSuite::frame018a()
  141. {
  142. try
  143. {
  144. ctkServiceReference ref = pc->getServiceReference("illegalname");
  145. qDebug() << "Got service reference =" << ref << ", excpected ctkServiceException";
  146. QFAIL("Got service reference, excpected NullPointerException");
  147. }
  148. catch (const ctkServiceException& )
  149. {}
  150. catch (...)
  151. {
  152. QFAIL("Got wrong exception, expected ctkServiceException");
  153. }
  154. }
  155. // Load pluginA_test and check that it exists and that its expected service does not exist,
  156. // also check that the expected events in the framework occur
  157. void ctkPluginFrameworkTestSuite::frame020a()
  158. {
  159. pA.clear();
  160. try
  161. {
  162. pA = ctkPluginFrameworkTestUtil::installPlugin(pc, "pluginA_test");
  163. }
  164. catch (ctkPluginException& e)
  165. {
  166. QFAIL(e.what());
  167. }
  168. const QHash<QString, QString> headers = pA->getHeaders();
  169. QHash<QString, QString>::const_iterator iter =
  170. headers.find(ctkPluginConstants::PLUGIN_SYMBOLICNAME);
  171. QVERIFY(iter != headers.end());
  172. QCOMPARE(iter.value(), QString("pluginA.test"));
  173. // Check that no service reference exist yet.
  174. try
  175. {
  176. pc->getServiceReference("org.commontk.TestPluginAService");
  177. QFAIL("framework test plugin, service from test plugin A unexpectedly found");
  178. }
  179. catch (ctkServiceException& /*e*/)
  180. {
  181. }
  182. // check the listeners for events, expect only a plugin event,
  183. // of type installation
  184. bool lStat = checkListenerEvents(false, ctkPluginFrameworkEvent::INFO, true , ctkPluginEvent::INSTALLED,
  185. false, ctkServiceEvent::MODIFIED, pA, 0);
  186. QVERIFY(pA->getState() == ctkPlugin::INSTALLED && lStat == true);
  187. }
  188. // Start pluginA_test and check that it gets state ACTIVE,
  189. // and that the service it registers exist
  190. void ctkPluginFrameworkTestSuite::frame025b()
  191. {
  192. try
  193. {
  194. pA->start();
  195. QVERIFY2(pA->getState() == ctkPlugin::ACTIVE, "pluginA_test should be ACTIVE");
  196. }
  197. catch (const ctkPluginException& pexcA)
  198. {
  199. QString failMsg = QString("Unexpected plugin exception: ") + pexcA.what();
  200. QFAIL(failMsg.toStdString().c_str());
  201. }
  202. catch (const std::logic_error& le)
  203. {
  204. QString failMsg = QString("Start plugin exception: ") + le.what();
  205. QFAIL(failMsg.toStdString().c_str());
  206. }
  207. // Check if pluginA_test registered the expected service
  208. try
  209. {
  210. ctkServiceReference sr1 = pc->getServiceReference("org.commontk.pluginAtest.TestPluginAService");
  211. QObject* o1 = pc->getService(sr1);
  212. QVERIFY2(o1 != 0, "no service object found");
  213. try
  214. {
  215. QVERIFY2(pc->ungetService(sr1), "Service unget should return true");
  216. }
  217. catch (const std::logic_error le)
  218. {
  219. QString failMsg = QString("Unget service exception: ") + le.what();
  220. QFAIL(failMsg.toStdString().c_str());
  221. }
  222. // check the listeners for events
  223. QList<ctkPluginEvent> pEvts;
  224. pEvts.push_back(ctkPluginEvent(ctkPluginEvent::RESOLVED, pA));
  225. pEvts.push_back(ctkPluginEvent(ctkPluginEvent::STARTED, pA));
  226. QList<ctkServiceEvent> seEvts;
  227. seEvts.push_back(ctkServiceEvent(ctkServiceEvent::REGISTERED, sr1));
  228. QVERIFY2(checkListenerEvents(QList<ctkPluginFrameworkEvent>(), pEvts, seEvts),
  229. "Unexpected events");
  230. QList<ctkPluginEvent> syncPEvts;
  231. syncPEvts.push_back(ctkPluginEvent(ctkPluginEvent::STARTING, pA));
  232. QVERIFY2(checkSyncListenerEvents(syncPEvts), "Unexpected events");
  233. }
  234. catch (const ctkServiceException& /*se*/)
  235. {
  236. QFAIL("framework test bundle, expected service not found");
  237. }
  238. }
  239. // Stop pluginA_test and check that it gets state RESOLVED
  240. void ctkPluginFrameworkTestSuite::frame030b()
  241. {
  242. ctkServiceReference sr1
  243. = pc->getServiceReference("org.commontk.pluginAtest.TestPluginAService");
  244. try
  245. {
  246. pA->stop();
  247. QVERIFY2(pA->getState() == ctkPlugin::RESOLVED, "pluginA should be RESOLVED");
  248. QVERIFY(sr1.getPlugin().isNull());
  249. QVERIFY(pc->getService(sr1) == 0);
  250. }
  251. catch (const std::logic_error& ise)
  252. {
  253. qDebug() << "Unexpected logic_error exception:" << ise.what();
  254. QFAIL("framework test plugin, stop plugin pluginA");
  255. }
  256. catch (const ctkPluginException& pe)
  257. {
  258. qDebug() << "Unexpected plugin exception:" << pe;
  259. QFAIL("framework test plugin, stop plugin pluginA");
  260. }
  261. QList<ctkPluginEvent> pEvts;
  262. pEvts << ctkPluginEvent(ctkPluginEvent::STOPPED, pA);
  263. QList<ctkServiceEvent> seEvts;
  264. seEvts << ctkServiceEvent(ctkServiceEvent::UNREGISTERING, sr1);
  265. QVERIFY2(checkListenerEvents(QList<ctkPluginFrameworkEvent>(), pEvts, seEvts),
  266. "Unexpected events");
  267. QList<ctkPluginEvent> syncPEvts;
  268. syncPEvts << ctkPluginEvent(ctkPluginEvent::STOPPING, pA);
  269. QVERIFY2(checkSyncListenerEvents(syncPEvts), "Unexpected events");
  270. }
  271. // Uninstall pluginA_test and check that it gets state UNINSTALLED
  272. void ctkPluginFrameworkTestSuite::frame035b()
  273. {
  274. try
  275. {
  276. pA->uninstall();
  277. QVERIFY2(pA->getState() == ctkPlugin::UNINSTALLED,
  278. "pluginA_test should be UNINSTALLED");
  279. }
  280. catch (const std::logic_error& ise)
  281. {
  282. qDebug() << "Unexpected logic_error exception:" << ise.what();
  283. QFAIL("framework test plugin, uninstall");
  284. }
  285. catch (const ctkPluginException& pe)
  286. {
  287. qDebug() << "Unexpected plugin exception:" << pe;
  288. QFAIL("framework test plugin, uninstall pluginA_test");
  289. }
  290. QList<ctkPluginEvent> pEvts;
  291. pEvts << ctkPluginEvent(ctkPluginEvent::UNRESOLVED, pA);
  292. pEvts << ctkPluginEvent(ctkPluginEvent::UNINSTALLED, pA);
  293. QVERIFY2(checkListenerEvents(QList<ctkPluginFrameworkEvent>(),
  294. pEvts, QList<ctkServiceEvent>()),
  295. "Unexpected events");
  296. QVERIFY2(checkSyncListenerEvents(QList<ctkPluginEvent>()),
  297. "Unexpected sync events");
  298. }
  299. // Install pluginD_test, check that a ctkPluginException is thrown
  300. // as this plugin is not a Qt plugin
  301. void ctkPluginFrameworkTestSuite::frame040a()
  302. {
  303. bool teststatus = true;
  304. bool exception = false;
  305. try
  306. {
  307. pD = ctkPluginFrameworkTestUtil::installPlugin(pc, "pluginD_test");
  308. exception = false;
  309. }
  310. catch (const ctkPluginException& pe)
  311. {
  312. // This exception is expected
  313. qDebug() << "Expected exception" << pe;
  314. exception = true;
  315. }
  316. // catch (SecurityException secA) {
  317. // QFAIL("framework test plugin " + secA + " :FRAME040A:FAIL");
  318. // teststatus = false;
  319. // exception = true;
  320. // }
  321. if (exception == false)
  322. {
  323. teststatus = false;
  324. }
  325. // check the listeners for events, expect no events
  326. bool lStat = checkListenerEvents(false, ctkPluginFrameworkEvent::STARTED,
  327. false , ctkPluginEvent::INSTALLED,
  328. false, ctkServiceEvent::MODIFIED,
  329. pD, 0);
  330. QVERIFY(teststatus == true && pD.isNull() && lStat == true);
  331. }
  332. // Install a non-existent plug-in
  333. void ctkPluginFrameworkTestSuite::frame042a()
  334. {
  335. bool exception = false;
  336. try
  337. {
  338. pc->installPlugin(QUrl("file://no-plugin"));
  339. exception = false;
  340. }
  341. catch (const ctkPluginException& pe)
  342. {
  343. // This exception is expected
  344. qDebug() << "Expected exception" << pe;
  345. exception = true;
  346. }
  347. // check the listeners for events, expect no events
  348. bool lStat = checkListenerEvents(false, ctkPluginFrameworkEvent::STARTED,
  349. false , ctkPluginEvent::INSTALLED,
  350. false, ctkServiceEvent::MODIFIED,
  351. QSharedPointer<ctkPlugin>(), 0);
  352. QVERIFY(exception == true && lStat == true);
  353. }
  354. // Add a service listener with a broken LDAP filter to get an exception
  355. void ctkPluginFrameworkTestSuite::frame045a()
  356. {
  357. ctkServiceListenerPFW sListen1;
  358. QString brokenFilter = "A broken LDAP filter";
  359. try
  360. {
  361. pc->connectServiceListener(&sListen1, "serviceChanged", brokenFilter);
  362. }
  363. catch (const std::invalid_argument& ia)
  364. {
  365. //assertEquals("InvalidSyntaxException.getFilter should be same as input string", brokenFilter, ise.getFilter());
  366. }
  367. catch (...)
  368. {
  369. QFAIL("framework test bundle, wrong exception on broken LDAP filter:");
  370. }
  371. }
  372. void ctkPluginFrameworkTestSuite::frameworkListener(const ctkPluginFrameworkEvent& fwEvent)
  373. {
  374. frameworkEvents.push_back(fwEvent);
  375. qDebug() << "FrameworkEvent:" << fwEvent;
  376. }
  377. void ctkPluginFrameworkTestSuite::pluginListener(const ctkPluginEvent& event)
  378. {
  379. pluginEvents.push_back(event);
  380. qDebug() << "PluginEvent:" << event;
  381. }
  382. void ctkPluginFrameworkTestSuite::syncPluginListener(const ctkPluginEvent& event)
  383. {
  384. if (event.getType() == ctkPluginEvent::STARTING ||
  385. event.getType() == ctkPluginEvent::STOPPING)
  386. {
  387. syncPluginEvents.push_back(event);
  388. qDebug() << "Synchronous PluginEvent:" << event;
  389. }
  390. }
  391. void ctkPluginFrameworkTestSuite::serviceListener(const ctkServiceEvent& event)
  392. {
  393. serviceEvents.push_back(event);
  394. qDebug() << "ServiceEvent:" << event;
  395. }
  396. ctkPluginEvent ctkPluginFrameworkTestSuite::getPluginEvent() const
  397. {
  398. if (pluginEvents.empty())
  399. {
  400. return ctkPluginEvent();
  401. }
  402. return pluginEvents.last();
  403. }
  404. ctkPluginEvent ctkPluginFrameworkTestSuite::getSyncPluginEvent() const
  405. {
  406. if (syncPluginEvents.empty())
  407. {
  408. return ctkPluginEvent();
  409. }
  410. return syncPluginEvents.last();
  411. }
  412. ctkPluginFrameworkEvent ctkPluginFrameworkTestSuite::getFrameworkEvent() const
  413. {
  414. if (frameworkEvents.empty())
  415. {
  416. return ctkPluginFrameworkEvent();
  417. }
  418. return frameworkEvents.last();
  419. }
  420. ctkServiceEvent ctkPluginFrameworkTestSuite::getServiceEvent() const
  421. {
  422. if (serviceEvents.empty())
  423. {
  424. return ctkServiceEvent();
  425. }
  426. return serviceEvents.last();
  427. }
  428. bool ctkPluginFrameworkTestSuite::checkListenerEvents(
  429. bool fwexp, ctkPluginFrameworkEvent::Type fwtype,
  430. bool pexp, ctkPluginEvent::Type ptype,
  431. bool sexp, ctkServiceEvent::Type stype,
  432. QSharedPointer<ctkPlugin> pluginX, ctkServiceReference* servX)
  433. {
  434. QList<ctkPluginFrameworkEvent> fwEvts;
  435. QList<ctkPluginEvent> pEvts;
  436. QList<ctkServiceEvent> seEvts;
  437. if (fwexp) fwEvts << ctkPluginFrameworkEvent(fwtype, pluginX.data());
  438. if (pexp) pEvts << ctkPluginEvent(ptype, pluginX);
  439. if (sexp) seEvts << ctkServiceEvent(stype, *servX);
  440. return checkListenerEvents(fwEvts, pEvts, seEvts);
  441. }
  442. bool ctkPluginFrameworkTestSuite::checkListenerEvents(
  443. const QList<ctkPluginFrameworkEvent>& fwEvts,
  444. const QList<ctkPluginEvent>& pEvts,
  445. const QList<ctkServiceEvent>& seEvts)
  446. {
  447. bool listenState = true; // assume everything will work
  448. // Wait a while to allow events to arrive
  449. QTest::qWait(eventDelay);
  450. //QCoreApplication::sendPostedEvents();
  451. if (fwEvts.size() != frameworkEvents.size())
  452. {
  453. listenState = false;
  454. qDebug() << "*** Plugin Framework event mismatch: expected"
  455. << fwEvts.size() << "event(s), found"
  456. << frameworkEvents.size() << "event(s).";
  457. const int max = fwEvts.size() > frameworkEvents.size()
  458. ? fwEvts.size() : frameworkEvents.size();
  459. for (int i = 0; i < max; ++i)
  460. {
  461. const ctkPluginFrameworkEvent& fwE = i < fwEvts.size() ? fwEvts[i] : ctkPluginFrameworkEvent();
  462. const ctkPluginFrameworkEvent& fwR = i < frameworkEvents.size() ? frameworkEvents[i] : ctkPluginFrameworkEvent();
  463. qDebug() << " " << fwE << " - " << fwR;
  464. }
  465. }
  466. else
  467. {
  468. for (int i = 0; i < fwEvts.size(); ++i)
  469. {
  470. const ctkPluginFrameworkEvent& feE = fwEvts[i];
  471. const ctkPluginFrameworkEvent& feR = frameworkEvents[i];
  472. if (feE.getType() != feR.getType()
  473. || feE.getPlugin() != feR.getPlugin())
  474. {
  475. listenState = false;
  476. qDebug() << "*** Wrong framework event:" << feR
  477. << "expected" << feE;
  478. }
  479. }
  480. }
  481. if (pEvts.size() != pluginEvents.size())
  482. {
  483. listenState = false;
  484. qDebug() << "*** Plugin event mismatch: expected"
  485. << pEvts.size() << "event(s), found "
  486. << pluginEvents.size() << "event(s).";
  487. const int max = pEvts.size() > pluginEvents.size() ? pEvts.size() : pluginEvents.size();
  488. for (int i = 0; i < max; ++i)
  489. {
  490. const ctkPluginEvent& pE = i < pEvts.size() ? pEvts[i] : ctkPluginEvent();
  491. const ctkPluginEvent& pR = i < pluginEvents.size() ? pluginEvents[i] : ctkPluginEvent();
  492. qDebug() << " " << pE << " - " << pR;
  493. }
  494. }
  495. else
  496. {
  497. for (int i = 0; i < pEvts.size(); ++i)
  498. {
  499. const ctkPluginEvent& pE = pEvts[i];
  500. const ctkPluginEvent& pR = pluginEvents[i];
  501. if (pE.getType() != pR.getType()
  502. || pE.getPlugin() != pR.getPlugin())
  503. {
  504. listenState = false;
  505. qDebug() << "*** Wrong plugin event:" << pR << "expected" << pE;
  506. }
  507. }
  508. }
  509. if (seEvts.size() != serviceEvents.size())
  510. {
  511. listenState = false;
  512. qDebug() << "*** Service event mismatch: expected"
  513. << seEvts.size() << "event(s), found"
  514. << serviceEvents.size() << "event(s).";
  515. const int max = seEvts.size() > serviceEvents.size()
  516. ? seEvts.size() : serviceEvents.size();
  517. for (int i = 0; i < max; ++i)
  518. {
  519. const ctkServiceEvent& seE = i < seEvts.size() ? seEvts[i] : ctkServiceEvent();
  520. const ctkServiceEvent& seR = i < serviceEvents.size() ? serviceEvents[i] : ctkServiceEvent();
  521. qDebug() << " " << seE << " - " << seR;
  522. }
  523. }
  524. else
  525. {
  526. for (int i = 0; i < seEvts.size(); ++i)
  527. {
  528. const ctkServiceEvent& seE = seEvts[i];
  529. const ctkServiceEvent& seR = serviceEvents[i];
  530. if (seE.getType() != seR.getType()
  531. || (!(seE.getServiceReference() == seR.getServiceReference())))
  532. {
  533. listenState = false;
  534. qDebug() << "*** Wrong service event:" << seR << "expected" << seE;
  535. }
  536. }
  537. }
  538. frameworkEvents.clear();
  539. pluginEvents.clear();
  540. serviceEvents.clear();
  541. return listenState;
  542. }
  543. // Check that the expected events have reached the listeners and
  544. // reset the events
  545. bool ctkPluginFrameworkTestSuite::checkSyncListenerEvents(
  546. bool pexp, ctkPluginEvent::Type ptype, QSharedPointer<ctkPlugin> pX,
  547. ctkServiceReference servX)
  548. {
  549. Q_UNUSED(servX)
  550. QList<ctkPluginEvent> pEvts;
  551. if (pexp)
  552. {
  553. pEvts << ctkPluginEvent(ptype, pX);
  554. }
  555. return checkSyncListenerEvents(pEvts);
  556. }
  557. // Check that the expected events have reached the listeners and
  558. // reset the events
  559. bool ctkPluginFrameworkTestSuite::checkSyncListenerEvents(
  560. const QList<ctkPluginEvent>& pEvts)
  561. {
  562. bool listenState = true; // assume everything will work
  563. // Sleep a while to allow events to arrive
  564. QTest::qWait(eventDelay);
  565. if (pEvts.size() != syncPluginEvents.size())
  566. {
  567. listenState = false;
  568. qDebug() << "*** Sync plugin event mismatch: expected"
  569. << pEvts.size() << "event(s), found"
  570. << syncPluginEvents.size() << "event(s).";
  571. const int max = pEvts.size() > syncPluginEvents.size() ? pEvts.size() : syncPluginEvents.size();
  572. for (int i = 0; i < max; ++i)
  573. {
  574. const ctkPluginEvent& pE = i< pEvts.size() ? pEvts[i] : ctkPluginEvent();
  575. const ctkPluginEvent& pR = i < syncPluginEvents.size() ? syncPluginEvents[i] : ctkPluginEvent();
  576. qDebug() << " " << pE << " - " << pR;
  577. }
  578. }
  579. else
  580. {
  581. for (int i = 0; i < pEvts.size(); ++i)
  582. {
  583. const ctkPluginEvent& pE = pEvts[i];
  584. const ctkPluginEvent& pR = syncPluginEvents[i];
  585. if (pE.getType() != pR.getType() || pE.getPlugin() != pR.getPlugin())
  586. {
  587. listenState = false;
  588. qDebug() << "Wrong sync plugin event:" << pR << "expected" << pE;
  589. }
  590. }
  591. }
  592. syncPluginEvents.clear();
  593. return listenState;
  594. }
  595. ctkServiceEvent ctkServiceListenerPFW::getEvent() const
  596. {
  597. return events.size() ? events.last() : ctkServiceEvent();
  598. }
  599. QList<ctkServiceEvent> ctkServiceListenerPFW::getEvents() const
  600. {
  601. return events;
  602. }
  603. void ctkServiceListenerPFW::clearEvent()
  604. {
  605. events.clear();
  606. }
  607. void ctkServiceListenerPFW::serviceChanged(const ctkServiceEvent& evt)
  608. {
  609. events.push_back(evt);
  610. qDebug() << "ctkServiceEvent:" << evt;
  611. }