Fix QUrl::toString(StripTrailingSlash) to not turn file:/// into file:

It should only strip one slash (as the name indicates), and not if the
path is just "/".

Change-Id: I133a81977241de77a49d1d1559143d30e0bd52f8
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
David Faure 2012-05-03 18:49:46 +02:00 committed by Qt by Nokia
parent 5190beae81
commit 7c717e56f5
2 changed files with 19 additions and 11 deletions

View File

@ -2159,7 +2159,7 @@ QString QUrl::toString(FormattingOptions options) const
d->appendPath(url, options, QUrlPrivate::FullUrl); d->appendPath(url, options, QUrlPrivate::FullUrl);
// check if we need to remove trailing slashes // check if we need to remove trailing slashes
while ((options & StripTrailingSlash) && url.endsWith(QLatin1Char('/'))) if ((options & StripTrailingSlash) && d->path != QLatin1String("/") && url.endsWith(QLatin1Char('/')))
url.chop(1); url.chop(1);
} }

View File

@ -140,6 +140,7 @@ private slots:
void setEncodedFragment_data(); void setEncodedFragment_data();
void setEncodedFragment(); void setEncodedFragment();
void fromEncoded(); void fromEncoded();
void stripTrailingSlash_data();
void stripTrailingSlash(); void stripTrailingSlash();
void hosts_data(); void hosts_data();
void hosts(); void hosts();
@ -2246,18 +2247,25 @@ void tst_QUrl::fromEncoded()
QCOMPARE(qurl_newline_1.toEncoded().constData(), "http://www.foo.bar/foo/bar%0Agnork"); QCOMPARE(qurl_newline_1.toEncoded().constData(), "http://www.foo.bar/foo/bar%0Agnork");
} }
void tst_QUrl::stripTrailingSlash_data()
{
QTest::addColumn<QString>("url");
QTest::addColumn<QString>("expected");
QTest::newRow("ftp no slash") << "ftp://ftp.de.kde.org/dir" << "ftp://ftp.de.kde.org/dir";
QTest::newRow("ftp slash") << "ftp://ftp.de.kde.org/dir/" << "ftp://ftp.de.kde.org/dir";
QTest::newRow("file slash") << "file:///dir/" << "file:///dir";
QTest::newRow("file no slash") << "file:///dir/" << "file:///dir";
QTest::newRow("file root") << "file:///" << "file:///";
}
void tst_QUrl::stripTrailingSlash() void tst_QUrl::stripTrailingSlash()
{ {
QUrl u1( "ftp://ftp.de.kde.org/dir" ); QFETCH(QString, url);
QUrl u2( "ftp://ftp.de.kde.org/dir/" ); QFETCH(QString, expected);
QUrl::FormattingOptions options = QUrl::None;
options |= QUrl::StripTrailingSlash; QUrl u(url);
QString str1 = u1.toString(options); QCOMPARE(u.toString(QUrl::StripTrailingSlash), expected);
QString str2 = u2.toString(options);
QCOMPARE( str1, u1.toString() );
QCOMPARE( str2, u1.toString() );
bool same = str1 == str2;
QVERIFY( same );
} }
void tst_QUrl::hosts_data() void tst_QUrl::hosts_data()