summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorshiroki <shiroki@cuteqt.com>2011-05-25 09:11:51 (GMT)
committershiroki <shiroki@cuteqt.com>2011-05-25 09:15:53 (GMT)
commit4ab5a2bc78e142d0035299090e3ad8bee81eed9f (patch)
tree211f877326d55d8d17c78ed7c372fc31327ca5c6
parent00bf2e2605b97ff77efdcb68b7968375b3e9d195 (diff)
downloadQt-4ab5a2bc78e142d0035299090e3ad8bee81eed9f.zip
Qt-4ab5a2bc78e142d0035299090e3ad8bee81eed9f.tar.gz
Qt-4ab5a2bc78e142d0035299090e3ad8bee81eed9f.tar.bz2
fix "Host" header of ipv6 URLs in QNAM
Reviewed-by: Markus Goetz
-rw-r--r--src/network/access/qhttpnetworkconnection.cpp12
-rw-r--r--tests/auto/qnetworkreply/tst_qnetworkreply.cpp18
2 files changed, 20 insertions, 10 deletions
diff --git a/src/network/access/qhttpnetworkconnection.cpp b/src/network/access/qhttpnetworkconnection.cpp
index a471559..dd80a07 100644
--- a/src/network/access/qhttpnetworkconnection.cpp
+++ b/src/network/access/qhttpnetworkconnection.cpp
@@ -261,7 +261,17 @@ void QHttpNetworkConnectionPrivate::prepareRequest(HttpMessagePair &messagePair)
// set the host
value = request.headerField("host");
if (value.isEmpty()) {
- QByteArray host = QUrl::toAce(hostName);
+ QHostAddress add;
+ QByteArray host;
+ if(add.setAddress(hostName)) {
+ if(add.protocol() == QAbstractSocket::IPv6Protocol) {
+ host = "[" + hostName.toAscii() + "]";//format the ipv6 in the standard way
+ } else {
+ host = QUrl::toAce(hostName);
+ }
+ } else {
+ host = QUrl::toAce(hostName);
+ }
int port = request.url().port();
if (port != -1) {
diff --git a/tests/auto/qnetworkreply/tst_qnetworkreply.cpp b/tests/auto/qnetworkreply/tst_qnetworkreply.cpp
index 203de5b..113b64b 100644
--- a/tests/auto/qnetworkreply/tst_qnetworkreply.cpp
+++ b/tests/auto/qnetworkreply/tst_qnetworkreply.cpp
@@ -457,9 +457,9 @@ public:
: client(0), dataToTransmit(data), doClose(true), doSsl(ssl), ipv6(useipv6),
multiple(false), totalConnections(0)
{
- if( useipv6 ){
+ if(useipv6) {
listen(QHostAddress::AnyIPv6);
- }else{
+ } else {
listen();
}
if (thread) {
@@ -2329,8 +2329,9 @@ void tst_QNetworkReply::connectToIPv6Address_data()
QTest::addColumn<QUrl>("url");
QTest::addColumn<QNetworkReply::NetworkError>("error");
QTest::addColumn<QByteArray>("dataToSend");
- QTest::addColumn<QByteArray>("serverVerifyData");
- QTest::newRow("localhost") << QUrl(QByteArray("http://[::1]")) << QNetworkReply::NoError<< QByteArray("localhost") << QByteArray("\r\nHost: [::1]\r\n");
+ QTest::addColumn<QByteArray>("hostfield");
+ QTest::newRow("localhost") << QUrl(QByteArray("http://[::1]")) << QNetworkReply::NoError<< QByteArray("localhost") << QByteArray("[::1]");
+ //QTest::newRow("ipv4localhost") << QUrl(QByteArray("http://127.0.0.1")) << QNetworkReply::NoError<< QByteArray("ipv4localhost") << QByteArray("127.0.0.1");
//to add more test data here
}
@@ -2339,7 +2340,7 @@ void tst_QNetworkReply::connectToIPv6Address()
QFETCH(QUrl, url);
QFETCH(QNetworkReply::NetworkError, error);
QFETCH(QByteArray, dataToSend);
- QFETCH(QByteArray, serverVerifyData);
+ QFETCH(QByteArray, hostfield);
QByteArray httpResponse = QByteArray("HTTP/1.0 200 OK\r\nContent-Length: ");
httpResponse += QByteArray::number(dataToSend.size());
@@ -2357,10 +2358,9 @@ void tst_QNetworkReply::connectToIPv6Address()
QTestEventLoop::instance().enterLoop(10);
QVERIFY(!QTestEventLoop::instance().timeout());
QByteArray content = reply->readAll();
- if( !serverVerifyData.isEmpty()){
- //qDebug() << server.receivedData;
- //QVERIFY(server.receivedData.contains(serverVerifyData)); //got a bug here
- }
+ //qDebug() << server.receivedData;
+ QByteArray hostinfo = "\r\nHost: " + hostfield + ":" + QByteArray::number(server.serverPort()) + "\r\n";
+ QVERIFY(server.receivedData.contains(hostinfo));
QVERIFY(content == dataToSend);
QCOMPARE(reply->url(), request.url());
QVERIFY(reply->error() == error);