| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- /*
- * This software is in the public domain, furnished "as is", without technical
- * support, and with no warranty, express or implied, as to its usefulness for
- * any purpose.
- * */
- #include <QtTest>
- #include <sqlite3.h>
- #include "libsync/syncjournaldb.h"
- #include "libsync/syncjournalfilerecord.h"
- using namespace OCC;
- namespace {
- const char testdbC[] = "/tmp";
- }
- class TestSyncJournalDB : public QObject
- {
- Q_OBJECT
- public:
- TestSyncJournalDB()
- : _db(testdbC)
- {
- }
- QDateTime dropMsecs(QDateTime time)
- {
- return Utility::qDateTimeFromTime_t(Utility::qDateTimeToTime_t(time));
- }
- private slots:
- void initTestCase()
- {
- }
- void cleanupTestCase()
- {
- }
- void testFileRecord()
- {
- SyncJournalFileRecord record = _db.getFileRecord("nonexistant");
- QVERIFY(!record.isValid());
- record._path = "foo";
- record._inode = 1234;
- record._modtime = dropMsecs(QDateTime::currentDateTime());
- record._type = 5;
- record._etag = "789789";
- record._fileId = "abcd";
- record._remotePerm = "744";
- record._fileSize = 213089055;
- record._contentChecksum = "mychecksum";
- record._contentChecksumType = "MD5";
- QVERIFY(_db.setFileRecord(record));
- SyncJournalFileRecord storedRecord = _db.getFileRecord("foo");
- QVERIFY(storedRecord == record);
- // Update checksum
- record._contentChecksum = "newchecksum";
- record._contentChecksumType = "Adler32";
- _db.updateFileRecordChecksum("foo", record._contentChecksum, record._contentChecksumType);
- storedRecord = _db.getFileRecord("foo");
- QVERIFY(storedRecord == record);
- // Update metadata
- record._inode = 12345;
- record._modtime = dropMsecs(QDateTime::currentDateTime().addDays(1));
- record._type = 7;
- record._etag = "789FFF";
- record._fileId = "efg";
- record._remotePerm = "777";
- record._fileSize = 289055;
- _db.setFileRecordMetadata(record);
- storedRecord = _db.getFileRecord("foo");
- QVERIFY(storedRecord == record);
- QVERIFY(_db.deleteFileRecord("foo"));
- record = _db.getFileRecord("foo");
- QVERIFY(!record.isValid());
- }
- void testFileRecordChecksum()
- {
- // Try with and without a checksum
- {
- SyncJournalFileRecord record;
- record._path = "foo-checksum";
- record._remotePerm = "744";
- record._contentChecksum = "mychecksum";
- record._contentChecksumType = "MD5";
- record._modtime = QDateTime::currentDateTimeUtc();
- QVERIFY(_db.setFileRecord(record));
- SyncJournalFileRecord storedRecord = _db.getFileRecord("foo-checksum");
- QVERIFY(storedRecord._path == record._path);
- QVERIFY(storedRecord._remotePerm == record._remotePerm);
- QVERIFY(storedRecord._contentChecksum == record._contentChecksum);
- QVERIFY(storedRecord._contentChecksumType == record._contentChecksumType);
- // qDebug()<< "OOOOO " << storedRecord._modtime.toTime_t() << record._modtime.toTime_t();
- // Attention: compare time_t types here, as QDateTime seem to maintain
- // milliseconds internally, which disappear in sqlite. Go for full seconds here.
- QVERIFY(storedRecord._modtime.toTime_t() == record._modtime.toTime_t());
- QVERIFY(storedRecord == record);
- }
- {
- SyncJournalFileRecord record;
- record._path = "foo-nochecksum";
- record._remotePerm = "744";
- record._modtime = QDateTime::currentDateTimeUtc();
- QVERIFY(_db.setFileRecord(record));
- SyncJournalFileRecord storedRecord = _db.getFileRecord("foo-nochecksum");
- QVERIFY(storedRecord == record);
- }
- }
- void testDownloadInfo()
- {
- typedef SyncJournalDb::DownloadInfo Info;
- Info record = _db.getDownloadInfo("nonexistant");
- QVERIFY(!record._valid);
- record._errorCount = 5;
- record._etag = "ABCDEF";
- record._valid = true;
- record._tmpfile = "/tmp/foo";
- _db.setDownloadInfo("foo", record);
- Info storedRecord = _db.getDownloadInfo("foo");
- QVERIFY(storedRecord == record);
- _db.setDownloadInfo("foo", Info());
- Info wipedRecord = _db.getDownloadInfo("foo");
- QVERIFY(!wipedRecord._valid);
- }
- void testUploadInfo()
- {
- typedef SyncJournalDb::UploadInfo Info;
- Info record = _db.getUploadInfo("nonexistant");
- QVERIFY(!record._valid);
- record._errorCount = 5;
- record._chunk = 12;
- record._transferid = 812974891;
- record._size = 12894789147;
- record._modtime = dropMsecs(QDateTime::currentDateTime());
- record._valid = true;
- _db.setUploadInfo("foo", record);
- Info storedRecord = _db.getUploadInfo("foo");
- QVERIFY(storedRecord == record);
- _db.setUploadInfo("foo", Info());
- Info wipedRecord = _db.getUploadInfo("foo");
- QVERIFY(!wipedRecord._valid);
- }
- private:
- SyncJournalDb _db;
- };
- QTEST_APPLESS_MAIN(TestSyncJournalDB)
- #include "testsyncjournaldb.moc"
|