[SCM] WebKit Debian packaging branch, webkit-1.2, updated. upstream/1.1.90-6072-g9a69373

kov at webkit.org kov at webkit.org
Thu Apr 8 00:58:26 UTC 2010


The following commit has been merged in the webkit-1.2 branch:
commit c132eae3a9fd734367f986e278aee34e87773506
Author: kov at webkit.org <kov at webkit.org@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Date:   Fri Jan 8 11:54:29 2010 +0000

    2010-01-08  Gustavo Noronha Silva  <gns at gnome.org>
    
            Reviewed by Xan Lopez.
    
            [GTK] loading test should use SoupServer instead of actual sites
            https://bugs.webkit.org/show_bug.cgi?id=33353
    
            Make all the loading tests use SoupServer, instead of fetching
            stuff from the Internet.
    
            * tests/testloading.c:
            (server_callback):
            (get_uri_for_path):
            (test_loading_status):
            (test_loading_error):
            (test_loading_cancelled):
            (load_wentback_status_changed_cb):
            (load_error_test):
            (test_loading_goback):
            (main):
    
    git-svn-id: http://svn.webkit.org/repository/webkit/trunk@52986 268f45cc-cd09-0410-ab3c-d52691b4dbfc

diff --git a/WebKit/gtk/ChangeLog b/WebKit/gtk/ChangeLog
index cc6d12e..6d446a3 100644
--- a/WebKit/gtk/ChangeLog
+++ b/WebKit/gtk/ChangeLog
@@ -1,3 +1,24 @@
+2010-01-08  Gustavo Noronha Silva  <gns at gnome.org>
+
+        Reviewed by Xan Lopez.
+
+        [GTK] loading test should use SoupServer instead of actual sites
+        https://bugs.webkit.org/show_bug.cgi?id=33353
+
+        Make all the loading tests use SoupServer, instead of fetching
+        stuff from the Internet.
+
+        * tests/testloading.c:
+        (server_callback):
+        (get_uri_for_path):
+        (test_loading_status):
+        (test_loading_error):
+        (test_loading_cancelled):
+        (load_wentback_status_changed_cb):
+        (load_error_test):
+        (test_loading_goback):
+        (main):
+
 2010-01-06  Joanmarie Diggs  <joanmarie.diggs at gmail.com>
 
         Reviewed by Xan Lopez.
diff --git a/WebKit/gtk/tests/testloading.c b/WebKit/gtk/tests/testloading.c
index 8838d7b..34897bb 100644
--- a/WebKit/gtk/tests/testloading.c
+++ b/WebKit/gtk/tests/testloading.c
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2009 Gustavo Noronha Silva
+ * Copyright (C) 2009, 2010 Gustavo Noronha Silva
  * Copyright (C) 2009 Igalia S.L.
  *
  * This library is free software; you can redistribute it and/or
@@ -19,10 +19,45 @@
  */
 
 #include <gtk/gtk.h>
+#include <libsoup/soup.h>
+#include <string.h>
 #include <webkit/webkit.h>
 
 #if GLIB_CHECK_VERSION(2, 16, 0) && GTK_CHECK_VERSION(2, 14, 0)
 
