summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorKai Koehne <kai.koehne@theqtcompany.com>2015-09-25 13:27:58 +0200
committerKai Koehne <kai.koehne@theqtcompany.com>2015-10-19 08:37:17 +0000
commit38a426f21c0d6e47bdc05e5541b79c48cf967a0c (patch)
tree34769fbf91f69a27316fa09a9183f137e874c008 /tests
parentd9d1cc3ec8931cecc0b0dcb5d5d184cdb53ff434 (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.cpp48
-rw-r--r--tests/quicktestbrowser/main.cpp29
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));