Blame tests/misc-test.c

rpm-build 4f3c61
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
rpm-build 4f3c61
/*
rpm-build 4f3c61
 * Copyright 2007-2012 Red Hat, Inc.
rpm-build 4f3c61
 */
rpm-build 4f3c61
rpm-build 4f3c61
#include "test-utils.h"
rpm-build 4f3c61
rpm-build 4f3c61
SoupServer *server, *ssl_server;
rpm-build 4f3c61
SoupURI *base_uri, *ssl_base_uri;
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
auth_callback (SoupAuthDomain *auth_domain, SoupMessage *msg,
rpm-build 4f3c61
	       const char *username, const char *password, gpointer data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	return !strcmp (username, "user") && !strcmp (password, "password");
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
timeout_finish_message (gpointer msg)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupServer *server = g_object_get_data (G_OBJECT (msg), "server");
rpm-build 4f3c61
rpm-build 4f3c61
	soup_server_unpause_message (server, msg);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
server_callback (SoupServer *server, SoupMessage *msg,
rpm-build 4f3c61
		 const char *path, GHashTable *query,
rpm-build 4f3c61
		 SoupClientContext *context, gpointer data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupURI *uri = soup_message_get_uri (msg);
rpm-build 4f3c61
	const char *server_protocol = data;
rpm-build 4f3c61
rpm-build 4f3c61
	if (msg->method != SOUP_METHOD_GET && msg->method != SOUP_METHOD_POST) {
rpm-build 4f3c61
		soup_message_set_status (msg, SOUP_STATUS_NOT_IMPLEMENTED);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	if (!strcmp (path, "/redirect")) {
rpm-build 4f3c61
		soup_message_set_redirect (msg, SOUP_STATUS_FOUND, "/");
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	if (!strcmp (path, "/alias-redirect")) {
rpm-build 4f3c61
		SoupURI *redirect_uri;
rpm-build 4f3c61
		char *redirect_string;
rpm-build 4f3c61
		const char *redirect_protocol;
rpm-build 4f3c61
rpm-build 4f3c61
		redirect_protocol = soup_message_headers_get_one (msg->request_headers, "X-Redirect-Protocol");
rpm-build 4f3c61
rpm-build 4f3c61
		redirect_uri = soup_uri_copy (uri);
rpm-build 4f3c61
		soup_uri_set_scheme (redirect_uri, "foo");
rpm-build 4f3c61
		if (!g_strcmp0 (redirect_protocol, "https"))
rpm-build 4f3c61
			soup_uri_set_port (redirect_uri, ssl_base_uri->port);
rpm-build 4f3c61
		else
rpm-build 4f3c61
			soup_uri_set_port (redirect_uri, base_uri->port);
rpm-build 4f3c61
		soup_uri_set_path (redirect_uri, "/alias-redirected");
rpm-build 4f3c61
		redirect_string = soup_uri_to_string (redirect_uri, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
		soup_message_set_redirect (msg, SOUP_STATUS_FOUND, redirect_string);
rpm-build 4f3c61
		g_free (redirect_string);
rpm-build 4f3c61
		soup_uri_free (redirect_uri);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	} else if (!strcmp (path, "/alias-redirected")) {
rpm-build 4f3c61
		soup_message_set_status (msg, SOUP_STATUS_OK);
rpm-build 4f3c61
		soup_message_headers_append (msg->response_headers,
rpm-build 4f3c61
					     "X-Redirected-Protocol",
rpm-build 4f3c61
					     server_protocol);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	if (!strcmp (path, "/slow")) {
rpm-build 4f3c61
		soup_server_pause_message (server, msg);
rpm-build 4f3c61
		g_object_set_data (G_OBJECT (msg), "server", server);
rpm-build 4f3c61
		soup_add_timeout (g_main_context_get_thread_default (),
rpm-build 4f3c61
				  1000, timeout_finish_message, msg);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	soup_message_set_status (msg, SOUP_STATUS_OK);
rpm-build 4f3c61
	if (!strcmp (uri->host, "foo")) {
rpm-build 4f3c61
		soup_message_set_response (msg, "text/plain",
rpm-build 4f3c61
					   SOUP_MEMORY_STATIC, "foo-index", 9);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	} else {
rpm-build 4f3c61
		soup_message_set_response (msg, "text/plain",
rpm-build 4f3c61
					   SOUP_MEMORY_STATIC, "index", 5);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	}
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
/* Host header handling: client must be able to override the default
rpm-build 4f3c61
 * value, server must be able to recognize different Host values.
rpm-build 4f3c61
 */
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_host_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *one, *two;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("539803");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	one = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	two = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	soup_message_headers_replace (two->request_headers, "Host", "foo");
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_send_message (session, one);
rpm-build 4f3c61
	soup_session_send_message (session, two);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (one, SOUP_STATUS_OK);
rpm-build 4f3c61
	g_assert_cmpstr (one->response_body->data, ==, "index");
rpm-build 4f3c61
	g_object_unref (one);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (two, SOUP_STATUS_OK);
rpm-build 4f3c61
	g_assert_cmpstr (two->response_body->data, ==, "foo-index");
rpm-build 4f3c61
	g_object_unref (two);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
/* request with too big header should be discarded with a IO error to 
rpm-build 4f3c61
 * prevent DOS attacks.
rpm-build 4f3c61
 */
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_host_big_header (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	int i;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("792173");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	for (i = 0; i < 2048; i++) {
rpm-build 4f3c61
		char *key = g_strdup_printf ("test-long-header-key%d", i);
rpm-build 4f3c61
		char *value = g_strdup_printf ("test-long-header-key%d", i);
rpm-build 4f3c61
		soup_message_headers_append (msg->request_headers, key, value);
rpm-build 4f3c61
		g_free (value);
rpm-build 4f3c61
		g_free (key);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_IO_ERROR);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
/* Dropping the application's ref on the session from a callback
rpm-build 4f3c61
 * should not cause the session to be freed at an incorrect time.
rpm-build 4f3c61
 * (This test will crash if it fails.)
rpm-build 4f3c61
 */
rpm-build 4f3c61
static void
rpm-build 4f3c61
cu_one_completed (SoupSession *session, SoupMessage *msg, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	debug_printf (2, "  Message 1 completed\n");
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANT_CONNECT);
rpm-build 4f3c61
	g_object_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
cu_idle_quit (gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_main_loop_quit (loop);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
cu_two_completed (SoupSession *session, SoupMessage *msg, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	debug_printf (2, "  Message 2 completed\n");
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANT_CONNECT);
rpm-build 4f3c61
	g_idle_add (cu_idle_quit, loop); 
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_callback_unref_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupServer *bad_server;
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *one, *two;
rpm-build 4f3c61
	GMainLoop *loop;
rpm-build 4f3c61
	SoupURI *bad_uri;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("533473");
rpm-build 4f3c61
rpm-build 4f3c61
	/* Get a guaranteed-bad URI */
rpm-build 4f3c61
	bad_server = soup_test_server_new (SOUP_TEST_SERVER_DEFAULT);
rpm-build 4f3c61
	bad_uri = soup_test_server_get_uri (bad_server, "http", NULL);
rpm-build 4f3c61
	soup_test_server_quit_unref (bad_server);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (session), (gpointer *)&session);
rpm-build 4f3c61
rpm-build 4f3c61
	loop = g_main_loop_new (NULL, TRUE);
rpm-build 4f3c61
rpm-build 4f3c61
	one = soup_message_new_from_uri ("GET", bad_uri);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (one), (gpointer *)&one);
rpm-build 4f3c61
	two = soup_message_new_from_uri ("GET", bad_uri);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (two), (gpointer *)&two);
rpm-build 4f3c61
	soup_uri_free (bad_uri);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_queue_message (session, one, cu_one_completed, loop);
rpm-build 4f3c61
	soup_session_queue_message (session, two, cu_two_completed, loop);
rpm-build 4f3c61
rpm-build 4f3c61
	g_main_loop_run (loop);
rpm-build 4f3c61
	g_main_loop_unref (loop);
rpm-build 4f3c61
rpm-build 4f3c61
	g_assert_null (session);
rpm-build 4f3c61
	if (session) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (session), (gpointer *)&session);
rpm-build 4f3c61
		g_object_unref (session);
rpm-build 4f3c61
	}
rpm-build 4f3c61
	g_assert_null (one);
rpm-build 4f3c61
	if (one) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (one), (gpointer *)&one);
rpm-build 4f3c61
		g_object_unref (one);
rpm-build 4f3c61
	}
rpm-build 4f3c61
	g_assert_null (two);
rpm-build 4f3c61
	if (two) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (two), (gpointer *)&two);
rpm-build 4f3c61
		g_object_unref (two);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	/* Otherwise, if we haven't crashed, we're ok. */
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
cur_one_completed (GObject *source, GAsyncResult *result, gpointer session)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupRequest *one = SOUP_REQUEST (source);
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (2, "  Request 1 completed\n");
rpm-build 4f3c61
	soup_request_send_finish (one, result, &error);
rpm-build 4f3c61
	g_assert_error (error, G_IO_ERROR, G_IO_ERROR_CONNECTION_REFUSED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
cur_idle_quit (gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_main_loop_quit (loop);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
cur_two_completed (GObject *source, GAsyncResult *result, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupRequest *two = SOUP_REQUEST (source);
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (2, "  Request 2 completed\n");
rpm-build 4f3c61
	soup_request_send_finish (two, result, &error);
rpm-build 4f3c61
	g_assert_error (error, G_IO_ERROR, G_IO_ERROR_CONNECTION_REFUSED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
rpm-build 4f3c61
	g_idle_add (cur_idle_quit, loop); 
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_callback_unref_req_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupServer *bad_server;
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupRequest *one, *two;
rpm-build 4f3c61
	GMainLoop *loop;
rpm-build 4f3c61
	SoupURI *bad_uri;
rpm-build 4f3c61
rpm-build 4f3c61
	/* Get a guaranteed-bad URI */
rpm-build 4f3c61
	bad_server = soup_test_server_new (SOUP_TEST_SERVER_DEFAULT);
rpm-build 4f3c61
	bad_uri = soup_test_server_get_uri (bad_server, "http", NULL);
rpm-build 4f3c61
	soup_test_server_quit_unref (bad_server);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (session), (gpointer *)&session);
rpm-build 4f3c61
rpm-build 4f3c61
	loop = g_main_loop_new (NULL, TRUE);
rpm-build 4f3c61
rpm-build 4f3c61
	one = soup_session_request_uri (session, bad_uri, NULL);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (one), (gpointer *)&one);
rpm-build 4f3c61
	two = soup_session_request_uri (session, bad_uri, NULL);
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (two), (gpointer *)&two);
rpm-build 4f3c61
	soup_uri_free (bad_uri);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_request_send_async (one, NULL, cur_one_completed, session);
rpm-build 4f3c61
	g_object_unref (one);
rpm-build 4f3c61
	soup_request_send_async (two, NULL, cur_two_completed, loop);
rpm-build 4f3c61
	g_object_unref (two);
rpm-build 4f3c61
rpm-build 4f3c61
	g_main_loop_run (loop);
rpm-build 4f3c61
	g_main_loop_unref (loop);
rpm-build 4f3c61
rpm-build 4f3c61
	g_assert_null (session);
rpm-build 4f3c61
	if (session) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (session), (gpointer *)&session);
rpm-build 4f3c61
		g_object_unref (session);
rpm-build 4f3c61
	}
