diff options
author | Kai Koehne <kai.koehne@theqtcompany.com> | 2015-09-25 13:27:58 +0200 |
---|---|---|
committer | Kai Koehne <kai.koehne@theqtcompany.com> | 2015-10-19 08:37:17 +0000 |
commit | 38a426f21c0d6e47bdc05e5541b79c48cf967a0c (patch) | |
tree | 34769fbf91f69a27316fa09a9183f137e874c008 /tests | |
parent | d9d1cc3ec8931cecc0b0dcb5d5d184cdb53ff434 (diff) |
Do not require to subclass/install QWebEngineCookieStoreClient
The class has only setters and getters, except for the virtual
acceptCookie method. By replacing this method with a setCookieFilter
callback we can avoid the need of users to subclass the client.
Change-Id: Id78c01fc103b8d9cc267594527239b598e8975f1
Reviewed-by: Allan Sandfeld Jensen <allan.jensen@theqtcompany.com>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/auto/core/qwebenginecookiestoreclient/tst_qwebenginecookiestoreclient.cpp | 48 | ||||
-rw-r--r-- | tests/quicktestbrowser/main.cpp | 29 |
2 files changed, 30 insertions, 47 deletions
diff --git a/tests/auto/core/qwebenginecookiestoreclient/tst_qwebenginecookiestoreclient.cpp b/tests/auto/core/qwebenginecookiestoreclient/tst_qwebenginecookiestoreclient.cpp index 0f007d643..d78a81c21 100644 --- a/tests/auto/core/qwebenginecookiestoreclient/tst_qwebenginecookiestoreclient.cpp +++ b/tests/auto/core/qwebenginecookiestoreclient/tst_qwebenginecookiestoreclient.cpp @@ -94,13 +94,11 @@ void tst_QWebEngineCookieStoreClient::cleanupTestCase() void tst_QWebEngineCookieStoreClient::cookieSignals() { QWebEngineView view; - QWebEngineCookieStoreClient client; + QWebEngineCookieStoreClient *client = view.page()->profile()->cookieStoreClient(); QSignalSpy loadSpy(&view, SIGNAL(loadFinished(bool))); - QSignalSpy cookieAddedSpy(&client, SIGNAL(cookieAdded(const QNetworkCookie &))); - QSignalSpy cookieRemovedSpy(&client, SIGNAL(cookieRemoved(const QNetworkCookie &))); - - view.page()->profile()->setCookieStoreClient(&client); + QSignalSpy cookieAddedSpy(client, SIGNAL(cookieAdded(const QNetworkCookie &))); + QSignalSpy cookieRemovedSpy(client, SIGNAL(cookieRemoved(const QNetworkCookie &))); view.load(QUrl("qrc:///resources/index.html")); @@ -111,24 +109,24 @@ void tst_QWebEngineCookieStoreClient::cookieSignals() // try whether updating a cookie to be expired results in that cookie being removed. QNetworkCookie expiredCookie(QNetworkCookie::parseCookies(QByteArrayLiteral("SessionCookie=delete; expires=Thu, 01-Jan-1970 00:00:00 GMT; path=///resources")).first()); - client.setCookie(expiredCookie, QUrl("qrc:///resources/index.html")); + client->setCookie(expiredCookie, QUrl("qrc:///resources/index.html")); QTRY_COMPARE(cookieRemovedSpy.count(), 1); cookieRemovedSpy.clear(); // try removing the other cookie. QNetworkCookie nonSessionCookie(QNetworkCookie::parseCookies(QByteArrayLiteral("CookieWithExpiresField=QtWebEngineCookieTest; path=///resources")).first()); - client.deleteCookie(nonSessionCookie, QUrl("qrc:///resources/index.html")); + client->deleteCookie(nonSessionCookie, QUrl("qrc:///resources/index.html")); QTRY_COMPARE(cookieRemovedSpy.count(), 1); } void tst_QWebEngineCookieStoreClient::setAndDeleteCookie() { QWebEngineView view; - QWebEngineCookieStoreClient client; + QWebEngineCookieStoreClient *client = view.page()->profile()->cookieStoreClient(); QSignalSpy loadSpy(&view, SIGNAL(loadFinished(bool))); - QSignalSpy cookieAddedSpy(&client, SIGNAL(cookieAdded(const QNetworkCookie &))); - QSignalSpy cookieRemovedSpy(&client, SIGNAL(cookieRemoved(const QNetworkCookie &))); + QSignalSpy cookieAddedSpy(client, SIGNAL(cookieAdded(const QNetworkCookie &))); + QSignalSpy cookieRemovedSpy(client, SIGNAL(cookieRemoved(const QNetworkCookie &))); QNetworkCookie cookie1(QNetworkCookie::parseCookies(QByteArrayLiteral("khaos=I9GX8CWI; Domain=.example.com; Path=/docs")).first()); QNetworkCookie cookie2(QNetworkCookie::parseCookies(QByteArrayLiteral("Test%20Cookie=foobar; domain=example.com; Path=/")).first()); @@ -136,11 +134,10 @@ void tst_QWebEngineCookieStoreClient::setAndDeleteCookie() QNetworkCookie expiredCookie3(QNetworkCookie::parseCookies(QByteArrayLiteral("SessionCookie=delete; expires=Thu, 01-Jan-1970 00:00:00 GMT; path=///resources")).first()); // check if pending cookies are set and removed - client.setCookieWithCallback(cookie1, [](bool success) { QVERIFY(success); }); - client.setCookieWithCallback(cookie2, [](bool success) { QVERIFY(success); }); - client.deleteCookie(cookie1); + client->setCookieWithCallback(cookie1, [](bool success) { QVERIFY(success); }); + client->setCookieWithCallback(cookie2, [](bool success) { QVERIFY(success); }); + client->deleteCookie(cookie1); - view.page()->profile()->setCookieStoreClient(&client); view.load(QUrl("qrc:///resources/content.html")); QTRY_COMPARE(loadSpy.count(), 1); @@ -151,10 +148,10 @@ void tst_QWebEngineCookieStoreClient::setAndDeleteCookie() cookieAddedSpy.clear(); cookieRemovedSpy.clear(); - client.setCookieWithCallback(cookie3, [](bool success) { QVERIFY(success); }); + client->setCookieWithCallback(cookie3, [](bool success) { QVERIFY(success); }); // updating a cookie with an expired 'expires' field should remove the cookie with the same name - client.setCookieWithCallback(expiredCookie3, [](bool success) { QVERIFY(success); }); - client.deleteCookie(cookie2); + client->setCookieWithCallback(expiredCookie3, [](bool success) { QVERIFY(success); }); + client->deleteCookie(cookie2); QTRY_COMPARE(cookieAddedSpy.count(), 1); QTRY_COMPARE(cookieRemovedSpy.count(), 2); } @@ -162,21 +159,20 @@ void tst_QWebEngineCookieStoreClient::setAndDeleteCookie() void tst_QWebEngineCookieStoreClient::batchCookieTasks() { QWebEngineView view; - QWebEngineCookieStoreClient client; + QWebEngineCookieStoreClient *client = view.page()->profile()->cookieStoreClient(); QSignalSpy loadSpy(&view, SIGNAL(loadFinished(bool))); - QSignalSpy cookieAddedSpy(&client, SIGNAL(cookieAdded(const QNetworkCookie &))); - QSignalSpy cookieRemovedSpy(&client, SIGNAL(cookieRemoved(const QNetworkCookie &))); + QSignalSpy cookieAddedSpy(client, SIGNAL(cookieAdded(const QNetworkCookie &))); + QSignalSpy cookieRemovedSpy(client, SIGNAL(cookieRemoved(const QNetworkCookie &))); QNetworkCookie cookie1(QNetworkCookie::parseCookies(QByteArrayLiteral("khaos=I9GX8CWI; Domain=.example.com; Path=/docs")).first()); QNetworkCookie cookie2(QNetworkCookie::parseCookies(QByteArrayLiteral("Test%20Cookie=foobar; domain=example.com; Path=/")).first()); int capture = 0; - client.setCookieWithCallback(cookie1, [&capture](bool success) { QVERIFY(success); ++capture; }); - client.setCookieWithCallback(cookie2, [&capture](bool success) { QVERIFY(success); ++capture; }); + client->setCookieWithCallback(cookie1, [&capture](bool success) { QVERIFY(success); ++capture; }); + client->setCookieWithCallback(cookie2, [&capture](bool success) { QVERIFY(success); ++capture; }); - view.page()->profile()->setCookieStoreClient(&client); view.load(QUrl("qrc:///resources/index.html")); QTRY_COMPARE(loadSpy.count(), 1); @@ -190,17 +186,17 @@ void tst_QWebEngineCookieStoreClient::batchCookieTasks() cookieAddedSpy.clear(); cookieRemovedSpy.clear(); - client.getAllCookies([&capture](const QByteArray& cookieLine) { + client->getAllCookies([&capture](const QByteArray& cookieLine) { ++capture; QCOMPARE(QNetworkCookie::parseCookies(cookieLine).count(), 4); }); - client.deleteSessionCookiesWithCallback([&capture](int numDeleted) { + client->deleteSessionCookiesWithCallback([&capture](int numDeleted) { ++capture; QCOMPARE(numDeleted, 3); }); - client.deleteAllCookiesWithCallback([&capture](int numDeleted) { + client->deleteAllCookiesWithCallback([&capture](int numDeleted) { ++capture; QCOMPARE(numDeleted, 1); }); diff --git a/tests/quicktestbrowser/main.cpp b/tests/quicktestbrowser/main.cpp index 166da4d5b..167f67dc3 100644 --- a/tests/quicktestbrowser/main.cpp +++ b/tests/quicktestbrowser/main.cpp @@ -69,24 +69,6 @@ static QUrl startupUrl() return QUrl(QStringLiteral("http://qt.io/")); } -class CookieClient: public QWebEngineCookieStoreClient -{ - QMetaProperty m_settingProperty; - const QObject *m_object; -public: - CookieClient(const QObject *object) - : m_object(object) - { - const QMetaObject *rootMeta = object->metaObject(); - int index = rootMeta->indexOfProperty("thirdPartyCookiesEnabled"); - Q_ASSERT(index != -1); - m_settingProperty = rootMeta->property(index); - } - virtual bool acceptCookieFromUrl(const QByteArray &, const QUrl &) { - return m_settingProperty.read(m_object).toBool(); - } -}; - int main(int argc, char **argv) { Application app(argc, argv); @@ -110,10 +92,15 @@ int main(int argc, char **argv) "}") , QUrl()); QObject *profile = component.create(); - CookieClient client(rootObject); - QMetaObject::invokeMethod(profile, "setCookieStoreClient", Q_ARG(QWebEngineCookieStoreClient*, &client)); const QMetaObject *rootMeta = rootObject->metaObject(); - int index = rootMeta->indexOfProperty("testProfile"); + QWebEngineCookieStoreClient *client = 0; + QMetaObject::invokeMethod(profile, "cookieStoreClient", Q_RETURN_ARG(QWebEngineCookieStoreClient*, client)); + int index = rootMeta->indexOfProperty("thirdPartyCookiesEnabled"); + Q_ASSERT(index != -1); + QMetaProperty thirdPartyCookiesProperty = rootMeta->property(index); + client->setCookieFilter([rootObject,&thirdPartyCookiesProperty](const QWebEngineCookieStoreClient::FilterRequest&){ return thirdPartyCookiesProperty.read(rootObject).toBool(); }); + + index = rootMeta->indexOfProperty("testProfile"); Q_ASSERT(index != -1); QMetaProperty profileProperty = rootMeta->property(index); profileProperty.write(rootObject, qVariantFromValue(profile)); |