ctkDICOMDatabaseTest1.cpp 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. // Qt includes
  2. #include <QApplication>
  3. #include <QDir>
  4. #include <QTimer>
  5. // ctkDICOMCore includes
  6. #include "ctkDICOMDatabase.h"
  7. // STD includes
  8. #include <iostream>
  9. int ctkDICOMDatabaseTest1( int argc, char * argv [] )
  10. {
  11. QApplication app(argc, argv);
  12. ctkDICOMDatabase database;
  13. QDir databaseDirectory = QDir::temp();
  14. QFileInfo databaseFile(databaseDirectory, QString("database.test"));
  15. database.openDatabase(databaseFile.absoluteFilePath());
  16. if (!database.lastError().isEmpty())
  17. {
  18. std::cerr << "ctkDICOMDatabase::openDatabase() failed: "
  19. << qPrintable(database.lastError()) << std::endl;
  20. return EXIT_FAILURE;
  21. }
  22. if (!database.database().isValid())
  23. {
  24. std::cerr << "ctkDICOMDatabase::openDatabase() failed: "
  25. << "invalid sql database" << std::endl;
  26. return EXIT_FAILURE;
  27. }
  28. if (database.isInMemory())
  29. {
  30. std::cerr << "ctkDICOMDatabase::openDatabase() failed: "
  31. << "database should not be in memory" << std::endl;
  32. return EXIT_FAILURE;
  33. }
  34. if (database.databaseFilename() != databaseFile.absoluteFilePath())
  35. {
  36. std::cerr << "ctkDICOMDatabase::databaseFilename() failed: "
  37. << qPrintable( database.databaseFilename()) << std::endl;
  38. return EXIT_FAILURE;
  39. }
  40. if (QDir(database.databaseDirectory()) != databaseDirectory)
  41. {
  42. std::cerr << "ctkDICOMDatabase::databaseDirectory() failed"
  43. << qPrintable(database.databaseDirectory()) << std::endl;
  44. return EXIT_FAILURE;
  45. }
  46. bool res = database.initializeDatabase();
  47. if (!res)
  48. {
  49. std::cerr << "ctkDICOMDatabase::initializeDatabase() failed." << std::endl;
  50. return EXIT_FAILURE;
  51. }
  52. // check if it doesn't crash
  53. database.pathForDataset(0);
  54. database.insert(0, true, true);
  55. database.insert(0, true, false);
  56. database.insert(0, false, false);
  57. database.insert(0, false, true);
  58. database.closeDatabase();
  59. database.initializeDatabase();
  60. if (argc <= 1 || QString(argv[1]) != "-I")
  61. {
  62. QTimer::singleShot(200, &app, SLOT(quit()));
  63. }
  64. return app.exec();
  65. }