Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/owncloud/client.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJocelyn Turcotte <jturcotte@woboq.com>2016-03-30 18:58:15 +0300
committerJocelyn Turcotte <jturcotte@woboq.com>2016-03-30 19:00:22 +0300
commitf42795551235568ecf4c82514c2175164d24c64a (patch)
tree6808373e2a9e5ba055a8b35a9260bc268af86285 /test/testsyncjournaldb.cpp
parentdd8b0c3e4a3263b936c2a860fe0bb2d592613802 (diff)
Simplify the build of auto tests
Remove all configure_files: - Move all tests to cpp files - Use the QTEST_MAIN macro instead of a generated main.cpp - Include test*.moc in the cpp to let CMAKE_AUTOMOC call moc - Pass info through add_definitions instead of generating oc_bin.h with them This makes sure that build errors points to the original test source file instead of the generated one in the build directory to be able to jump and fix errors directly from the IDE's error pane.
Diffstat (limited to 'test/testsyncjournaldb.cpp')
-rw-r--r--test/testsyncjournaldb.cpp175
1 files changed, 175 insertions, 0 deletions
diff --git a/test/testsyncjournaldb.cpp b/test/testsyncjournaldb.cpp
new file mode 100644
index 000000000..9bfce3b54
--- /dev/null
+++ b/test/testsyncjournaldb.cpp
@@ -0,0 +1,175 @@
+/*
+ * 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_MAIN(TestSyncJournalDB)
+#include "testsyncjournaldb.moc"