some bugs fixed, test written, version() added

This commit is contained in:
romixlab
2014-09-26 22:03:24 +04:00
parent 93f45f9b0b
commit c07318c325
22 changed files with 562 additions and 333 deletions

View File

@@ -8,4 +8,8 @@ if (Qt5Core_FOUND)
set(TEST_LIBRARIES ${Qt5Test_LIBRARIES})
endif ()
add_subdirectory(pack)
set(TEST_SUBDIRS pack unpack mixed)
foreach(subdir ${TEST_SUBDIRS})
add_subdirectory(${subdir})
endforeach()

View File

@@ -0,0 +1,24 @@
set(QT_USE_QTTEST TRUE)
if (NOT Qt5Core_FOUND)
include( ${QT_USE_FILE} )
endif()
include(AddFileDependencies)
include_directories(../../src ${CMAKE_CURRENT_BINARY_DIR})
set(UNIT_TESTS mixed_test)
foreach(test ${UNIT_TESTS})
message(status "Building ${test}")
add_executable(${test} ${test}.cpp)
target_link_libraries(${test}
${QT_LIBRARIES}
${TEST_LIBRARIES}
qmsgpack
)
add_test(${test} ${test})
endforeach()

22
tests/mixed/mixed.pro Normal file
View File

@@ -0,0 +1,22 @@
#-------------------------------------------------
#
# Project created by QtCreator 2014-09-26T19:10:31
#
#-------------------------------------------------
QT += testlib
QT -= gui
TARGET = mixed_test
CONFIG += console
CONFIG -= app_bundle
TEMPLATE = app
INCLUDEPATH += ../../src
LIBS += -lqmsgpack
SOURCES += mixed_test.cpp
DEFINES += SRCDIR=\\\"$$PWD/\\\"

239
tests/mixed/mixed_test.cpp Normal file
View File

@@ -0,0 +1,239 @@
#include <QString>
#include <QtTest>
#include <msgpack.h>
#include <QDebug>
class MixedTest : public QObject
{
Q_OBJECT
private Q_SLOTS:
void test_map();
void test_ext();
void test_mixed();
};
void MixedTest::test_map()
{
QVariantMap map;
map.insert(QString("%1").QString::arg(0, 5), "v");
QByteArray arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 1);
quint8 *p = (quint8 *)arr.data();
QVERIFY(p[0] == (0x80 | map.size()));
QVariantMap m2 = MsgPack::unpack(arr).toMap();
QVERIFY(m2 == map);
for (int i = 1; i < 16; ++i)
map.insert(QString("%1").QString::arg(i, 5), "v");
arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 3);
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xde);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x10);
m2 = MsgPack::unpack(arr).toMap();
QVERIFY(m2 == map);
for (int i = 16; i < 65536; ++i)
map.insert(QString("%1").QString::arg(i, 5), "v");
arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 5);
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xdf);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x01);
QVERIFY(p[3] == 0x00);
QVERIFY(p[4] == 0x00);
m2 = MsgPack::unpack(arr).toMap();
QVERIFY(m2 == map);
}
class CustomType
{
public:
CustomType() {}
CustomType(const CustomType &other) { m_size = other.m_size; }
~CustomType() {}
CustomType(int size) : m_size(size) {}
int size() { return m_size; }
void setSize(int size) { m_size = size; }
private:
int m_size;
};
Q_DECLARE_METATYPE(CustomType)
quint32 pack_custom_type(const QVariant &variant, QByteArray &data, bool write)
{
CustomType ct = variant.value<CustomType>();
if (write) {
data.resize(ct.size());
quint8 *p = (quint8 *)data.data();
for (int i = 0; i < ct.size(); ++i)
p[i] = 7;
}
return ct.size();
}
QVariant unpack_custom_type(const QByteArray &data)
{
return data;
}
void MixedTest::test_ext()
{
CustomType ct(1);
QVariant custom;
custom.setValue(ct);
MsgPack::registerPacker((QMetaType::Type)qMetaTypeId<CustomType>(),
3, pack_custom_type);
MsgPack::registerUnpacker(3, unpack_custom_type);
QByteArray arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
quint8 *p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd4);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
QByteArray ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(2);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd5);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
QVERIFY(p[3] == 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(4);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd6);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
QVERIFY(p[3] == 0x07);
QVERIFY(p[4] == 0x07);
QVERIFY(p[5] == 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(8);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd7);
QVERIFY(p[1] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[2 + i] = 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(16);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd8);
QVERIFY(p[1] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[2 + i] = 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(3);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 3 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc7);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[3 + i] = 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(256);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 4 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc8);
QVERIFY(p[1] == 0x01);
QVERIFY(p[2] == 0x00);
QVERIFY(p[3] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[4 + i] = 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
ct.setSize(65536);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 6 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc9);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x01);
QVERIFY(p[3] == 0x00);
QVERIFY(p[4] == 0x00);
QVERIFY(p[5] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[6 + i] = 0x07);
ub = MsgPack::unpack(arr).toByteArray();
QVERIFY(ub.size() == ct.size());
for (int i = 0; i < ub.size(); ++i)
QVERIFY(ub.data()[i] == 7);
}
void MixedTest::test_mixed()
{
QVariantMap map;
map["booleans"] = QVariantList() << false << true;
map["list2"] = QVariantList() << (QVariantList() << "abc" << "def")
<< (QVariantList() << "qwe" << "rty");
map["integers"] = QVariantList() << 0 << 127 << -31 << 128 << 777;
map["bytearray"] = QByteArray("bytes");
QVariantMap map2;
map2["one"] = 1;
map2["two"] = QVariantMap();
map["map2"] = map2;
QByteArray arr = MsgPack::pack(map);
QVariant unpacked = MsgPack::unpack(arr);
QVERIFY(unpacked.toMap() == map);
}
QTEST_APPLESS_MAIN(MixedTest)
#include "mixed_test.moc"

