diff options
author | axis <qt-info@nokia.com> | 2009-04-24 11:34:15 (GMT) |
---|---|---|
committer | axis <qt-info@nokia.com> | 2009-04-24 11:34:15 (GMT) |
commit | 8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76 (patch) | |
tree | a17e1a767a89542ab59907462206d7dcf2e504b2 /tests/auto/qnetworkaddressentry | |
download | Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.zip Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.tar.gz Qt-8f427b2b914d5b575a4a7c0ed65d2fb8f45acc76.tar.bz2 |
Long live Qt for S60!
Diffstat (limited to 'tests/auto/qnetworkaddressentry')
-rw-r--r-- | tests/auto/qnetworkaddressentry/.gitignore | 1 | ||||
-rw-r--r-- | tests/auto/qnetworkaddressentry/qnetworkaddressentry.pro | 4 | ||||
-rw-r--r-- | tests/auto/qnetworkaddressentry/tst_qnetworkaddressentry.cpp | 185 |
3 files changed, 190 insertions, 0 deletions
diff --git a/tests/auto/qnetworkaddressentry/.gitignore b/tests/auto/qnetworkaddressentry/.gitignore new file mode 100644 index 0000000..375dbcf --- /dev/null +++ b/tests/auto/qnetworkaddressentry/.gitignore @@ -0,0 +1 @@ +tst_qnetworkaddressentry diff --git a/tests/auto/qnetworkaddressentry/qnetworkaddressentry.pro b/tests/auto/qnetworkaddressentry/qnetworkaddressentry.pro new file mode 100644 index 0000000..8feb95f --- /dev/null +++ b/tests/auto/qnetworkaddressentry/qnetworkaddressentry.pro @@ -0,0 +1,4 @@ +load(qttest_p4) +SOURCES += tst_qnetworkaddressentry.cpp + +QT = core network diff --git a/tests/auto/qnetworkaddressentry/tst_qnetworkaddressentry.cpp b/tests/auto/qnetworkaddressentry/tst_qnetworkaddressentry.cpp new file mode 100644 index 0000000..9bb3f5d --- /dev/null +++ b/tests/auto/qnetworkaddressentry/tst_qnetworkaddressentry.cpp @@ -0,0 +1,185 @@ +/**************************************************************************** +** +** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). +** Contact: Qt Software Information (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 either Technology Preview License Agreement or the +** Beta Release License Agreement. +** +** 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.0, included in the file LGPL_EXCEPTION.txt in this +** package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** If you are unsure which license is appropriate for your use, please +** contact the sales department at qt-sales@nokia.com. +** $QT_END_LICENSE$ +** +****************************************************************************/ + + +#include <QtTest/QtTest> +#include <qcoreapplication.h> +#include <qnetworkinterface.h> + +// TESTED_FILES=qnetworkinterface.cpp qnetworkinterface.h +Q_DECLARE_METATYPE(QHostAddress) + +class tst_QNetworkAddressEntry: public QObject +{ + Q_OBJECT +private slots: + void getSetCheck(); + void prefixAndNetmask_data(); + void prefixAndNetmask(); +}; + +void tst_QNetworkAddressEntry::getSetCheck() +{ + QNetworkAddressEntry entry; + + QVERIFY(entry.ip().isNull()); + QVERIFY(entry.netmask().isNull()); + QVERIFY(entry.broadcast().isNull()); + QCOMPARE(entry.prefixLength(), -1); + + entry.setIp(QHostAddress::LocalHost); + QCOMPARE(entry.ip(), QHostAddress(QHostAddress::LocalHost)); + entry.setIp(QHostAddress()); + QVERIFY(entry.ip().isNull()); + + entry.setBroadcast(QHostAddress::LocalHost); + QCOMPARE(entry.broadcast(), QHostAddress(QHostAddress::LocalHost)); + entry.setBroadcast(QHostAddress()); + QVERIFY(entry.broadcast().isNull()); + + // netmask and prefix length tested in the next test + entry.setIp(QHostAddress::LocalHost); + entry.setBroadcast(QHostAddress::LocalHost); + + QNetworkAddressEntry entry2; + QVERIFY(entry != entry2); + QVERIFY(!(entry == entry2)); + + entry = entry2; + QCOMPARE(entry, entry2); + QVERIFY(entry == entry); + QVERIFY(!(entry != entry2)); +} + +void tst_QNetworkAddressEntry::prefixAndNetmask_data() +{ + QTest::addColumn<QHostAddress>("ip"); + QTest::addColumn<QHostAddress>("netmask"); + QTest::addColumn<int>("prefix"); + + // IPv4 set: + QHostAddress ipv4(QHostAddress::LocalHost); + QTest::newRow("v4/0") << ipv4 << QHostAddress(QHostAddress::Any) << 0; + QTest::newRow("v4/32") << ipv4 << QHostAddress("255.255.255.255") << 32; + QTest::newRow("v4/24") << ipv4 << QHostAddress("255.255.255.0") << 24; + QTest::newRow("v4/23") << ipv4 << QHostAddress("255.255.254.0") << 23; + QTest::newRow("v4/20") << ipv4 << QHostAddress("255.255.240.0") << 20; + QTest::newRow("v4/invalid1") << ipv4 << QHostAddress(QHostAddress::LocalHost) << -1; + QTest::newRow("v4/invalid2") << ipv4 << QHostAddress(QHostAddress::AnyIPv6) << -1; + QTest::newRow("v4/invalid3") << ipv4 << QHostAddress("255.255.253.0") << -1; + QTest::newRow("v4/invalid4") << ipv4 << QHostAddress() << -2; + QTest::newRow("v4/invalid5") << ipv4 << QHostAddress() << 33; + + // IPv6 set: + QHostAddress ipv6(QHostAddress::LocalHostIPv6); + QTest::newRow("v6/0") << ipv6 << QHostAddress(QHostAddress::AnyIPv6) << 0; + QTest::newRow("v6/128") << ipv6 << QHostAddress("ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff") << 128; + QTest::newRow("v6/64") << ipv6 << QHostAddress("ffff:ffff:ffff:ffff::") << 64; + QTest::newRow("v6/63") << ipv6 << QHostAddress("ffff:ffff:ffff:fffe::") << 63; + QTest::newRow("v6/60") << ipv6 << QHostAddress("ffff:ffff:ffff:fff0::") << 60; + QTest::newRow("v6/48") << ipv6 << QHostAddress("ffff:ffff:ffff::") << 48; + QTest::newRow("v6/3") << ipv6 << QHostAddress("e000::") << 3; + QTest::newRow("v6/invalid1") << ipv6 << QHostAddress(QHostAddress::LocalHostIPv6) << -1; + QTest::newRow("v6/invalid2") << ipv6 << QHostAddress(QHostAddress::Any) << -1; + QTest::newRow("v6/invalid3") << ipv6 << QHostAddress("fffd::") << -1; + QTest::newRow("v6/invalid4") << ipv6 << QHostAddress() << -2; + QTest::newRow("v6/invalid5") << ipv6 << QHostAddress() << 129; +} + +void tst_QNetworkAddressEntry::prefixAndNetmask() +{ + QFETCH(QHostAddress, ip); + QFETCH(QHostAddress, netmask); + QFETCH(int, prefix); + + QNetworkAddressEntry entry; + + // first, without setting the IP, all must be invalid: + entry.setNetmask(netmask); + QVERIFY(entry.netmask().isNull()); + entry.setPrefixLength(prefix); + QCOMPARE(entry.prefixLength(), -1); + + // set the IP: + entry.setIp(ip); + + // set the netmask: + if (!netmask.isNull()) { + entry.setNetmask(netmask); + + // was it a valid one? + if (prefix != -1) { + QVERIFY(!entry.netmask().isNull()); + QCOMPARE(entry.netmask(), netmask); + QCOMPARE(entry.prefixLength(), prefix); + } else { + // not valid + QVERIFY(entry.netmask().isNull()); + QCOMPARE(entry.prefixLength(), -1); + } + } + entry.setNetmask(QHostAddress()); + QVERIFY(entry.netmask().isNull()); + QCOMPARE(entry.prefixLength(), -1); + + // set the prefix + if (prefix != -1) { + entry.setPrefixLength(prefix); + + // was it a valid one? + if (!netmask.isNull()) { + QVERIFY(!entry.netmask().isNull()); + QCOMPARE(entry.netmask(), netmask); + QCOMPARE(entry.prefixLength(), prefix); + } else { + // not valid + QVERIFY(entry.netmask().isNull()); + QCOMPARE(entry.prefixLength(), -1); + } + } + entry.setPrefixLength(-1); + QVERIFY(entry.netmask().isNull()); + QCOMPARE(entry.prefixLength(), -1); +} + +QTEST_MAIN(tst_QNetworkAddressEntry) +#include "tst_qnetworkaddressentry.moc" + |