summaryrefslogtreecommitdiffstats
path: root/tests/auto/corelib/tools/qringbuffer
diff options
context:
space:
mode:
authorAlex Trotsenko <alex1973tr@gmail.com>2014-06-21 14:30:30 +0300
committerAlex Trotsenko <alex1973tr@gmail.com>2014-07-24 17:31:20 +0200
commitdf4f334ad0473f4f6cc9a9388bed8f3c9a19f8b8 (patch)
treef604e566ec140f94a9e066999443ac0cf92116e5 /tests/auto/corelib/tools/qringbuffer
parent40705cb4c1befa930fd9e262db3a0f01e41271dc (diff)
Rewrite QRingBuffer
QRingBuffer is a fully inlined class used in many I/O classes. So, it must be as fast and small as possible. To this end, a lot of unnecessary special cases were replaced by generic structures. Change-Id: Ic189ced3b200924da158ce511d69d324337d01b6 Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@digia.com>
Diffstat (limited to 'tests/auto/corelib/tools/qringbuffer')
-rw-r--r--tests/auto/corelib/tools/qringbuffer/tst_qringbuffer.cpp120
1 files changed, 120 insertions, 0 deletions
diff --git a/tests/auto/corelib/tools/qringbuffer/tst_qringbuffer.cpp b/tests/auto/corelib/tools/qringbuffer/tst_qringbuffer.cpp
index a2d686d5d8..579d6cfe95 100644
--- a/tests/auto/corelib/tools/qringbuffer/tst_qringbuffer.cpp
+++ b/tests/auto/corelib/tools/qringbuffer/tst_qringbuffer.cpp
@@ -54,7 +54,13 @@ private slots:
void sizeWhenEmpty();
void sizeWhenReservedAndChopped();
void sizeWhenReserved();
+ void free();
+ void reserveAndRead();
+ void chop();
+ void ungetChar();
+ void indexOf();
void appendAndRead();
+ void readLine();
};
void tst_QRingBuffer::sizeWhenReserved()
@@ -180,6 +186,93 @@ void tst_QRingBuffer::readPointerAtPositionWriteRead()
QVERIFY(outData.buffer().startsWith(inData.buffer()));
}
+void tst_QRingBuffer::free()
+{
+ QRingBuffer ringBuffer;
+ // make three byte arrays with different sizes
+ ringBuffer.reserve(4096);
+ ringBuffer.reserve(2048);
+ ringBuffer.append(QByteArray("01234", 5));
+
+ ringBuffer.free(1);
+ QCOMPARE(ringBuffer.size(), 4095 + 2048 + 5);
+ ringBuffer.free(4096);
+ QCOMPARE(ringBuffer.size(), 2047 + 5);
+ ringBuffer.free(48);
+ ringBuffer.free(2000);
+ QCOMPARE(ringBuffer.size(), 4);
+ QVERIFY(memcmp(ringBuffer.readPointer(), "1234", 4) == 0);
+}
+
+void tst_QRingBuffer::reserveAndRead()
+{
+ QRingBuffer ringBuffer;
+ // fill buffer with an arithmetic progression
+ for (int i = 1; i < 256; ++i) {
+ QByteArray ba(i, char(i));
+ char *ringPos = ringBuffer.reserve(i);
+ QVERIFY(ringPos);
+ memcpy(ringPos, ba.constData(), i);
+ }
+
+ // readback and check stored data
+ for (int i = 1; i < 256; ++i) {
+ QByteArray ba;
+ ba.resize(i);
+ int thisRead = ringBuffer.read(ba.data(), i);
+ QCOMPARE(thisRead, i);
+ QVERIFY(ba.count(char(i)) == i);
+ }
+ QVERIFY(ringBuffer.size() == 0);
+}
+
+void tst_QRingBuffer::chop()
+{
+ QRingBuffer ringBuffer;
+ // make three byte arrays with different sizes
+ ringBuffer.append(QByteArray("01234", 5));
+ ringBuffer.reserve(2048);
+ ringBuffer.reserve(4096);
+
+ ringBuffer.chop(1);
+ QCOMPARE(ringBuffer.size(), 5 + 2048 + 4095);
+ ringBuffer.chop(4096);
+ QCOMPARE(ringBuffer.size(), 5 + 2047);
+ ringBuffer.chop(48);
+ ringBuffer.chop(2000);
+ QCOMPARE(ringBuffer.size(), 4);
+ QVERIFY(memcmp(ringBuffer.readPointer(), "0123", 4) == 0);
+}
+
+void tst_QRingBuffer::ungetChar()
+{
+ QRingBuffer ringBuffer(16);
+ for (int i = 1; i < 32; ++i)
+ ringBuffer.putChar(char(i));
+
+ for (int i = 1; i < 31; ++i) {
+ int c = ringBuffer.getChar();
+ QVERIFY(c == 1);
+ ringBuffer.getChar();
+ ringBuffer.ungetChar(char(c)); // unget first char
+ }
+ QCOMPARE(ringBuffer.size(), 1);
+}
+
+void tst_QRingBuffer::indexOf()
+{
+ QRingBuffer ringBuffer(16);
+ for (int i = 1; i < 256; ++i)
+ ringBuffer.putChar(char(i));
+
+ for (int i = 1; i < 256; ++i) {
+ int index = ringBuffer.indexOf(char(i));
+ QCOMPARE(i - 1, index);
+ QCOMPARE(index, ringBuffer.indexOf(char(i), i));
+ QVERIFY(ringBuffer.indexOf(char(i), i - 1) == -1); // test for absent char
+ }
+}
+
void tst_QRingBuffer::appendAndRead()
{
QRingBuffer ringBuffer;
@@ -195,5 +288,32 @@ void tst_QRingBuffer::appendAndRead()
QVERIFY(ringBuffer.read() == ba3);
}
+void tst_QRingBuffer::readLine()
+{
+ QRingBuffer ringBuffer;
+ QByteArray ba1("Hello world!\n", 13);
+ QByteArray ba2("\n", 1);
+ QByteArray ba3("Test string.", 12);
+ QByteArray ba4("0123456789", 10);
+ ringBuffer.append(ba1);
+ ringBuffer.append(ba2);
+ ringBuffer.append(ba3 + ba4 + ba2);
+
+ char stringBuf[102];
+ stringBuf[101] = 0; // non-crash terminator
+ QVERIFY(ringBuffer.readLine(stringBuf, sizeof(stringBuf) - 2) == ba1.size());
+ QVERIFY(QByteArray(stringBuf, strlen(stringBuf)) == ba1);
+
+ // check first empty string reading
+ stringBuf[0] = 0xFF;
+ QCOMPARE(ringBuffer.readLine(stringBuf, sizeof(stringBuf) - 2), ba2.size());
+ QVERIFY(stringBuf[0] == ba2[0]);
+
+ QVERIFY(ringBuffer.readLine(stringBuf, sizeof(stringBuf) - 2) == (ba3.size() + ba4.size()
+ + ba2.size()));
+ QVERIFY(QByteArray(stringBuf, strlen(stringBuf)) == (ba3 + ba4 + ba2));
+ QVERIFY(ringBuffer.size() == 0);
+}
+
QTEST_APPLESS_MAIN(tst_QRingBuffer)
#include "tst_qringbuffer.moc"