View File

@@ -19,9 +19,6 @@ private Q_SLOTS:
void test_str();
void test_bin();
void test_array();
void test_map();
void test_ext();
void test_mixed();
};
void PackTest::test_bool()
@@ -316,180 +313,6 @@ void PackTest::test_array()
QVERIFY(p[4] == 0x00);
}
void PackTest::test_map()
{
QVariantMap map;
map.insert(QString("%1").QString::arg(0, 5), "v");
QByteArray arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 1);
quint8 *p = (quint8 *)arr.data();
QVERIFY(p[0] == (0x80 | map.size()));
for (int i = 1; i < 16; ++i)
map.insert(QString("%1").QString::arg(i, 5), "v");
arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 3);
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xde);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x10);
for (int i = 16; i < 65536; ++i)
map.insert(QString("%1").QString::arg(i, 5), "v");
arr = MsgPack::pack(map);
QVERIFY(arr.size() == map.size() * 8 + 5);
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xdf);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x01);
QVERIFY(p[3] == 0x00);
QVERIFY(p[4] == 0x00);
}
class CustomType
{
public:
CustomType() {}
CustomType(const CustomType &other) { m_size = other.m_size; }
~CustomType() {}
CustomType(int size) : m_size(size) {}
int size() { return m_size; }
void setSize(int size) { m_size = size; }
private:
int m_size;
};
Q_DECLARE_METATYPE(CustomType)
quint32 pack_custom_type(const QVariant &variant, QByteArray &data, bool write)
{
CustomType ct = variant.value<CustomType>();
if (write) {
data.resize(ct.size());
quint8 *p = (quint8 *)data.data();
for (int i = 0; i < ct.size(); ++i)
p[i] = 7;
}
return ct.size();
}
void PackTest::test_ext()
{
CustomType ct(1);
QVariant custom;
custom.setValue(ct);
MsgPack::registerPacker((QMetaType::Type)qMetaTypeId<CustomType>(),
3, pack_custom_type);
QByteArray arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
quint8 *p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd4);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
ct.setSize(2);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd5);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
QVERIFY(p[3] == 0x07);
ct.setSize(4);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd6);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x07);
QVERIFY(p[3] == 0x07);
QVERIFY(p[4] == 0x07);
QVERIFY(p[5] == 0x07);
ct.setSize(8);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd7);
QVERIFY(p[1] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[2 + i] = 0x07);
ct.setSize(16);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 2 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xd8);
QVERIFY(p[1] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[2 + i] = 0x07);
ct.setSize(3);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 3 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc7);
QVERIFY(p[1] == 0x03);
QVERIFY(p[2] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[3 + i] = 0x07);
ct.setSize(256);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 4 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc8);
QVERIFY(p[1] == 0x01);
QVERIFY(p[2] == 0x00);
QVERIFY(p[3] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[4 + i] = 0x07);
ct.setSize(65536);
custom.setValue(ct);
arr = MsgPack::pack(custom);
QVERIFY(arr.size() == 6 + ct.size());
p = (quint8 *)arr.data();
QVERIFY(p[0] == 0xc9);
QVERIFY(p[1] == 0x00);
QVERIFY(p[2] == 0x01);
QVERIFY(p[3] == 0x00);
QVERIFY(p[4] == 0x00);
QVERIFY(p[5] == 0x03);
for (int i = 0; i < ct.size(); ++i)
QVERIFY(p[6 + i] = 0x07);
}
void PackTest::test_mixed()
{
QVariantMap map;
// map["booleans"] = QVariantList() << false << true;
// map["list2"] = QVariantList() << (QVariantList() << "abc" << "def")
// << (QVariantList() << "qwe" << "rty");
// map["integers"] = QVariantList() << 0 << 127 << -31 << 128 << 777;
map["bytearray"] = QByteArray("bytes");
// QVariantMap map2;
// map2["one"] = 1;
// map2["two"] = QVariantMap();
// map["map2"] = map2;
QByteArray arr = MsgPack::pack(map);
qDebug() << arr.toBase64();
}
QTEST_APPLESS_MAIN(PackTest)
#include "pack_test.moc"