+/* This string has to be rather big because of the cancelled test - it
+ * looks like soup refuses to send or receive a too small chunk */
+#define HTML_STRING "<html><body>Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!Testing!</body></html>"
+
+SoupURI* base_uri;
+
+/* For real request testing */
+static void
+server_callback(SoupServer* server, SoupMessage* msg,
+                const char* path, GHashTable* query,
+                SoupClientContext* context, gpointer data)
+{
+    if (msg->method != SOUP_METHOD_GET) {
+        soup_message_set_status(msg, SOUP_STATUS_NOT_IMPLEMENTED);
+        return;
+    }
+
+    soup_message_set_status(msg, SOUP_STATUS_OK);
+
+    if (g_str_equal(path, "/test_loading_status") || g_str_equal(path, "/test_loading_status2"))
+        soup_message_body_append(msg->response_body, SOUP_MEMORY_STATIC, HTML_STRING, strlen(HTML_STRING));
+    else if (g_str_equal(path, "/test_load_error")) {
+        soup_message_set_status(msg, SOUP_STATUS_CANT_CONNECT);
+    } else if (g_str_equal(path, "/test_loading_cancelled")) {
+        soup_message_headers_set_encoding(msg->response_headers, SOUP_ENCODING_CHUNKED);
+        soup_message_body_append(msg->response_body, SOUP_MEMORY_STATIC, HTML_STRING, strlen(HTML_STRING));
+        soup_server_unpause_message(server, msg);
+        return;
+    }
+
+    soup_message_body_complete(msg->response_body);
+}
+
 typedef struct {
     WebKitWebView* webView;
     GMainLoop *loop;
@@ -53,6 +88,18 @@ static void web_loading_fixture_teardown(WebLoadingFixture* fixture, gconstpoint
     g_main_loop_unref(fixture->loop);
 }
 
+static char* get_uri_for_path(const char* path)
+{
+    SoupURI* uri;
+    char* uri_string;
+
+    uri = soup_uri_new_with_base(base_uri, path);
+    uri_string = soup_uri_to_string(uri, FALSE);
+    soup_uri_free (uri);
+
+    return uri_string;
+}
+
 static void load_finished_cb(WebKitWebView* web_view, WebKitWebFrame* web_frame, WebLoadingFixture* fixture)
 {
     g_assert(fixture->has_been_provisional);
@@ -98,6 +145,8 @@ static void status_changed_cb(GObject* object, GParamSpec* pspec, WebLoadingFixt
 
 static void test_loading_status(WebLoadingFixture* fixture, gconstpointer data)
 {
+    char* uri_string;
+
     g_assert_cmpint(webkit_web_view_get_load_status(fixture->webView), ==, WEBKIT_LOAD_PROVISIONAL);
 
     g_object_connect(G_OBJECT(fixture->webView),
@@ -105,10 +154,13 @@ static void test_loading_status(WebLoadingFixture* fixture, gconstpointer data)
                      "signal::load-finished", G_CALLBACK(load_finished_cb), fixture,
                      NULL);
 
+    uri_string = get_uri_for_path("/test_loading_status");
+
     /* load_uri will trigger the navigation-policy-decision-requested
      * signal emission;
      */
-    webkit_web_view_load_uri(fixture->webView, "http://gnome.org/");
+    webkit_web_view_load_uri(fixture->webView, uri_string);
+    g_free(uri_string);
 
     g_main_loop_run(fixture->loop);
 }
@@ -153,12 +205,17 @@ static gboolean load_error_cb(WebKitWebView* webView, WebKitWebFrame* frame, con
 
 static void test_loading_error(WebLoadingFixture* fixture, gconstpointer data)
 {
+    char* uri_string;
+
     g_test_bug("28842");
 
     g_signal_connect(fixture->webView, "load-error", G_CALLBACK(load_error_cb), fixture);
     g_signal_connect(fixture->webView, "notify::load-status", G_CALLBACK(load_error_status_changed_cb), fixture);
 
-    webkit_web_view_load_uri(fixture->webView, "http://snoetuhsetuhseoutoeutc.com/");
+    uri_string = get_uri_for_path("/test_load_error");
+    webkit_web_view_load_uri(fixture->webView, uri_string);
+    g_free(uri_string);
+
     g_main_loop_run(fixture->loop);
 }
 
@@ -211,12 +268,17 @@ static void load_cancelled_status_changed_cb(GObject* object, GParamSpec* pspec,
 
 static void test_loading_cancelled(WebLoadingFixture* fixture, gconstpointer data)
 {
+    char* uri_string;
+
     g_test_bug("29644");
 
     g_signal_connect(fixture->webView, "load-error", G_CALLBACK(load_cancelled_cb), fixture);
     g_signal_connect(fixture->webView, "notify::load-status", G_CALLBACK(load_cancelled_status_changed_cb), fixture);
 
-    webkit_web_view_load_uri(fixture->webView, "http://google.com/");
+    uri_string = get_uri_for_path("/test_loading_cancelled");
+    webkit_web_view_load_uri(fixture->webView, uri_string);
+    g_free(uri_string);
+
     g_main_loop_run(fixture->loop);
 }
 
@@ -250,31 +312,51 @@ static void load_goback_status_changed_cb(GObject* object, GParamSpec* pspec, We
 static void load_wentback_status_changed_cb(GObject* object, GParamSpec* pspec, WebLoadingFixture* fixture)
 {
     WebKitLoadStatus status = webkit_web_view_get_load_status(WEBKIT_WEB_VIEW(object));
+    char* uri_string;
+    char* uri_string2;
+
+    uri_string = get_uri_for_path("/test_loading_status");
+    uri_string2 = get_uri_for_path("/test_loading_status2");
 
     switch(status) {
     case WEBKIT_LOAD_PROVISIONAL:
-        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, "http://www.debian.org/distrib/");
+        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, uri_string2);
         break;
     case WEBKIT_LOAD_COMMITTED:
-        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, "http://www.debian.org/");
+        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, uri_string);
         break;
     case WEBKIT_LOAD_FAILED:
         g_assert_not_reached();
         break;
     case WEBKIT_LOAD_FINISHED:
-        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, "http://www.debian.org/");
+        g_assert_cmpstr(webkit_web_view_get_uri(fixture->webView), ==, uri_string);
         g_main_loop_quit(fixture->loop);
         break;
     default:
         break;
     }
+
+    g_free(uri_string);
+    g_free(uri_string2);
+}
+
+static void load_error_test(WebKitWebView* webview, WebKitWebFrame* frame, const char* uri, GError* error)
+{
+    g_debug("Error: %s", error->message);
 }
 
 static void test_loading_goback(WebLoadingFixture* fixture, gconstpointer data)
 {
+    char* uri_string;
+
     g_signal_connect(fixture->webView, "notify::load-status", G_CALLBACK(load_goback_status_changed_cb), fixture);
 
-    webkit_web_view_load_uri(fixture->webView, "http://www.debian.org/");
+    g_signal_connect(fixture->webView, "load-error", G_CALLBACK(load_error_test), fixture);
+
+    uri_string = get_uri_for_path("/test_loading_status");
+    webkit_web_view_load_uri(fixture->webView, uri_string);
+    g_free(uri_string);
+
     g_main_loop_run(fixture->loop);
 
     fixture->has_been_provisional = FALSE;
@@ -284,9 +366,14 @@ static void test_loading_goback(WebLoadingFixture* fixture, gconstpointer data)
     fixture->has_been_failed = FALSE;
     fixture->has_been_load_error = FALSE;
 
-    webkit_web_view_load_uri(fixture->webView, "http://debian.org/distrib/");
+    uri_string = get_uri_for_path("/test_loading_status2");
+    webkit_web_view_load_uri(fixture->webView, uri_string);
+    g_free(uri_string);
+
     g_main_loop_run(fixture->loop);
 
+    g_signal_handlers_disconnect_by_func(fixture->webView, load_goback_status_changed_cb, fixture);
+
     fixture->has_been_provisional = FALSE;
     fixture->has_been_committed = FALSE;
     fixture->has_been_first_visually_non_empty_layout = FALSE;
@@ -296,13 +383,27 @@ static void test_loading_goback(WebLoadingFixture* fixture, gconstpointer data)
 
     g_signal_connect(fixture->webView, "notify::load-status", G_CALLBACK(load_wentback_status_changed_cb), fixture);
     webkit_web_view_go_back(fixture->webView);
+
+    g_main_loop_run(fixture->loop);
+
+    g_signal_handlers_disconnect_by_func(fixture->webView, load_wentback_status_changed_cb, fixture);
 }
 
 int main(int argc, char** argv)
 {
+    SoupServer* server;
+
     g_thread_init(NULL);
     gtk_test_init(&argc, &argv, NULL);
 
+    server = soup_server_new(SOUP_SERVER_PORT, 0, NULL);
+    soup_server_run_async(server);
+
+    soup_server_add_handler(server, NULL, server_callback, NULL, NULL);
+
+    base_uri = soup_uri_new("http://127.0.0.1/");
+    soup_uri_set_port(base_uri, soup_server_get_port(server));
+
     g_test_bug_base("https://bugs.webkit.org/");
     g_test_add("/webkit/loading/status",
                WebLoadingFixture, NULL,

-- 
WebKit Debian packaging



More information about the Pkg-webkit-commits mailing list