/* * Copyright (C) 2011 Igalia S.L. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #include "config.h" #include "LoadTrackingTest.h" #include static void loadChangedCallback(WebKitWebView* webView, WebKitLoadEvent loadEvent, LoadTrackingTest* test) { switch (loadEvent) { case WEBKIT_LOAD_STARTED: g_assert(webkit_web_view_is_loading(webView)); g_assert_cmpstr(test->m_activeURI.data(), ==, webkit_web_view_get_uri(webView)); test->provisionalLoadStarted(); break; case WEBKIT_LOAD_REDIRECTED: g_assert(webkit_web_view_is_loading(webView)); test->m_activeURI = webkit_web_view_get_uri(webView); if (!test->m_redirectURI.isNull()) g_assert_cmpstr(test->m_redirectURI.data(), ==, test->m_activeURI.data()); test->provisionalLoadReceivedServerRedirect(); break; case WEBKIT_LOAD_COMMITTED: { g_assert(webkit_web_view_is_loading(webView)); g_assert_cmpstr(test->m_activeURI.data(), ==, webkit_web_view_get_uri(webView)); // Check that on committed we always have a main resource with a response. WebKitWebResource* resource = webkit_web_view_get_main_resource(webView); g_assert(resource); g_assert(webkit_web_resource_get_response(resource)); test->loadCommitted(); break; } case WEBKIT_LOAD_FINISHED: if (!test->m_loadFailed) { g_assert(!webkit_web_view_is_loading(webView)); g_assert_cmpstr(test->m_activeURI.data(), ==, webkit_web_view_get_uri(webView)); } else if (!g_error_matches(test->m_error.get(), WEBKIT_NETWORK_ERROR, WEBKIT_NETWORK_ERROR_CANCELLED)) { // When a new load is started before the previous one has finished, we receive the load-finished signal // of the ongoing load while we already have a provisional URL for the new load. This is the only case // where isloading is true when the load has finished. g_assert(!webkit_web_view_is_loading(webView)); } test->loadFinished(); break; default: g_assert_not_reached(); } } static void loadFailedCallback(WebKitWebView* webView, WebKitLoadEvent loadEvent, const char* failingURI, GError* error, LoadTrackingTest* test) { test->m_loadFailed = true; g_assert(error); test->m_error.reset(g_error_copy(error)); if (!g_error_matches(error, WEBKIT_NETWORK_ERROR, WEBKIT_NETWORK_ERROR_CANCELLED)) { // When a new load is started before the previous one has finished, we receive the load-failed signal // of the ongoing load while we already have a provisional URL for the new load. This is the only case // where is-loading is true when the load has failed. g_assert(!webkit_web_view_is_loading(webView)); } switch (loadEvent) { case WEBKIT_LOAD_STARTED: g_assert_cmpstr(test->m_activeURI.data(), ==, failingURI); test->provisionalLoadFailed(failingURI, error); break; case WEBKIT_LOAD_COMMITTED: g_assert_cmpstr(test->m_activeURI.data(), ==, webkit_web_view_get_uri(webView)); test->loadFailed(failingURI, error); break; default: g_assert_not_reached(); } } static gboolean loadFailedWithTLSErrorsCallback(WebKitWebView* webView, const char* failingURI, GTlsCertificate* certificate, GTlsCertificateFlags tlsErrors, LoadTrackingTest* test) { test->m_loadFailed = true; g_assert(!webkit_web_view_is_loading(webView)); g_assert_cmpstr(test->m_activeURI.data(), ==, failingURI); g_assert(G_IS_TLS_CERTIFICATE(certificate)); g_assert(tlsErrors); return test->loadFailedWithTLSErrors(failingURI, certificate, tlsErrors); } static void estimatedProgressChangedCallback(GObject*, GParamSpec*, LoadTrackingTest* test) { test->estimatedProgressChanged(); } LoadTrackingTest::LoadTrackingTest() : m_runLoadUntilCompletion(false) , m_loadFailed(false) { g_signal_connect(m_webView, "load-changed", G_CALLBACK(loadChangedCallback), this); g_signal_connect(m_webView, "load-failed", G_CALLBACK(loadFailedCallback), this); g_signal_connect(m_webView, "load-failed-with-tls-errors", G_CALLBACK(loadFailedWithTLSErrorsCallback), this); g_signal_connect(m_webView, "notify::estimated-load-progress", G_CALLBACK(estimatedProgressChangedCallback), this); g_assert(!webkit_web_view_get_uri(m_webView)); } LoadTrackingTest::~LoadTrackingTest() { g_signal_handlers_disconnect_matched(m_webView, G_SIGNAL_MATCH_DATA, 0, 0, 0, 0, this); } void LoadTrackingTest::waitUntilLoadFinished() { m_estimatedProgress = 0; m_runLoadUntilCompletion = true; g_main_loop_run(m_mainLoop); } void LoadTrackingTest::provisionalLoadStarted() { m_loadEvents.append(ProvisionalLoadStarted); } void LoadTrackingTest::provisionalLoadReceivedServerRedirect() { m_loadEvents.append(ProvisionalLoadReceivedServerRedirect); } void LoadTrackingTest::provisionalLoadFailed(const gchar* failingURI, GError* error) { m_loadEvents.append(ProvisionalLoadFailed); } void LoadTrackingTest::loadCommitted() { m_loadEvents.append(LoadCommitted); } void LoadTrackingTest::loadFinished() { m_loadEvents.append(LoadFinished); if (m_runLoadUntilCompletion) g_main_loop_quit(m_mainLoop); } void LoadTrackingTest::loadFailed(const gchar* failingURI, GError* error) { m_loadEvents.append(LoadFailed); } bool LoadTrackingTest::loadFailedWithTLSErrors(const gchar* /*failingURI*/, GTlsCertificate*, GTlsCertificateFlags) { m_loadEvents.append(LoadFailedWithTLSErrors); return false; } void LoadTrackingTest::estimatedProgressChanged() { double progress = webkit_web_view_get_estimated_load_progress(m_webView); g_assert_cmpfloat(m_estimatedProgress, <, progress); m_estimatedProgress = progress; } void LoadTrackingTest::loadURI(const char* uri) { reset(); WebViewTest::loadURI(uri); } void LoadTrackingTest::loadHtml(const char* html, const char* baseURI) { reset(); WebViewTest::loadHtml(html, baseURI); } void LoadTrackingTest::loadPlainText(const char* plainText) { reset(); WebViewTest::loadPlainText(plainText); } void LoadTrackingTest::loadBytes(GBytes* bytes, const char* mimeType, const char* encoding, const char* baseURI) { reset(); WebViewTest::loadBytes(bytes, mimeType, encoding, baseURI); } void LoadTrackingTest::loadRequest(WebKitURIRequest* request) { reset(); WebViewTest::loadRequest(request); } void LoadTrackingTest::reload() { reset(); webkit_web_view_reload(m_webView); } void LoadTrackingTest::goBack() { reset(); WebViewTest::goBack(); } void LoadTrackingTest::goForward() { reset(); WebViewTest::goForward(); } void LoadTrackingTest::reset() { m_runLoadUntilCompletion = false; m_loadFailed = false; m_loadEvents.clear(); m_estimatedProgress = 0; m_error.reset(); }