1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- // Qt includes
- #include <QApplication>
- #include <QDebug>
- #include <QFileInfo>
- #include <QTreeView>
- #include <QSqlQuery>
- // ctkDICOMCore includes
- #include "ctkDICOMDatabase.h"
- #include "ctkDICOMModel.h"
- #include "ctkModelTester.h"
- // STD includes
- #include <iostream>
- /* Test from build directory:
- ./CTK-build/bin/CTKDICOMCoreCxxTests ctkDICOMModelTest1 test.db ../CTK/Libs/DICOM/Core/Resources/dicom-sample.sql
- */
- int ctkDICOMModelTest1( int argc, char * argv [] )
- {
- QApplication app(argc, argv);
-
- if (argc <= 2)
- {
- std::cerr << "Warning, no sql file given. Test stops" << std::endl;
- std::cerr << "Usage: qctkDICOMModelTest1 <scratch.db> <dumpfile.sql>" << std::endl;
- return EXIT_FAILURE;
- }
-
- try
- {
- ctkDICOMDatabase myCTK( argv[1] );
- if (!myCTK.initializeDatabase(argv[2]))
- {
- std::cerr << "Error when initializing the data base: " << argv[2]
- << " error: " << myCTK.lastError().toStdString();
- }
- /*
- QSqlQuery toto("SELECT PatientsName as 'Name tt' FROM Patients ORDER BY \"Name tt\" ASC", myCTK.database());
- qDebug() << "toto: " << myCTK.lastError() ;
- qDebug()<< toto.seek(0) << myCTK.lastError();
- qDebug() << toto.value(0).toString() << myCTK.lastError();
- QSqlQuery titi("SELECT StudyID as UID, StudyDescription as Name, ModalitiesInStudy as Scan, StudyDate as Date, AccessionNumber as Number, ReferringPhysician as Institution, ReferringPhysician as Referrer, PerformingPysiciansName as Performer FROM Studies WHERE PatientsUID='14'", myCTK.database());
- qDebug() << "titi: " << titi.seek(0) << myCTK.lastError();
- QSqlQuery tata("SELECT SeriesInstanceUID as UID, BodyPartExamined as Scan, SeriesDate as Date, AcquisitionNumber as Number FROM Series WHERE StudyInstanceUID='1.2.826.0.1.3680043.2.1125.1.73379483469717886505187028001198162'", myCTK.database());
- qDebug() << "tata: " << tata.seek(0) << myCTK.lastError();
- QSqlQuery tutu("SELECT SOPInstanceUID as UID, Filename as Name, SeriesInstanceUID as Date FROM Images WHERE SeriesInstanceUID='%1'", myCTK.database());
- qDebug() << "tutu: " << tutu.seek(0) << myCTK.lastError();
- */
- ctkModelTester tester;
- tester.setNestedInserts(true);
- tester.setThrowOnError(false);
- ctkDICOMModel model;
- tester.setModel(&model);
- model.setDatabase(myCTK.database());
- model.setDatabase(QSqlDatabase());
- model.setDatabase(myCTK.database());
- QTreeView viewer;
- viewer.setModel(&model);
- viewer.setSortingEnabled(true);
- model.rowCount();
- qDebug() << model.rowCount() << model.columnCount();
- qDebug() << model.index(0,0);
- viewer.show();
- if (argc > 3 && QString(argv[3]) == "-I")
- {
- return app.exec();
- }
- return EXIT_SUCCESS;
- }
- catch (std::exception e)
- {
- std::cerr << "Error when opening the data base file: " << argv[1]
- << " error: " << e.what();
- return EXIT_FAILURE;
- }
- }
|