ctkXnatSessionTest.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) 2013 University College London, Centre for Medical Image Computing
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.apache.org/licenses/LICENSE-2.0.txt
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. #include "ctkXnatSessionTest.h"
  15. #include <QCoreApplication>
  16. #include <QDebug>
  17. #include <QDir>
  18. #include <QSignalSpy>
  19. #include <QStringList>
  20. #include <QTest>
  21. #include <QTime>
  22. #include <QTimer>
  23. #include <QUrl>
  24. #include <QUuid>
  25. #include <ctkXnatDataModel.h>
  26. #include <ctkXnatSession.h>
  27. #include <ctkXnatSessionFactory.h>
  28. #include <ctkXnatProject.h>
  29. #include <ctkXnatSubject.h>
  30. class ctkXnatSessionTestCasePrivate
  31. {
  32. public:
  33. ctkXnatSessionFactory* SessionFactory;
  34. ctkXnatSession* Session;
  35. QString ServerUri;
  36. QString UserName;
  37. QString Password;
  38. QString Project;
  39. QString Subject;
  40. QString Experiment;
  41. };
  42. // --------------------------------------------------------------------------
  43. ctkXnatSessionTestCase::ctkXnatSessionTestCase()
  44. : d_ptr(new ctkXnatSessionTestCasePrivate())
  45. {
  46. }
  47. // --------------------------------------------------------------------------
  48. ctkXnatSessionTestCase::~ctkXnatSessionTestCase()
  49. {
  50. }
  51. // --------------------------------------------------------------------------
  52. void ctkXnatSessionTestCase::initTestCase()
  53. {
  54. Q_D(ctkXnatSessionTestCase);
  55. d->ServerUri = "https://central.xnat.org";
  56. d->UserName = "ctk";
  57. d->Password = "ctk";
  58. d->SessionFactory = new ctkXnatSessionFactory();
  59. d->Session = d->SessionFactory->makeConnection(d->ServerUri, d->UserName, d->Password);
  60. d->Session->setProfileName("ctk");
  61. }
  62. void ctkXnatSessionTestCase::cleanupTestCase()
  63. {
  64. Q_D(ctkXnatSessionTestCase);
  65. delete d->Session;
  66. delete d->SessionFactory;
  67. }
  68. void ctkXnatSessionTestCase::testProjectList()
  69. {
  70. Q_D(ctkXnatSessionTestCase);
  71. ctkXnatObject* dataModel = d->Session->dataModel();
  72. dataModel->fetch();
  73. QList<ctkXnatObject*> projects = dataModel->children();
  74. QVERIFY(projects.size() > 0);
  75. }
  76. void ctkXnatSessionTestCase::testResourceUri()
  77. {
  78. Q_D(ctkXnatSessionTestCase);
  79. ctkXnatObject* dataModel = d->Session->dataModel();
  80. QVERIFY(!dataModel->resourceUri().isNull());
  81. QVERIFY(dataModel->resourceUri().isEmpty());
  82. }
  83. void ctkXnatSessionTestCase::testParentChild()
  84. {
  85. Q_D(ctkXnatSessionTestCase);
  86. ctkXnatDataModel* dataModel = d->Session->dataModel();
  87. ctkXnatProject* project = new ctkXnatProject(dataModel);
  88. QVERIFY(project->parent() == dataModel);
  89. QVERIFY(dataModel->children().contains(project));
  90. dataModel->add(project);
  91. int numberOfOccurrences = 0;
  92. foreach (ctkXnatObject* serverProject, dataModel->children())
  93. {
  94. if (serverProject == project || serverProject->id() == project->id())
  95. {
  96. ++numberOfOccurrences;
  97. }
  98. }
  99. QVERIFY(numberOfOccurrences == 1);
  100. dataModel->remove(project);
  101. numberOfOccurrences = 0;
  102. foreach (ctkXnatObject* serverProject, dataModel->children())
  103. {
  104. if (serverProject == project || serverProject->id() == project->id())
  105. {
  106. ++numberOfOccurrences;
  107. }
  108. }
  109. QVERIFY(numberOfOccurrences == 0);
  110. delete project;
  111. }
  112. void ctkXnatSessionTestCase::testCreateProject()
  113. {
  114. Q_D(ctkXnatSessionTestCase);
  115. ctkXnatDataModel* dataModel = d->Session->dataModel();
  116. QString projectId = QString("CTK_") + QUuid::createUuid().toString().mid(1, 8);
  117. d->Project = projectId;
  118. ctkXnatProject* project = new ctkXnatProject(dataModel);
  119. project->setId(projectId);
  120. project->setName(projectId);
  121. project->setDescription("CTK_test_project");
  122. bool exists = d->Session->exists(project);
  123. QVERIFY(!exists);
  124. d->Session->save(project);
  125. exists = d->Session->exists(project);
  126. QVERIFY(exists);
  127. d->Session->remove(project);
  128. exists = d->Session->exists(project);
  129. QVERIFY(!exists);
  130. }
  131. void ctkXnatSessionTestCase::testCreateSubject()
  132. {
  133. Q_D(ctkXnatSessionTestCase);
  134. ctkXnatDataModel* dataModel = d->Session->dataModel();
  135. QString projectId = QString("CTK_") + QUuid::createUuid().toString().mid(1, 8);
  136. d->Project = projectId;
  137. ctkXnatProject* project = new ctkXnatProject(dataModel);
  138. project->setId(projectId);
  139. project->setName(projectId);
  140. project->setDescription("CTK_test_project");
  141. QVERIFY(!project->exists());
  142. project->save();
  143. QVERIFY(project->exists());
  144. ctkXnatSubject* subject = new ctkXnatSubject(project);
  145. QString subjectName = QString("CTK_S") + QUuid::createUuid().toString().mid(1, 8);
  146. subject->setId(subjectName);
  147. subject->setName(subjectName);
  148. subject->save();
  149. QVERIFY(!subject->id().isNull());
  150. subject->erase();
  151. QVERIFY(!subject->exists());
  152. project->erase();
  153. QVERIFY(!project->exists());
  154. }
  155. // --------------------------------------------------------------------------
  156. int ctkXnatSessionTest(int argc, char* argv[])
  157. {
  158. QCoreApplication app(argc, argv);
  159. ctkXnatSessionTestCase test;
  160. return QTest::qExec(&test, argc, argv);
  161. }