summaryrefslogtreecommitdiffstats
path: root/tests/auto/network/access/qnetworkreply
diff options
context:
space:
mode:
authorFrederik Gladhorn <frederik.gladhorn@digia.com>2013-08-14 09:05:42 +0200
committerFrederik Gladhorn <frederik.gladhorn@digia.com>2013-08-14 09:06:31 +0200
commit5c23199d4e8ff21661dfa5aacc13149178e78cab (patch)
tree322aee61581d7c85f1ccb65e47d1e79eba1ba6c9 /tests/auto/network/access/qnetworkreply
parent252bad7c589e03d3e12df02354b00a84d8e3159a (diff)
parentc8d9b17367cfdcb034d11f8a168ca4ae3993e7c3 (diff)
Merge remote-tracking branch 'origin/stable' into dev
Conflicts: configure mkspecs/macx-xcode/Info.plist.app mkspecs/macx-xcode/Info.plist.lib qmake/doc/qmake.qdocconf src/corelib/global/qglobal.h tests/auto/other/exceptionsafety/exceptionsafety.pro tests/auto/widgets/widgets/qcombobox/tst_qcombobox.cpp Change-Id: I3c769a4a82dc2e99a12c69123fbf17613fd2ac2a
Diffstat (limited to 'tests/auto/network/access/qnetworkreply')
-rw-r--r--tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp44
1 files changed, 44 insertions, 0 deletions
diff --git a/tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp b/tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp
index 2bf8f71d31..eb9ad81101 100644
--- a/tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp
+++ b/tests/auto/network/access/qnetworkreply/tst_qnetworkreply.cpp
@@ -221,6 +221,7 @@ private Q_SLOTS:
void postToHttpSynchronous();
void postToHttpMultipart_data();
void postToHttpMultipart();
+ void multipartSkipIndices(); // QTBUG-32534
#ifndef QT_NO_SSL
void putToHttps_data();
void putToHttps();
@@ -2384,6 +2385,49 @@ void tst_QNetworkReply::postToHttpMultipart()
QCOMPARE(replyData, expectedReplyData);
}
+void tst_QNetworkReply::multipartSkipIndices() // QTBUG-32534
+{
+ QHttpMultiPart *multiPart = new QHttpMultiPart(QHttpMultiPart::MixedType);
+ QUrl url("http://" + QtNetworkSettings::serverName() + "/qtest/cgi-bin/multipart.cgi");
+ QNetworkRequest request(url);
+ QList<QByteArray> parts;
+ parts << QByteArray(56083, 'X') << QByteArray(468, 'X') << QByteArray(24952, 'X');
+
+ QHttpPart part1;
+ part1.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"field1\"; filename=\"aaaa.bin\"");
+ part1.setHeader(QNetworkRequest::ContentTypeHeader, "application/octet-stream");
+ part1.setBody(parts.at(0));
+ multiPart->append(part1);
+
+ QHttpPart part2;
+ part2.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"field2\"; filename=\"bbbb.txt\"");
+ part2.setHeader(QNetworkRequest::ContentTypeHeader, "text/plain");
+ part2.setBody(parts.at(1));
+ multiPart->append(part2);
+
+ QHttpPart part3;
+ part3.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"text-3\"; filename=\"cccc.txt\"");
+ part3.setHeader(QNetworkRequest::ContentTypeHeader, "text/plain");
+ part3.setBody(parts.at(2));
+ multiPart->append(part3);
+
+ QNetworkReplyPtr reply;
+ RUN_REQUEST(runMultipartRequest(request, reply, multiPart, "POST"));
+
+ QCOMPARE(reply->error(), QNetworkReply::NoError);
+
+ QCOMPARE(reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt(), 200); // 200 Ok
+ QByteArray line;
+ int partIndex = 0;
+ while ((line = reply->readLine()) != QByteArray("")) {
+ if (line.startsWith("content:")) {
+ // before, the 3rd part would return garbled output at the end
+ QCOMPARE("content: " + parts[partIndex++] + "\n", line);
+ }
+ }
+ multiPart->deleteLater();
+}
+
void tst_QNetworkReply::putToHttpMultipart_data()
{
postToHttpMultipart_data();