ctkPluginFrameworkPerfRegistryTestSuite.cpp 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. /*=============================================================================
  2. Library: CTK
  3. Copyright (c) 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 "ctkPluginFrameworkPerfRegistryTestSuite_p.h"
  16. #include <ctkPluginContext.h>
  17. #include <ctkHighPrecisionTimer.h>
  18. #undef REGISTERED
  19. #include <ctkServiceEvent.h>
  20. #include <QTest>
  21. #include <QDebug>
  22. //----------------------------------------------------------------------------
  23. ctkPluginFrameworkPerfRegistryTestSuite::ctkPluginFrameworkPerfRegistryTestSuite(ctkPluginContext* context)
  24. : QObject(0)
  25. , pc(context)
  26. , nListeners(100)
  27. , nServices(1000)
  28. , nRegistered(0)
  29. , nUnregistering(0)
  30. , nModified(0)
  31. {
  32. this->setObjectName("ctkPluginFrameworkPerfRegistryTestSuite");
  33. }
  34. //----------------------------------------------------------------------------
  35. void ctkPluginFrameworkPerfRegistryTestSuite::initTestCase()
  36. {
  37. qDebug() << "Initialize event counters";
  38. nRegistered = 0;
  39. nUnregistering = 0;
  40. nModified = 0;
  41. }
  42. //----------------------------------------------------------------------------
  43. void ctkPluginFrameworkPerfRegistryTestSuite::cleanupTestCase()
  44. {
  45. qDebug() << "Remove all service listeners";
  46. for(int i = 0; i < listeners.size(); i++)
  47. {
  48. try
  49. {
  50. ctkServiceListener* l = listeners[i];
  51. pc->disconnectServiceListener(l, "serviceChanged");
  52. }
  53. catch (const ctkException& e)
  54. {
  55. qDebug() << e.printStackTrace();
  56. }
  57. }
  58. listeners.clear();
  59. }
  60. //----------------------------------------------------------------------------
  61. void ctkPluginFrameworkPerfRegistryTestSuite::testAddListeners()
  62. {
  63. addListeners(nListeners);
  64. }
  65. //----------------------------------------------------------------------------
  66. void ctkPluginFrameworkPerfRegistryTestSuite::addListeners(int n)
  67. {
  68. log() << "adding" << n << "service listeners";
  69. for(int i = 0; i < n; i++)
  70. {
  71. ctkServiceListener* l = new ctkServiceListener(this);
  72. try
  73. {
  74. listeners.push_back(l);
  75. pc->connectServiceListener(l, "serviceChanged", "(perf.service.value>=0)");
  76. }
  77. catch (const ctkException& e)
  78. {
  79. qDebug() << e.printStackTrace();
  80. }
  81. }
  82. log() << "listener count=" << listeners.size();
  83. }
  84. //----------------------------------------------------------------------------
  85. void ctkPluginFrameworkPerfRegistryTestSuite::testRegisterServices()
  86. {
  87. qDebug() << "Register services, and check that we get #of services ("
  88. << nServices << ") * #of listeners (" << nListeners << ") REGISTERED events";
  89. log() << "registering" << nServices << "services, listener count=" << listeners.size();
  90. ctkHighPrecisionTimer t;
  91. t.start();
  92. registerServices(nServices);
  93. int ms = t.elapsedMilli();
  94. log() << "register took" << ms << "ms";
  95. QVERIFY2(nServices * listeners.size() == nRegistered,
  96. "# REGISTERED events must be same as # of registered services * # of listeners");
  97. }
  98. //----------------------------------------------------------------------------
  99. void ctkPluginFrameworkPerfRegistryTestSuite::registerServices(int n)
  100. {
  101. QString pid("my.service.%1");
  102. for(int i = 0; i < n; i++)
  103. {
  104. ctkDictionary props;
  105. props.insert("service.pid", pid.arg(i));
  106. props.insert("perf.service.value", i+1);
  107. QObject* service = new PerfTestService();
  108. services.push_back(service);
  109. ctkServiceRegistration reg =
  110. pc->registerService<IPerfTestService>(service, props);
  111. regs.push_back(reg);
  112. }
  113. }
  114. //----------------------------------------------------------------------------
  115. void ctkPluginFrameworkPerfRegistryTestSuite::testModifyServices()
  116. {
  117. qDebug() << "Modify all services, and check that we get #of services ("
  118. << nServices << ") * #of listeners (" << nListeners << ") MODIFIED "
  119. << " events";
  120. ctkHighPrecisionTimer t;
  121. t.start();
  122. modifyServices();
  123. int ms = t.elapsedMilli();
  124. log() << "modify took" << ms << "ms";
  125. QVERIFY2(nServices * listeners.size() == nModified,
  126. "# MODIFIED events must be same as # of modified services * # of listeners");
  127. }
  128. //----------------------------------------------------------------------------
  129. void ctkPluginFrameworkPerfRegistryTestSuite::modifyServices()
  130. {
  131. log() << "modifying " << regs.size() << "services, listener count=" << listeners.size();
  132. for(int i = 0; i < regs.size(); i++)
  133. {
  134. ctkServiceRegistration reg = regs[i];
  135. ctkDictionary props;
  136. props.insert("perf.service.value", i * 2);
  137. reg.setProperties(props);
  138. }
  139. }
  140. //----------------------------------------------------------------------------
  141. void ctkPluginFrameworkPerfRegistryTestSuite::testUnregisterServices()
  142. {
  143. qDebug() << "Unregister all services, and check that we get #of services ("
  144. << nServices << ") * #of listeners (" << nListeners
  145. << ") UNREGISTERING events";
  146. ctkHighPrecisionTimer t;
  147. t.start();
  148. unregisterServices();
  149. int ms = t.elapsedMilli();
  150. log() << "unregister took " << ms << "ms";
  151. QVERIFY2(nServices * listeners.size() == nUnregistering, "# UNREGISTERING events must be same as # of (un)registered services * # of listeners");
  152. }
  153. //----------------------------------------------------------------------------
  154. void ctkPluginFrameworkPerfRegistryTestSuite::unregisterServices()
  155. {
  156. log() << "unregistering " << regs.size() << " services, listener count="
  157. << listeners.size();
  158. for(int i = 0; i < regs.size(); i++)
  159. {
  160. ctkServiceRegistration reg = regs[i];
  161. reg.unregister();
  162. }
  163. regs.clear();
  164. }
  165. //----------------------------------------------------------------------------
  166. ctkServiceListener::ctkServiceListener(ctkPluginFrameworkPerfRegistryTestSuite* ts)
  167. : ts(ts)
  168. {
  169. }
  170. //----------------------------------------------------------------------------
  171. void ctkServiceListener::serviceChanged(const ctkServiceEvent& ev)
  172. {
  173. switch(ev.getType())
  174. {
  175. case ctkServiceEvent::REGISTERED:
  176. ts->nRegistered++;
  177. break;
  178. case ctkServiceEvent::UNREGISTERING:
  179. ts->nUnregistering++;
  180. break;
  181. case ctkServiceEvent::MODIFIED:
  182. ts->nModified++;
  183. break;
  184. default:
  185. break;
  186. }
  187. }