View File

@@ -0,0 +1,24 @@
set(QT_USE_QTTEST TRUE)
if (NOT Qt5Core_FOUND)
include( ${QT_USE_FILE} )
endif()
include(AddFileDependencies)
include_directories(../../src ${CMAKE_CURRENT_BINARY_DIR})
set(UNIT_TESTS unpack_test)
foreach(test ${UNIT_TESTS})
message(status "Building ${test}")
add_executable(${test} ${test}.cpp)
target_link_libraries(${test}
${QT_LIBRARIES}
${TEST_LIBRARIES}
qmsgpack
)
add_test(${test} ${test})
endforeach()

21
tests/unpack/unpack.pro Normal file
View File

@@ -0,0 +1,21 @@
#-------------------------------------------------
#
# Project created by QtCreator 2014-09-25T10:25:22
#
#-------------------------------------------------
QT += testlib
QT -= gui
TARGET = unpack_test
CONFIG += console
CONFIG -= app_bundle
TEMPLATE = app
LIBS += -lqmsgpack
INCLUDEPATH += ../../src
SOURCES += unpack_test.cpp
DEFINES += SRCDIR=\\\"$$PWD/\\\"

View File

@@ -0,0 +1,145 @@
#include <QString>
#include <QtTest>
#include <QDebug>
#include <msgpack.h>
#include <limits>
class UnpackTest : public QObject
{
Q_OBJECT
private Q_SLOTS:
void test_booleans();
void test_integers();
void test_floats();
void test_strings();
void test_binary();
void test_array();
};
void UnpackTest::test_booleans()
{
QByteArray pack = MsgPack::pack(QVariantList() << true << false);
QVariantList u = MsgPack::unpack(pack).toList();
QVERIFY(u[0] == true);
QVERIFY(u[1] == false);
}
void UnpackTest::test_integers()
{
QByteArray ints = QByteArray::fromBase64("3AAUAH//4cyAzP/Q39CAzQEAzf//0f9/"
"0YAAzgABAADO/////9L//3//0oAAAADP"
"AAAAAQAAAADP///////////T/////3//"
"///TgAAAAAAAAAA=");
QVariantList l = MsgPack::unpack(ints).toList();
QVERIFY(l[0].toInt() == 0);
QVERIFY(l[1].toInt() == 127);
QVERIFY(l[2].toInt() == -1);
QVERIFY(l[3].toInt() == -31);
QVERIFY(l[4].toInt() == 128);
QVERIFY(l[5].toInt() == 255);
QVERIFY(l[6].toInt() == -33);
QVERIFY(l[7].toInt() == -128);
QVERIFY(l[8].toInt() == 256);
QVERIFY(l[9].toInt() == 65535);
QVERIFY(l[10].toInt() == -129);
QVERIFY(l[11].toInt() == -32768);
QVERIFY(l[12].toInt() == 65536);
QVERIFY(l[13].toUInt() == 4294967295);
QVERIFY(l[14].toInt() == -32769);
QVERIFY(l[15].toInt() == -2147483648);
QVERIFY(l[16].toLongLong() == 4294967296);
QVERIFY(l[17].toULongLong() == std::numeric_limits<quint64>::max());
QVERIFY(l[18].toLongLong() == -2147483649);
QVERIFY(l[19].toLongLong() == std::numeric_limits<qint64>::min());
}
void UnpackTest::test_floats()
{
QByteArray packed = QByteArray::fromBase64("k8sAAAAAAAAAAMtAHTMzMzMzM8tHM"
"0JhcsdNgg==");
QVariantList l = MsgPack::unpack(packed).toList();
QVERIFY(l[0].toDouble() == 0.0);
QVERIFY(l[1].toDouble() == 7.3);
QVERIFY(l[2].toDouble() == pow(10, 35));
}
void UnpackTest::test_strings()
{
QStringList strs;
strs << "abc";
QString s;
for (int i = 0; i < 8; ++i)
s += "xy";
strs << s;
s = QString();
for (int i = 0; i < 64; ++i)
s += "msgp";
strs << s;
s = QString();
for (int i = 0; i < 4096; ++i)
s += "messagepack test";
strs << s;
strs << "";
QByteArray arr = MsgPack::pack(strs);
QStringList l = MsgPack::unpack(arr).toStringList();
QVERIFY(l[0] == strs[0]);
QVERIFY(l[1] == strs[1]);
QVERIFY(l[2] == strs[2]);
QVERIFY(l[3] == strs[3]);
QVERIFY(l[4].isEmpty());
}
void UnpackTest::test_binary()
{
QVariantList l;
l << QByteArray(16, 'm');
l << QByteArray(256, 's');
l << QByteArray(65536, 'g');
l << QByteArray(0, 'p');
QByteArray arr = MsgPack::pack(l);
QVariantList u = MsgPack::unpack(arr).toList();
QVERIFY(u[0].toByteArray() == l[0].toByteArray());
QVERIFY(u[1].toByteArray() == l[1].toByteArray());
QVERIFY(u[2].toByteArray() == l[2].toByteArray());
QVERIFY(u[3].toByteArray().isEmpty());
}
void UnpackTest::test_array()
{
QVariantList l;
QVERIFY(MsgPack::unpack(MsgPack::pack(l)).toList().isEmpty());
l << 0;
QByteArray pack = MsgPack::pack(l);
QVariantList lu = MsgPack::unpack(pack).toList();
QVERIFY(lu.size() == 1);
QVERIFY(lu[0] == 0);
l = QVariantList();
for (int i = 0; i < 256; ++i)
l << i;
pack = MsgPack::pack(l);
lu = MsgPack::unpack(pack).toList();
QVERIFY(lu.size() == 256);
for (int i = 0; i < 256; ++i)
QVERIFY(lu[i] == i);
l = QVariantList();
for(int i = 0; i < 65536; ++i)
l << i;
pack = MsgPack::pack(l);
lu = MsgPack::unpack(pack).toList();
QVERIFY(lu.size() == 65536);
for (int i = 0; i < 65536; ++i)
QVERIFY(lu[i] == i);
}
QTEST_APPLESS_MAIN(UnpackTest)
#include "unpack_test.moc"