diff -r 000000000000 -r 1918ee327afb tests/auto/qbitarray/tst_qbitarray.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/tests/auto/qbitarray/tst_qbitarray.cpp Mon Jan 11 14:00:40 2010 +0000 @@ -0,0 +1,659 @@ +/**************************************************************************** +** +** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). +** All rights reserved. +** Contact: Nokia Corporation (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** No Commercial Usage +** This file contains pre-release code and may not be distributed. +** You may use this file in accordance with the terms and conditions +** contained in the Technology Preview License Agreement accompanying +** this package. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Nokia gives you certain additional +** rights. These rights are described in the Nokia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** If you have questions regarding the use of this file, please contact +** Nokia at qt-info@nokia.com. +** +** +** +** +** +** +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + + +#include +#include +#include + +#include "qbitarray.h" + +/** + * Helper function to initialize a bitarray from a string + */ +static QBitArray QStringToQBitArray(const QString &str) +{ + QBitArray ba; + ba.resize(str.length()); + int i; + QChar tru('1'); + for (i = 0; i < str.length(); i++) + { + if (str.at(i) == tru) + { + ba.setBit(i, true); + } + } + return ba; +} + + +//TESTED_CLASS= +//TESTED_FILES= + +class tst_QBitArray : public QObject +{ +Q_OBJECT + +public: + tst_QBitArray(); + virtual ~tst_QBitArray(); + + +public slots: + void init(); + void cleanup(); +private slots: + void size_data(); + void size(); + void countBits_data(); + void countBits(); + void countBits2(); + void isEmpty(); + void fill(); + void toggleBit_data(); + void toggleBit(); + // operator &= + void operator_andeq_data(); + void operator_andeq(); + // operator |= + void operator_oreq_data(); + void operator_oreq(); + // operator ^= + void operator_xoreq_data(); + void operator_xoreq(); + // operator ~ + void operator_neg_data(); + void operator_neg(); + void datastream_data(); + void datastream(); + void invertOnNull() const; + void operator_noteq_data(); + void operator_noteq(); + + void resize(); +}; + +Q_DECLARE_METATYPE(QBitArray) + +tst_QBitArray::tst_QBitArray() +{ +} + +tst_QBitArray::~tst_QBitArray() +{ + +} + +void tst_QBitArray::init() +{ +// TODO: Add initialization code here. +// This will be executed immediately before each test is run. +} + +void tst_QBitArray::cleanup() +{ +// TODO: Add cleanup code here. +// This will be executed immediately after each test is run. +} + +void tst_QBitArray::size_data() +{ + //create the testtable instance and define the elements + QTest::addColumn("count"); + QTest::addColumn("res"); + + //next we fill it with data + QTest::newRow( "data0" ) << 1 << QString("1"); + QTest::newRow( "data1" ) << 2 << QString("11"); + QTest::newRow( "data2" ) << 3 << QString("111"); + QTest::newRow( "data3" ) << 9 << QString("111111111"); + QTest::newRow( "data4" ) << 10 << QString("1111111111"); + QTest::newRow( "data5" ) << 17 << QString("11111111111111111"); + QTest::newRow( "data6" ) << 18 << QString("111111111111111111"); + QTest::newRow( "data7" ) << 19 << QString("1111111111111111111"); + QTest::newRow( "data8" ) << 20 << QString("11111111111111111111"); + QTest::newRow( "data9" ) << 21 << QString("111111111111111111111"); + QTest::newRow( "data10" ) << 22 << QString("1111111111111111111111"); + QTest::newRow( "data11" ) << 23 << QString("11111111111111111111111"); + QTest::newRow( "data12" ) << 24 << QString("111111111111111111111111"); + QTest::newRow( "data13" ) << 25 << QString("1111111111111111111111111"); + QTest::newRow( "data14" ) << 32 << QString("11111111111111111111111111111111"); +} + +void tst_QBitArray::size() +{ + QFETCH(int,count); + + QString S; + QBitArray a(count); + a.fill(1); + int len = a.size(); + for (int j=0; j("bitField"); + QTest::addColumn("numBits"); + QTest::addColumn("onBits"); + + QTest::newRow("empty") << QString() << 0 << 0; + QTest::newRow("1") << QString("1") << 1 << 1; + QTest::newRow("101") << QString("101") << 3 << 2; + QTest::newRow("101100001") << QString("101100001") << 9 << 4; + QTest::newRow("101100001101100001") << QString("101100001101100001") << 18 << 8; + QTest::newRow("101100001101100001101100001101100001") << QString("101100001101100001101100001101100001") << 36 << 16; + QTest::newRow("00000000000000000000000000000000000") << QString("00000000000000000000000000000000000") << 35 << 0; + QTest::newRow("11111111111111111111111111111111111") << QString("11111111111111111111111111111111111") << 35 << 35; + QTest::newRow("11111111111111111111111111111111") << QString("11111111111111111111111111111111") << 32 << 32; + QTest::newRow("11111111111111111111111111111111111111111111111111111111") + << QString("11111111111111111111111111111111111111111111111111111111") << 56 << 56; + QTest::newRow("00000000000000000000000000000000000") << QString("00000000000000000000000000000000000") << 35 << 0; + QTest::newRow("00000000000000000000000000000000") << QString("00000000000000000000000000000000") << 32 << 0; + QTest::newRow("00000000000000000000000000000000000000000000000000000000") + << QString("00000000000000000000000000000000000000000000000000000000") << 56 << 0; +} + +void tst_QBitArray::countBits() +{ + QFETCH(QString, bitField); + QFETCH(int, numBits); + QFETCH(int, onBits); + + QBitArray bits(bitField.size()); + for (int i = 0; i < bitField.size(); ++i) { + if (bitField.at(i) == QLatin1Char('1')) + bits.setBit(i); + } + + QCOMPARE(bits.count(), numBits); + QCOMPARE(bits.count(true), onBits); + QCOMPARE(bits.count(false), numBits - onBits); +} + +void tst_QBitArray::countBits2() +{ + QBitArray bitArray; + for (int i = 0; i < 4017; ++i) { + bitArray.resize(i); + bitArray.fill(true); + QCOMPARE(bitArray.count(true), i); + QCOMPARE(bitArray.count(false), 0); + bitArray.fill(false); + QCOMPARE(bitArray.count(true), 0); + QCOMPARE(bitArray.count(false), i); + } +} + +void tst_QBitArray::isEmpty() +{ + QBitArray a1; + QVERIFY(a1.isEmpty()); + QVERIFY(a1.isNull()); + QVERIFY(a1.size() == 0); + + QBitArray a2(0, true); + QVERIFY(a2.isEmpty()); + QVERIFY(!a2.isNull()); + QVERIFY(a2.size() == 0); + + QBitArray a3(1, true); + QVERIFY(!a3.isEmpty()); + QVERIFY(!a3.isNull()); + QVERIFY(a3.size() == 1); + + a1.resize(0); + QVERIFY(a1.isEmpty()); + QVERIFY(!a1.isNull()); + QVERIFY(a1.size() == 0); + + a2.resize(0); + QVERIFY(a2.isEmpty()); + QVERIFY(!a2.isNull()); + QVERIFY(a2.size() == 0); + + a1.resize(1); + QVERIFY(!a1.isEmpty()); + QVERIFY(!a1.isNull()); + QVERIFY(a1.size() == 1); + + a1.resize(2); + QVERIFY(!a1.isEmpty()); + QVERIFY(!a1.isNull()); + QVERIFY(a1.size() == 2); +} + +void tst_QBitArray::fill() +{ + int N = 64; + int M = 17; + QBitArray a(N, false); + int i, j; + + for (i = 0; i < N-M; ++i) { + a.fill(true, i, i + M); +/* + for (int k = 0; k < N; ++k) + qDebug("%*s%d", k, "", a.at(k)); +*/ + for (j = 0; j < N; ++j) { + if (j >= i && j < i + M) { + QVERIFY(a.at(j)); + } else { + QVERIFY(!a.at(j)); + } + } + a.fill(false, i, i + M); + } + for (i = 0; i < N; ++i) + a.fill(i % 2 == 0, i, i + 1); + for (i = 0; i < N; ++i) { + QVERIFY(a.at(i) == (i % 2 == 0)); + } +} + +void tst_QBitArray::toggleBit_data() +{ + QTest::addColumn("index"); + QTest::addColumn("input"); + QTest::addColumn("res"); + // 8 bits, toggle first bit + QTest::newRow( "data0" ) << 0 << QStringToQBitArray(QString("11111111")) << QStringToQBitArray(QString("01111111")); + // 8 bits + QTest::newRow( "data1" ) << 1 << QStringToQBitArray(QString("11111111")) << QStringToQBitArray(QString("10111111")); + // 11 bits, toggle last bit + QTest::newRow( "data2" ) << 10 << QStringToQBitArray(QString("11111111111")) << QStringToQBitArray(QString("11111111110")); + +} + +void tst_QBitArray::toggleBit() +{ + QFETCH(int,index); + QFETCH(QBitArray, input); + QFETCH(QBitArray, res); + + input.toggleBit(index); + + QCOMPARE(input, res); +} + +void tst_QBitArray::operator_andeq_data() +{ + QTest::addColumn("input1"); + QTest::addColumn("input2"); + QTest::addColumn("res"); + + QTest::newRow( "data0" ) << QStringToQBitArray(QString("11111111")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("00101100")); + + + QTest::newRow( "data1" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("00001000")); + + QTest::newRow( "data2" ) << QStringToQBitArray(QString("11011011111")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("00001000000")); + + QTest::newRow( "data3" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString("00001000000")); + + QTest::newRow( "data4" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString("00000000000")); + + QTest::newRow( "data5" ) << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00000000000")); + + QTest::newRow( "data6" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()); +} + +void tst_QBitArray::operator_andeq() +{ + QFETCH(QBitArray, input1); + QFETCH(QBitArray, input2); + QFETCH(QBitArray, res); + + input1&=input2; + + QCOMPARE(input1, res); +} + +void tst_QBitArray::operator_oreq_data() +{ + QTest::addColumn("input1"); + QTest::addColumn("input2"); + QTest::addColumn("res"); + + QTest::newRow( "data0" ) << QStringToQBitArray(QString("11111111")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11111111")); + + + QTest::newRow( "data1" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11111111")); + + QTest::newRow( "data2" ) << QStringToQBitArray(QString("01000010")) + << QStringToQBitArray(QString("10100001")) + << QStringToQBitArray(QString("11100011")); + + QTest::newRow( "data3" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00101100000")) + << QStringToQBitArray(QString("11111111000")); + + QTest::newRow( "data4" ) << QStringToQBitArray(QString("11011011111")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11111111111")); + + QTest::newRow( "data5" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString("00101100111")); + + QTest::newRow( "data6" ) << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")); + + QTest::newRow( "data7" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()); +} + +void tst_QBitArray::operator_oreq() +{ + QFETCH(QBitArray, input1); + QFETCH(QBitArray, input2); + QFETCH(QBitArray, res); + + input1|=input2; + + QCOMPARE(input1, res); +} + +void tst_QBitArray::operator_xoreq_data() +{ + QTest::addColumn("input1"); + QTest::addColumn("input2"); + QTest::addColumn("res"); + QTest::newRow( "data0" ) << QStringToQBitArray(QString("11111111")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11010011")); + + QTest::newRow( "data1" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11110111")); + + QTest::newRow( "data2" ) << QStringToQBitArray(QString("01000010")) + << QStringToQBitArray(QString("10100001")) + << QStringToQBitArray(QString("11100011")); + + QTest::newRow( "data3" ) << QStringToQBitArray(QString("01000010")) + << QStringToQBitArray(QString("10100001101")) + << QStringToQBitArray(QString("11100011101")); + + QTest::newRow( "data4" ) << QStringToQBitArray(QString("01000010111")) + << QStringToQBitArray(QString("101000011")) + << QStringToQBitArray(QString("11100011011")); + + QTest::newRow( "data5" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString("00101100111")); + + QTest::newRow( "data6" ) << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")); + + QTest::newRow( "data7" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()); +} + +void tst_QBitArray::operator_xoreq() +{ + QFETCH(QBitArray, input1); + QFETCH(QBitArray, input2); + QFETCH(QBitArray, res); + + input1^=input2; + + QCOMPARE(input1, res); +} + + +void tst_QBitArray::operator_neg_data() +{ + QTest::addColumn("input"); + QTest::addColumn("res"); + + QTest::newRow( "data0" ) << QStringToQBitArray(QString("11111111")) + << QStringToQBitArray(QString("00000000")); + + QTest::newRow( "data1" ) << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("00100100")); + + QTest::newRow( "data2" ) << QStringToQBitArray(QString("00000000")) + << QStringToQBitArray(QString("11111111")); + + QTest::newRow( "data3" ) << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()); + + QTest::newRow( "data4" ) << QStringToQBitArray("1") + << QStringToQBitArray("0"); + + QTest::newRow( "data5" ) << QStringToQBitArray("0") + << QStringToQBitArray("1"); + + QTest::newRow( "data6" ) << QStringToQBitArray("01") + << QStringToQBitArray("10"); + + QTest::newRow( "data7" ) << QStringToQBitArray("1110101") + << QStringToQBitArray("0001010"); + + QTest::newRow( "data8" ) << QStringToQBitArray("01110101") + << QStringToQBitArray("10001010"); + + QTest::newRow( "data9" ) << QStringToQBitArray("011101010") + << QStringToQBitArray("100010101"); + + QTest::newRow( "data10" ) << QStringToQBitArray("0111010101111010") + << QStringToQBitArray("1000101010000101"); +} + +void tst_QBitArray::operator_neg() +{ + QFETCH(QBitArray, input); + QFETCH(QBitArray, res); + + input = ~input; + + QCOMPARE(input, res); +} + +void tst_QBitArray::datastream_data() +{ + QTest::addColumn("bitField"); + QTest::addColumn("numBits"); + QTest::addColumn("onBits"); + + QTest::newRow("empty") << QString() << 0 << 0; + QTest::newRow("1") << QString("1") << 1 << 1; + QTest::newRow("101") << QString("101") << 3 << 2; + QTest::newRow("101100001") << QString("101100001") << 9 << 4; + QTest::newRow("101100001101100001") << QString("101100001101100001") << 18 << 8; + QTest::newRow("101100001101100001101100001101100001") << QString("101100001101100001101100001101100001") << 36 << 16; + QTest::newRow("00000000000000000000000000000000000") << QString("00000000000000000000000000000000000") << 35 << 0; + QTest::newRow("11111111111111111111111111111111111") << QString("11111111111111111111111111111111111") << 35 << 35; + QTest::newRow("11111111111111111111111111111111") << QString("11111111111111111111111111111111") << 32 << 32; + QTest::newRow("11111111111111111111111111111111111111111111111111111111") + << QString("11111111111111111111111111111111111111111111111111111111") << 56 << 56; + QTest::newRow("00000000000000000000000000000000000") << QString("00000000000000000000000000000000000") << 35 << 0; + QTest::newRow("00000000000000000000000000000000") << QString("00000000000000000000000000000000") << 32 << 0; + QTest::newRow("00000000000000000000000000000000000000000000000000000000") + << QString("00000000000000000000000000000000000000000000000000000000") << 56 << 0; +} + +void tst_QBitArray::datastream() +{ + QFETCH(QString, bitField); + QFETCH(int, numBits); + QFETCH(int, onBits); + + QBuffer buffer; + QVERIFY(buffer.open(QBuffer::ReadWrite)); + QDataStream stream(&buffer); + + QBitArray bits(bitField.size()); + for (int i = 0; i < bitField.size(); ++i) { + if (bitField.at(i) == QLatin1Char('1')) + bits.setBit(i); + } + + QCOMPARE(bits.count(), numBits); + QCOMPARE(bits.count(true), onBits); + QCOMPARE(bits.count(false), numBits - onBits); + + stream << bits << bits << bits; + buffer.close(); + + QCOMPARE(stream.status(), QDataStream::Ok); + + QVERIFY(buffer.open(QBuffer::ReadWrite)); + QDataStream stream2(&buffer); + + QBitArray array1, array2, array3; + stream2 >> array1 >> array2 >> array3; + + QCOMPARE(array1.count(), numBits); + QCOMPARE(array1.count(true), onBits); + QCOMPARE(array1.count(false), numBits - onBits); + + QCOMPARE(array1, bits); + QCOMPARE(array2, bits); + QCOMPARE(array3, bits); +} + +void tst_QBitArray::invertOnNull() const +{ + QBitArray a; + QCOMPARE(a = ~a, QBitArray()); +} + +void tst_QBitArray::operator_noteq_data() +{ + QTest::addColumn("input1"); + QTest::addColumn("input2"); + QTest::addColumn("res"); + + QTest::newRow("data0") << QStringToQBitArray(QString("11111111")) + << QStringToQBitArray(QString("00101100")) + << true; + + QTest::newRow("data1") << QStringToQBitArray(QString("11011011")) + << QStringToQBitArray(QString("11011011")) + << false; + + QTest::newRow("data2") << QStringToQBitArray(QString()) + << QStringToQBitArray(QString("00101100111")) + << true; + + QTest::newRow("data3") << QStringToQBitArray(QString()) + << QStringToQBitArray(QString()) + << false; + + QTest::newRow("data4") << QStringToQBitArray(QString("00101100")) + << QStringToQBitArray(QString("11111111")) + << true; + + QTest::newRow("data5") << QStringToQBitArray(QString("00101100111")) + << QStringToQBitArray(QString()) + << true; +} + +void tst_QBitArray::operator_noteq() +{ + QFETCH(QBitArray, input1); + QFETCH(QBitArray, input2); + QFETCH(bool, res); + + bool b = input1 != input2; + QCOMPARE(b, res); +} + +void tst_QBitArray::resize() +{ + // -- check that a resize handles the bits correctly + QBitArray a = QStringToQBitArray(QString("11")); + a.resize(10); + QVERIFY(a.size() == 10); + QCOMPARE( a, QStringToQBitArray(QString("1100000000")) ); + + a.setBit(9); + a.resize(9); + // now the bit in a should have been gone: + QCOMPARE( a, QStringToQBitArray(QString("110000000")) ); + + // grow the array back and check the new bit + a.resize(10); + QCOMPARE( a, QStringToQBitArray(QString("1100000000")) ); + + // other test with and + a.resize(9); + QBitArray b = QStringToQBitArray(QString("1111111111")); + b &= a; + QCOMPARE( b, QStringToQBitArray(QString("1100000000")) ); + +} + +QTEST_APPLESS_MAIN(tst_QBitArray) +#include "tst_qbitarray.moc"