summaryrefslogtreecommitdiffstats
path: root/store/test
diff options
context:
space:
mode:
Diffstat (limited to 'store/test')
-rw-r--r--store/test/CMakeLists.txt21
-rw-r--r--store/test/calendar.fbs12
-rw-r--r--store/test/storagebenchmark.cpp157
3 files changed, 0 insertions, 190 deletions
diff --git a/store/test/CMakeLists.txt b/store/test/CMakeLists.txt
deleted file mode 100644
index 1b9dc9e..0000000
--- a/store/test/CMakeLists.txt
+++ /dev/null
@@ -1,21 +0,0 @@
1set(CMAKE_AUTOMOC ON)
2include_directories(${CMAKE_CURRENT_BINARY_DIR})
3
4set(store_path "../")
5set(store_SRCS
6 ${store_path}/database.cpp
7)
8
9generate_flatbuffers(calendar)
10
11macro(manual_tests)
12 foreach(_testname ${ARGN})
13 add_executable(${_testname} ${_testname}.cpp ${store_SRCS})
14 qt5_use_modules(${_testname} Core Test)
15 target_link_libraries(${_testname} kyotocabinet)
16 endforeach(_testname)
17endmacro(auto_tests)
18
19manual_tests (
20 storagebenchmark
21)
diff --git a/store/test/calendar.fbs b/store/test/calendar.fbs
deleted file mode 100644
index 203ee43..0000000
--- a/store/test/calendar.fbs
+++ /dev/null
@@ -1,12 +0,0 @@
1// example IDL file
2
3namespace Calendar;
4
5table Event {
6 summary:string;
7 description:string;
8 attachment:[byte];
9}
10
11root_type Event;
12file_identifier "AKFB";
diff --git a/store/test/storagebenchmark.cpp b/store/test/storagebenchmark.cpp
deleted file mode 100644
index d42dea8..0000000
--- a/store/test/storagebenchmark.cpp
+++ /dev/null
@@ -1,157 +0,0 @@
1#include <QtTest>
2
3#include "calendar_generated.h"
4
5#include <iostream>
6#include <fstream>
7
8#include <QDebug>
9#include <QDir>
10#include <QString>
11#include <QTime>
12
13#include "store/database.h"
14
15using namespace Calendar;
16using namespace flatbuffers;
17
18static std::string createEvent()
19{
20 FlatBufferBuilder fbb;
21 {
22 auto summary = fbb.CreateString("summary");
23
24 const int attachmentSize = 1024*2; // 2KB
25 int8_t rawData[attachmentSize];
26 auto data = fbb.CreateVector(rawData, attachmentSize);
27
28 Calendar::EventBuilder eventBuilder(fbb);
29 eventBuilder.add_summary(summary);
30 eventBuilder.add_attachment(data);
31 auto eventLocation = eventBuilder.Finish();
32 FinishEventBuffer(fbb, eventLocation);
33 }
34 return std::string(reinterpret_cast<const char *>(fbb.GetBufferPointer()), fbb.GetSize());
35}
36
37// static void readEvent(const std::string &data)
38// {
39// auto readEvent = GetEvent(data.c_str());
40// std::cout << readEvent->summary()->c_str() << std::endl;
41// }
42
43class StorageBenchmark : public QObject
44{
45 Q_OBJECT
46private:
47 //This should point to a directory on disk and not a ramdisk (since we're measuring performance)
48 QString testDataPath;
49 QString dbName;
50 QString filePath;
51 const int count = 50000;
52
53private Q_SLOTS:
54 void initTestCase()
55 {
56 testDataPath = "./testdb";
57 dbName = "test";
58 filePath = testDataPath + "buffer.fb";
59 }
60
61 void testWriteRead_data()
62 {
63 QTest::addColumn<bool>("useDb");
64 QTest::addColumn<int>("count");
65
66 QTest::newRow("db, 50k") << true << count;
67 QTest::newRow("file, 50k") << false << count;
68 }
69
70 void testWriteRead()
71 {
72 QFETCH(bool, useDb);
73 QFETCH(int, count);
74
75 Database *db = 0;
76 if (useDb) {
77 db = new Database(testDataPath, dbName);
78 }
79
80 std::ofstream myfile;
81 myfile.open(filePath.toStdString());
82 const char *keyPrefix = "key";
83
84 QTime time;
85
86 time.start();
87 {
88 auto event = createEvent();
89 for (int i = 0; i < count; i++) {
90 if (db) {
91 if (i % 10000 == 0) {
92 if (i > 0) {
93 db->commitTransaction();
94 }
95 db->startTransaction();
96 }
97
98 db->write(keyPrefix + std::to_string(i), event);
99 } else {
100 myfile << event;
101 }
102 }
103
104 if (db) {
105 db->commitTransaction();
106 } else {
107 myfile.close();
108 }
109 }
110 const int writeDuration = time.restart();
111 qDebug() << "Writing took[ms]: " << writeDuration;
112
113 {
114 for (int i = 0; i < count; i++) {
115 if (db) {
116 db->read(keyPrefix + std::to_string(i), [](std::string value){});
117 }
118 }
119 }
120 const int readDuration = time.restart();
121
122 if (db) {
123 qDebug() << "Reading took[ms]: " << readDuration;
124 } else {
125 qDebug() << "File reading is not implemented.";
126 }
127
128 delete db;
129 }
130
131 void testBufferCreation()
132 {
133 QTime time;
134
135 time.start();
136 {
137 for (int i = 0; i < count; i++) {
138 auto event = createEvent();
139 }
140 }
141 const int bufferDuration = time.elapsed();
142 qDebug() << "Creating buffers took[ms]: " << bufferDuration;
143 }
144
145 void testSizes()
146 {
147 Database db(testDataPath, dbName);
148 qDebug() << "Database size [kb]: " << db.diskUsage()/1024;
149 db.removeFromDisk();
150
151 QFileInfo fileInfo(filePath);
152 qDebug() << "File size [kb]: " << fileInfo.size()/1024;
153 }
154};
155
156QTEST_MAIN(StorageBenchmark)
157#include "storagebenchmark.moc"