rpm-build 4f3c61
	g_assert_null (one);
rpm-build 4f3c61
	if (one) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (one), (gpointer *)&one);
rpm-build 4f3c61
		g_object_unref (one);
rpm-build 4f3c61
	}
rpm-build 4f3c61
	g_assert_null (two);
rpm-build 4f3c61
	if (two) {
rpm-build 4f3c61
		g_object_remove_weak_pointer (G_OBJECT (two), (gpointer *)&two);
rpm-build 4f3c61
		g_object_unref (two);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	/* Otherwise, if we haven't crashed, we're ok. */
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
/* SoupSession should clean up all signal handlers on a message after
rpm-build 4f3c61
 * it is finished, allowing the message to be reused if desired.
rpm-build 4f3c61
 */
rpm-build 4f3c61
static void
rpm-build 4f3c61
ensure_no_signal_handlers (SoupMessage *msg, guint *signal_ids, guint n_signal_ids)
rpm-build 4f3c61
{
rpm-build 4f3c61
	int i;
rpm-build 4f3c61
	guint id;
rpm-build 4f3c61
rpm-build 4f3c61
	for (i = 0; i < n_signal_ids; i++) {
rpm-build 4f3c61
		id = g_signal_handler_find (msg, G_SIGNAL_MATCH_ID, signal_ids[i],
rpm-build 4f3c61
					    0, NULL, NULL, NULL);
rpm-build 4f3c61
		soup_test_assert (id == 0,
rpm-build 4f3c61
				  "message has handler for '%s'",
rpm-build 4f3c61
				  g_signal_name (signal_ids[i]));
rpm-build 4f3c61
	}
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
reuse_test_authenticate (SoupSession *session, SoupMessage *msg,
rpm-build 4f3c61
			 SoupAuth *auth, gboolean retrying)
rpm-build 4f3c61
{
rpm-build 4f3c61
	/* Get it wrong the first time, then succeed */
rpm-build 4f3c61
	if (!retrying)
rpm-build 4f3c61
		soup_auth_authenticate (auth, "user", "wrong password");
rpm-build 4f3c61
	else
rpm-build 4f3c61
		soup_auth_authenticate (auth, "user", "password");
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_msg_reuse_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	SoupURI *uri;
rpm-build 4f3c61
	guint *signal_ids, n_signal_ids;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("559054");
rpm-build 4f3c61
rpm-build 4f3c61
	signal_ids = g_signal_list_ids (SOUP_TYPE_MESSAGE, &n_signal_ids);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	g_signal_connect (session, "authenticate",
rpm-build 4f3c61
			  G_CALLBACK (reuse_test_authenticate), NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  First message\n");
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	ensure_no_signal_handlers (msg, signal_ids, n_signal_ids);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Redirect message\n");
rpm-build 4f3c61
	uri = soup_uri_new_with_base (base_uri, "/redirect");
rpm-build 4f3c61
	soup_message_set_uri (msg, uri);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	g_assert_true (soup_uri_equal (soup_message_get_uri (msg), base_uri));
rpm-build 4f3c61
	ensure_no_signal_handlers (msg, signal_ids, n_signal_ids);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Auth message\n");
rpm-build 4f3c61
	uri = soup_uri_new_with_base (base_uri, "/auth");
rpm-build 4f3c61
	soup_message_set_uri (msg, uri);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_OK);
rpm-build 4f3c61
	ensure_no_signal_handlers (msg, signal_ids, n_signal_ids);
rpm-build 4f3c61
rpm-build 4f3c61
	/* One last try to make sure the auth stuff got cleaned up */
rpm-build 4f3c61
	debug_printf (1, "  Last message\n");
rpm-build 4f3c61
	soup_message_set_uri (msg, base_uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	ensure_no_signal_handlers (msg, signal_ids, n_signal_ids);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
	g_free (signal_ids);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
/* Handle unexpectedly-early aborts. */
rpm-build 4f3c61
static void
rpm-build 4f3c61
ea_msg_completed_one (SoupSession *session, SoupMessage *msg, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	debug_printf (2, "  Message 1 completed\n");
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_main_loop_quit (loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
ea_abort_session (gpointer session)
rpm-build 4f3c61
{
rpm-build 4f3c61
	soup_session_abort (session);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ea_connection_state_changed (GObject *conn, GParamSpec *pspec, gpointer session)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupConnectionState state;
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_get (conn, "state", &state, NULL);
rpm-build 4f3c61
	if (state == SOUP_CONNECTION_CONNECTING) {
rpm-build 4f3c61
		g_idle_add_full (G_PRIORITY_HIGH,
rpm-build 4f3c61
				 ea_abort_session,
rpm-build 4f3c61
				 session, NULL);
rpm-build 4f3c61
		g_signal_handlers_disconnect_by_func (conn, ea_connection_state_changed, session);
rpm-build 4f3c61
	}
rpm-build 4f3c61
}		
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ea_connection_created (SoupSession *session, GObject *conn, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_signal_connect (conn, "notify::state",
rpm-build 4f3c61
			  G_CALLBACK (ea_connection_state_changed), session);
rpm-build 4f3c61
	g_signal_handlers_disconnect_by_func (session, ea_connection_created, user_data);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ea_message_starting (SoupMessage *msg, SoupSession *session)
rpm-build 4f3c61
{
rpm-build 4f3c61
	soup_session_cancel_message (session, msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_early_abort_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	GMainContext *context;
rpm-build 4f3c61
	GMainLoop *loop;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("596074");
rpm-build 4f3c61
	g_test_bug ("618641");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
rpm-build 4f3c61
	context = g_main_context_default ();
rpm-build 4f3c61
	loop = g_main_loop_new (context, TRUE);
rpm-build 4f3c61
	soup_session_queue_message (session, msg, ea_msg_completed_one, loop);
rpm-build 4f3c61
	g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_abort (session);
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
	g_main_loop_unref (loop);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
rpm-build 4f3c61
	g_signal_connect (session, "connection-created",
rpm-build 4f3c61
			  G_CALLBACK (ea_connection_created), NULL);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	debug_printf (2, "  Message 2 completed\n");
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("668098");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
rpm-build 4f3c61
	g_signal_connect (msg, "starting",
rpm-build 4f3c61
			  G_CALLBACK (ea_message_starting), session);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	debug_printf (2, "  Message 3 completed\n");
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ear_one_completed (GObject *source, GAsyncResult *result, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (2, "  Request 1 completed\n");
rpm-build 4f3c61
	soup_request_send_finish (SOUP_REQUEST (source), result, &error);
rpm-build 4f3c61
	g_assert_error (error, SOUP_HTTP_ERROR, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ear_two_completed (GObject *source, GAsyncResult *result, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (2, "  Request 2 completed\n");
rpm-build 4f3c61
	soup_request_send_finish (SOUP_REQUEST (source), result, &error);
rpm-build 4f3c61
	g_assert_error (error, SOUP_HTTP_ERROR, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
rpm-build 4f3c61
	g_main_loop_quit (loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ear_three_completed (GObject *source, GAsyncResult *result, gpointer loop)
rpm-build 4f3c61
{
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (2, "  Request 3 completed\n");
rpm-build 4f3c61
	soup_request_send_finish (SOUP_REQUEST (source), result, &error);
rpm-build 4f3c61
	g_assert_error (error, G_IO_ERROR, G_IO_ERROR_CANCELLED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
rpm-build 4f3c61
	g_main_loop_quit (loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ear_message_starting (SoupMessage *msg, gpointer cancellable)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_cancellable_cancel (cancellable);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
ear_request_queued (SoupSession *session, SoupMessage *msg,
rpm-build 4f3c61
		    gpointer cancellable)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_signal_connect (msg, "starting",
rpm-build 4f3c61
			  G_CALLBACK (ear_message_starting),
rpm-build 4f3c61
			  cancellable);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_early_abort_req_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupRequest *req;
rpm-build 4f3c61
	GMainContext *context;
rpm-build 4f3c61
	GMainLoop *loop;
rpm-build 4f3c61
	GCancellable *cancellable;
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	req = soup_session_request_uri (session, base_uri, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	context = g_main_context_default ();
rpm-build 4f3c61
	loop = g_main_loop_new (context, TRUE);
rpm-build 4f3c61
	soup_request_send_async (req, NULL, ear_one_completed, NULL);
rpm-build 4f3c61
	g_object_unref (req);
rpm-build 4f3c61
	g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_abort (session);
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	req = soup_session_request_uri (session, base_uri, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	g_signal_connect (session, "connection-created",
rpm-build 4f3c61
			  G_CALLBACK (ea_connection_created), NULL);
rpm-build 4f3c61
	soup_request_send_async (req, NULL, ear_two_completed, loop);
rpm-build 4f3c61
	g_main_loop_run (loop);
rpm-build 4f3c61
	g_object_unref (req);
rpm-build 4f3c61
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	req = soup_session_request_uri (session, base_uri, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	cancellable = g_cancellable_new ();
rpm-build 4f3c61
	g_signal_connect (session, "request-queued",
rpm-build 4f3c61
			  G_CALLBACK (ear_request_queued), cancellable);
rpm-build 4f3c61
	soup_request_send_async (req, cancellable, ear_three_completed, loop);
rpm-build 4f3c61
	g_main_loop_run (loop);
rpm-build 4f3c61
	g_object_unref (req);
rpm-build 4f3c61
	g_object_unref (cancellable);
rpm-build 4f3c61
rpm-build 4f3c61
	while (g_main_context_pending (context))
rpm-build 4f3c61
		g_main_context_iteration (context, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
	g_main_loop_unref (loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_one_accept_language_test (const char *language, const char *expected_header)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	const char *val;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  LANGUAGE=%s\n", language);
rpm-build 4f3c61
	g_setenv ("LANGUAGE", language, TRUE);
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC,
rpm-build 4f3c61
					 SOUP_SESSION_ACCEPT_LANGUAGE_AUTO, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_OK);
rpm-build 4f3c61
	val = soup_message_headers_get_list (msg->request_headers,
rpm-build 4f3c61
					     "Accept-Language");
rpm-build 4f3c61
	g_assert_cmpstr (val, ==, expected_header);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_accept_language_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	const char *orig_language;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("602547");
rpm-build 4f3c61
rpm-build 4f3c61
	orig_language = g_getenv ("LANGUAGE");
rpm-build 4f3c61
	do_one_accept_language_test ("C", "en");
rpm-build 4f3c61
	do_one_accept_language_test ("fr_FR", "fr-fr, fr;q=0.9");
rpm-build 4f3c61
	do_one_accept_language_test ("fr_FR:de:en_US", "fr-fr, fr;q=0.9, de;q=0.8, en-us;q=0.7, en;q=0.6");
rpm-build 4f3c61
rpm-build 4f3c61
	if (orig_language)
rpm-build 4f3c61
		g_setenv ("LANGUAGE", orig_language, TRUE);
rpm-build 4f3c61
	else
rpm-build 4f3c61
		g_unsetenv ("LANGUAGE");
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
cancel_message_timeout (gpointer msg)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session = g_object_get_data (G_OBJECT (msg), "session");
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_cancel_message (session, msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
	g_object_unref (session);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gpointer
rpm-build 4f3c61
cancel_message_thread (gpointer msg)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session = g_object_get_data (G_OBJECT (msg), "session");
rpm-build 4f3c61
rpm-build 4f3c61
	g_usleep (100000); /* .1s */
rpm-build 4f3c61
	soup_session_cancel_message (session, msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
	g_object_unref (session);
rpm-build 4f3c61
	return NULL;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
set_done (SoupSession *session, SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	gboolean *done = user_data;
rpm-build 4f3c61
rpm-build 4f3c61
	*done = TRUE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_test_for_session (SoupSession *session)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	GThread *thread = NULL;
rpm-build 4f3c61
	SoupURI *uri;
rpm-build 4f3c61
	gboolean done = FALSE;
rpm-build 4f3c61
rpm-build 4f3c61
	uri = soup_uri_new_with_base (base_uri, "/slow");
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", uri);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_set_data (G_OBJECT (msg), "session", session);
rpm-build 4f3c61
	g_object_ref (msg);
rpm-build 4f3c61
	g_object_ref (session);
rpm-build 4f3c61
	if (SOUP_IS_SESSION_ASYNC (session))
rpm-build 4f3c61
		g_timeout_add (100, cancel_message_timeout, msg);
rpm-build 4f3c61
	else
rpm-build 4f3c61
		thread = g_thread_new ("cancel_message_thread", cancel_message_thread, msg);
rpm-build 4f3c61
rpm-build 4f3c61
	/* We intentionally don't use soup_session_send_message() here,
rpm-build 4f3c61
	 * because it holds an extra ref on the SoupMessageQueueItem
rpm-build 4f3c61
	 * relative to soup_session_queue_message().
rpm-build 4f3c61
	 */
rpm-build 4f3c61
	g_object_ref (msg);
rpm-build 4f3c61
	soup_session_queue_message (session, msg, set_done, &done);
rpm-build 4f3c61
	while (!done)
rpm-build 4f3c61
		g_main_context_iteration (NULL, TRUE);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
rpm-build 4f3c61
	if (thread)
rpm-build 4f3c61
		g_thread_join (thread);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("637741");
rpm-build 4f3c61
	g_test_bug ("676038");
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Async session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	do_cancel_while_reading_test_for_session (session);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Sync session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC, NULL);
rpm-build 4f3c61
	do_cancel_while_reading_test_for_session (session);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_req_test_for_session (SoupSession *session,
rpm-build 4f3c61
					      guint flags)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupRequest *req;
rpm-build 4f3c61
	SoupURI *uri;
rpm-build 4f3c61
	GCancellable *cancellable;
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	uri = soup_uri_new_with_base (base_uri, "/slow");
rpm-build 4f3c61
	req = soup_session_request_uri (session, uri, NULL);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
rpm-build 4f3c61
	cancellable = g_cancellable_new ();
rpm-build 4f3c61
	soup_test_request_send (req, cancellable, flags, &error);
rpm-build 4f3c61
	g_assert_error (error, G_IO_ERROR, G_IO_ERROR_CANCELLED);
rpm-build 4f3c61
	g_clear_error (&error);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (req);
rpm-build 4f3c61
	g_object_unref (cancellable);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_immediate_req_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	guint flags;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("692310");
rpm-build 4f3c61
rpm-build 4f3c61
	flags = SOUP_TEST_REQUEST_CANCEL_CANCELLABLE | SOUP_TEST_REQUEST_CANCEL_IMMEDIATE;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Async session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Sync session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_delayed_req_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	guint flags;
rpm-build 4f3c61
rpm-build 4f3c61
	flags = SOUP_TEST_REQUEST_CANCEL_CANCELLABLE | SOUP_TEST_REQUEST_CANCEL_SOON;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Async session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Sync session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_cancel_while_reading_preemptive_req_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	guint flags;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("637039");
rpm-build 4f3c61
rpm-build 4f3c61
	flags = SOUP_TEST_REQUEST_CANCEL_CANCELLABLE | SOUP_TEST_REQUEST_CANCEL_PREEMPTIVE;
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Async session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_USE_THREAD_CONTEXT, TRUE,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Sync session\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_cancel_while_reading_req_test_for_session (session, flags);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_aliases_test_for_session (SoupSession *session,
rpm-build 4f3c61
			     const char *redirect_protocol)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	SoupURI *uri;
rpm-build 4f3c61
	const char *redirected_protocol;
rpm-build 4f3c61
rpm-build 4f3c61
	uri = soup_uri_new_with_base (base_uri, "/alias-redirect");
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", uri);
rpm-build 4f3c61
	if (redirect_protocol)
rpm-build 4f3c61
		soup_message_headers_append (msg->request_headers, "X-Redirect-Protocol", redirect_protocol);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
rpm-build 4f3c61
	redirected_protocol = soup_message_headers_get_one (msg->response_headers, "X-Redirected-Protocol");
rpm-build 4f3c61
rpm-build 4f3c61
	g_assert_cmpstr (redirect_protocol, ==, redirected_protocol);
rpm-build 4f3c61
	if (redirect_protocol)
rpm-build 4f3c61
		soup_test_assert_message_status (msg, SOUP_STATUS_OK);
rpm-build 4f3c61
	else
rpm-build 4f3c61
		soup_test_assert_message_status (msg, SOUP_STATUS_FOUND);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_aliases_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	char *aliases[] = { "foo", NULL };
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  Default behavior\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
	do_aliases_test_for_session (session, "http");
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	if (tls_available) {
rpm-build 4f3c61
		debug_printf (1, "  foo-means-https\n");
rpm-build 4f3c61
		session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
						 SOUP_SESSION_HTTPS_ALIASES, aliases,
rpm-build 4f3c61
						 NULL);
rpm-build 4f3c61
		do_aliases_test_for_session (session, "https");
rpm-build 4f3c61
		soup_test_session_abort_unref (session);
rpm-build 4f3c61
	} else
rpm-build 4f3c61
		debug_printf (1, "  foo-means-https -- SKIPPING\n");
rpm-build 4f3c61
rpm-build 4f3c61
	debug_printf (1, "  foo-means-nothing\n");
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_HTTP_ALIASES, NULL,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
	do_aliases_test_for_session (session, NULL);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_idle_on_dispose_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	GMainContext *async_context;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("667364");
rpm-build 4f3c61
rpm-build 4f3c61
	async_context = g_main_context_new ();
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC,
rpm-build 4f3c61
					 SOUP_SESSION_ASYNC_CONTEXT, async_context,
rpm-build 4f3c61
					 NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	soup_session_send_message (session, msg);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
rpm-build 4f3c61
	while (g_main_context_iteration (async_context, FALSE))
rpm-build 4f3c61
		;
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_run_dispose (G_OBJECT (session));
rpm-build 4f3c61
rpm-build 4f3c61
	if (g_main_context_iteration (async_context, FALSE))
rpm-build 4f3c61
		soup_test_assert (FALSE, "idle was queued");
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (session);
rpm-build 4f3c61
	g_main_context_unref (async_context);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_pause_abort_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	gpointer ptr;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("673905");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	soup_session_queue_message (session, msg, NULL, NULL);
rpm-build 4f3c61
	soup_session_pause_message (session, msg);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_add_weak_pointer (G_OBJECT (msg), &ptr);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
rpm-build 4f3c61
	g_assert_null (ptr);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static GMainLoop *pause_cancel_loop;
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
pause_cancel_got_headers (SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session = user_data;
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_pause_message (session, msg);
rpm-build 4f3c61
	g_main_loop_quit (pause_cancel_loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
pause_cancel_finished (SoupSession *session, SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	gboolean *finished = user_data;
rpm-build 4f3c61
rpm-build 4f3c61
	*finished = TRUE;
rpm-build 4f3c61
	g_main_loop_quit (pause_cancel_loop);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
pause_cancel_timeout (gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	gboolean *timed_out = user_data;
rpm-build 4f3c61
rpm-build 4f3c61
	*timed_out = TRUE;
rpm-build 4f3c61
	g_main_loop_quit (pause_cancel_loop);
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_pause_cancel_test (void)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	gboolean finished = FALSE, timed_out = FALSE;
rpm-build 4f3c61
	guint timeout_id;
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_bug ("745094");
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION, NULL);
rpm-build 4f3c61
	pause_cancel_loop = g_main_loop_new (NULL, FALSE);
rpm-build 4f3c61
rpm-build 4f3c61
	timeout_id = g_timeout_add_seconds (5, pause_cancel_timeout, &timed_out);
rpm-build 4f3c61
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", base_uri);
rpm-build 4f3c61
	g_object_ref (msg);
rpm-build 4f3c61
	g_signal_connect (msg, "got-headers",
rpm-build 4f3c61
			  G_CALLBACK (pause_cancel_got_headers), session);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_queue_message (session, msg, pause_cancel_finished, &finished);
rpm-build 4f3c61
	g_main_loop_run (pause_cancel_loop);
rpm-build 4f3c61
	g_assert_false (finished);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_session_cancel_message (session, msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_main_loop_run (pause_cancel_loop);
rpm-build 4f3c61
	g_assert_true (finished);
rpm-build 4f3c61
	g_assert_false (timed_out);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_assert_message_status (msg, SOUP_STATUS_CANCELLED);
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
	g_main_loop_unref (pause_cancel_loop);
rpm-build 4f3c61
	if (!timed_out)
rpm-build 4f3c61
		g_source_remove (timeout_id);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static gboolean
rpm-build 4f3c61
run_echo_server (gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	GIOStream *stream = user_data;
rpm-build 4f3c61
	GInputStream *istream;
rpm-build 4f3c61
	GDataInputStream *distream;
rpm-build 4f3c61
	GOutputStream *ostream;
rpm-build 4f3c61
	char *str, *caps;
rpm-build 4f3c61
	gssize n;
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	istream = g_io_stream_get_input_stream (stream);
rpm-build 4f3c61
	distream = G_DATA_INPUT_STREAM (g_data_input_stream_new (istream));
rpm-build 4f3c61
	ostream = g_io_stream_get_output_stream (stream);
rpm-build 4f3c61
rpm-build 4f3c61
	/* Echo until the client disconnects */
rpm-build 4f3c61
	while (TRUE) {
rpm-build 4f3c61
		str = g_data_input_stream_read_line (distream, NULL, NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		if (!str)
rpm-build 4f3c61
			break;
rpm-build 4f3c61
rpm-build 4f3c61
		caps = g_ascii_strup (str, -1);
rpm-build 4f3c61
		n = g_output_stream_write (ostream, caps, strlen (caps), NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		g_assert_cmpint (n, ==, strlen (caps)); 
rpm-build 4f3c61
		n = g_output_stream_write (ostream, "\n", 1, NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		g_assert_cmpint (n, ==, 1);
rpm-build 4f3c61
		g_free (caps);
rpm-build 4f3c61
		g_free (str);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (distream);
rpm-build 4f3c61
rpm-build 4f3c61
	g_io_stream_close (stream, NULL, &error);
rpm-build 4f3c61
	g_assert_no_error (error);
rpm-build 4f3c61
	g_object_unref (stream);
rpm-build 4f3c61
rpm-build 4f3c61
	return FALSE;
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
steal_after_upgrade (SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupClientContext *context = user_data;
rpm-build 4f3c61
	GIOStream *stream;
rpm-build 4f3c61
	GSource *source;
rpm-build 4f3c61
rpm-build 4f3c61
	/* This should not ever be seen. */
rpm-build 4f3c61
	soup_message_set_status (msg, SOUP_STATUS_INTERNAL_SERVER_ERROR);
rpm-build 4f3c61
rpm-build 4f3c61
	stream = soup_client_context_steal_connection (context);
rpm-build 4f3c61
rpm-build 4f3c61
	source = g_idle_source_new ();
rpm-build 4f3c61
	g_source_set_callback (source, run_echo_server, stream, NULL);
rpm-build 4f3c61
	g_source_attach (source, g_main_context_get_thread_default ());
rpm-build 4f3c61
	g_source_unref (source);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
upgrade_server_callback (SoupServer *server, SoupMessage *msg,
rpm-build 4f3c61
			 const char *path, GHashTable *query,
rpm-build 4f3c61
			 SoupClientContext *context, gpointer data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	if (msg->method != SOUP_METHOD_GET) {
rpm-build 4f3c61
		soup_message_set_status (msg, SOUP_STATUS_NOT_IMPLEMENTED);
rpm-build 4f3c61
		return;
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	soup_message_set_status (msg, SOUP_STATUS_SWITCHING_PROTOCOLS);
rpm-build 4f3c61
	soup_message_headers_append (msg->request_headers, "Upgrade", "ECHO");
rpm-build 4f3c61
	soup_message_headers_append (msg->request_headers, "Connection", "upgrade");
rpm-build 4f3c61
rpm-build 4f3c61
	g_signal_connect (msg, "wrote-informational",
rpm-build 4f3c61
			  G_CALLBACK (steal_after_upgrade), context);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
callback_not_reached (SoupSession *session, SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	g_assert_not_reached ();
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
switching_protocols (SoupMessage *msg, gpointer user_data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	GIOStream **out_iostream = user_data;
rpm-build 4f3c61
	SoupSession *session = g_object_get_data (G_OBJECT (msg), "SoupSession");
rpm-build 4f3c61
rpm-build 4f3c61
	*out_iostream = soup_session_steal_connection (session, msg);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
static void
rpm-build 4f3c61
do_stealing_test (gconstpointer data)
rpm-build 4f3c61
{
rpm-build 4f3c61
	gboolean sync = GPOINTER_TO_INT (data);
rpm-build 4f3c61
	SoupServer *server;
rpm-build 4f3c61
	SoupURI *uri;
rpm-build 4f3c61
	SoupSession *session;
rpm-build 4f3c61
	SoupMessage *msg;
rpm-build 4f3c61
	GIOStream *iostream;
rpm-build 4f3c61
	GInputStream *istream;
rpm-build 4f3c61
	GDataInputStream *distream;
rpm-build 4f3c61
	GOutputStream *ostream;
rpm-build 4f3c61
	int i;
rpm-build 4f3c61
	gssize n;
rpm-build 4f3c61
	char *str, *caps;
rpm-build 4f3c61
	GError *error = NULL;
rpm-build 4f3c61
	static const char *strings[] = { "one", "two", "three", "four", "five" };
rpm-build 4f3c61
rpm-build 4f3c61
	server = soup_test_server_new (SOUP_TEST_SERVER_IN_THREAD);
rpm-build 4f3c61
	uri = soup_test_server_get_uri (server, SOUP_URI_SCHEME_HTTP, "127.0.0.1");
rpm-build 4f3c61
	soup_server_add_handler (server, NULL, upgrade_server_callback, NULL, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	session = soup_test_session_new (SOUP_TYPE_SESSION, NULL);
rpm-build 4f3c61
	msg = soup_message_new_from_uri ("GET", uri);
rpm-build 4f3c61
	soup_message_headers_append (msg->request_headers, "Upgrade", "echo");
rpm-build 4f3c61
	soup_message_headers_append (msg->request_headers, "Connection", "upgrade");
rpm-build 4f3c61
	g_object_set_data (G_OBJECT (msg), "SoupSession", session);
rpm-build 4f3c61
rpm-build 4f3c61
	soup_message_add_status_code_handler (msg, "got-informational",
rpm-build 4f3c61
					      SOUP_STATUS_SWITCHING_PROTOCOLS,
rpm-build 4f3c61
					      G_CALLBACK (switching_protocols), &iostream);
rpm-build 4f3c61
rpm-build 4f3c61
	iostream = NULL;
rpm-build 4f3c61
rpm-build 4f3c61
	if (sync) {
rpm-build 4f3c61
		soup_session_send_message (session, msg);
rpm-build 4f3c61
		soup_test_assert_message_status (msg, SOUP_STATUS_SWITCHING_PROTOCOLS);
rpm-build 4f3c61
	} else {
rpm-build 4f3c61
		g_object_ref (msg);
rpm-build 4f3c61
		soup_session_queue_message (session, msg, callback_not_reached, NULL);
rpm-build 4f3c61
		while (iostream == NULL)
rpm-build 4f3c61
			g_main_context_iteration (NULL, TRUE);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	g_assert (iostream != NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (msg);
rpm-build 4f3c61
	soup_test_session_abort_unref (session);
rpm-build 4f3c61
	soup_uri_free (uri);
rpm-build 4f3c61
rpm-build 4f3c61
	/* Now iostream connects to a (capitalizing) echo server */
rpm-build 4f3c61
rpm-build 4f3c61
	istream = g_io_stream_get_input_stream (iostream);
rpm-build 4f3c61
	distream = G_DATA_INPUT_STREAM (g_data_input_stream_new (istream));
rpm-build 4f3c61
	ostream = g_io_stream_get_output_stream (iostream);
rpm-build 4f3c61
rpm-build 4f3c61
	for (i = 0; i < G_N_ELEMENTS (strings); i++) {
rpm-build 4f3c61
		n = g_output_stream_write (ostream, strings[i], strlen (strings[i]),
rpm-build 4f3c61
					   NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		g_assert_cmpint (n, ==, strlen (strings[i]));
rpm-build 4f3c61
		n = g_output_stream_write (ostream, "\n", 1, NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		g_assert_cmpint (n, ==, 1);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	for (i = 0; i < G_N_ELEMENTS (strings); i++) {
rpm-build 4f3c61
		str = g_data_input_stream_read_line (distream, NULL, NULL, &error);
rpm-build 4f3c61
		g_assert_no_error (error);
rpm-build 4f3c61
		caps = g_ascii_strup (strings[i], -1);
rpm-build 4f3c61
		g_assert_cmpstr (caps, ==, str);
rpm-build 4f3c61
		g_free (caps);
rpm-build 4f3c61
		g_free (str);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	g_object_unref (distream);
rpm-build 4f3c61
rpm-build 4f3c61
	g_io_stream_close (iostream, NULL, &error);
rpm-build 4f3c61
	g_assert_no_error (error);
rpm-build 4f3c61
	g_object_unref (iostream);
rpm-build 4f3c61
rpm-build 4f3c61
	/* We can't do this until the end because it's in another thread, and
rpm-build 4f3c61
	 * soup_test_server_quit_unref() will wait for that thread to exit.
rpm-build 4f3c61
	 */ 
rpm-build 4f3c61
	soup_test_server_quit_unref (server);
rpm-build 4f3c61
}
rpm-build 4f3c61
rpm-build 4f3c61
int
rpm-build 4f3c61
main (int argc, char **argv)
rpm-build 4f3c61
{
rpm-build 4f3c61
	SoupAuthDomain *auth_domain;
rpm-build 4f3c61
	int ret;
rpm-build 4f3c61
rpm-build 4f3c61
	test_init (argc, argv, NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	server = soup_test_server_new (SOUP_TEST_SERVER_IN_THREAD);
rpm-build 4f3c61
	soup_server_add_handler (server, NULL, server_callback, "http", NULL);
rpm-build 4f3c61
	base_uri = soup_test_server_get_uri (server, "http", NULL);
rpm-build 4f3c61
rpm-build 4f3c61
	auth_domain = soup_auth_domain_basic_new (
rpm-build 4f3c61
		SOUP_AUTH_DOMAIN_REALM, "misc-test",
rpm-build 4f3c61
		SOUP_AUTH_DOMAIN_ADD_PATH, "/auth",
rpm-build 4f3c61
		SOUP_AUTH_DOMAIN_BASIC_AUTH_CALLBACK, auth_callback,
rpm-build 4f3c61
		NULL);
rpm-build 4f3c61
	soup_server_add_auth_domain (server, auth_domain);
rpm-build 4f3c61
	g_object_unref (auth_domain);
rpm-build 4f3c61
rpm-build 4f3c61
	if (tls_available) {
rpm-build 4f3c61
		ssl_server = soup_test_server_new (SOUP_TEST_SERVER_IN_THREAD);
rpm-build 4f3c61
		soup_server_add_handler (ssl_server, NULL, server_callback, "https", NULL);
rpm-build 4f3c61
		ssl_base_uri = soup_test_server_get_uri (ssl_server, "https", "127.0.0.1");
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	g_test_add_func ("/misc/bigheader", do_host_big_header);
rpm-build 4f3c61
	g_test_add_func ("/misc/host", do_host_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/callback-unref/msg", do_callback_unref_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/callback-unref/req", do_callback_unref_req_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/msg-reuse", do_msg_reuse_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/early-abort/msg", do_early_abort_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/early-abort/req", do_early_abort_req_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/accept-language", do_accept_language_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/cancel-while-reading/msg", do_cancel_while_reading_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/cancel-while-reading/req/immediate", do_cancel_while_reading_immediate_req_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/cancel-while-reading/req/delayed", do_cancel_while_reading_delayed_req_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/cancel-while-reading/req/preemptive", do_cancel_while_reading_preemptive_req_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/aliases", do_aliases_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/idle-on-dispose", do_idle_on_dispose_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/pause-abort", do_pause_abort_test);
rpm-build 4f3c61
	g_test_add_func ("/misc/pause-cancel", do_pause_cancel_test);
rpm-build 4f3c61
	g_test_add_data_func ("/misc/stealing/async", GINT_TO_POINTER (FALSE), do_stealing_test);
rpm-build 4f3c61
	g_test_add_data_func ("/misc/stealing/sync", GINT_TO_POINTER (TRUE), do_stealing_test);
rpm-build 4f3c61
rpm-build 4f3c61
	ret = g_test_run ();
rpm-build 4f3c61
rpm-build 4f3c61
	soup_uri_free (base_uri);
rpm-build 4f3c61
	soup_test_server_quit_unref (server);
rpm-build 4f3c61
rpm-build 4f3c61
	if (tls_available) {
rpm-build 4f3c61
		soup_uri_free (ssl_base_uri);
rpm-build 4f3c61
		soup_test_server_quit_unref (ssl_server);
rpm-build 4f3c61
	}
rpm-build 4f3c61
rpm-build 4f3c61
	test_cleanup ();
rpm-build 4f3c61
	return ret;
rpm-build 4f3c61
}