|
Packit Service |
ca3877 |
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
#include "test-utils.h"
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
static void
|
|
Packit Service |
ca3877 |
do_ssl_test_for_session (SoupSession *session, SoupURI *uri)
|
|
Packit Service |
ca3877 |
{
|
|
Packit Service |
ca3877 |
SoupMessage *msg;
|
|
Packit Service |
ca3877 |
GTlsCertificate *cert = NULL;
|
|
Packit Service |
ca3877 |
GTlsCertificateFlags flags;
|
|
Packit Service |
ca3877 |
gboolean is_https;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
msg = soup_message_new_from_uri ("GET", uri);
|
|
Packit Service |
ca3877 |
soup_session_send_message (session, msg);
|
|
Packit Service |
ca3877 |
soup_test_assert_message_status (msg, SOUP_STATUS_SSL_FAILED);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
is_https = soup_message_get_https_status (msg, &cert, &flags);
|
|
Packit Service |
ca3877 |
soup_test_assert (!is_https, "get_http_status() returned TRUE? (flags %x)", flags);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_assert_null (cert);
|
|
Packit Service |
ca3877 |
g_assert_false (soup_message_get_flags (msg) & SOUP_MESSAGE_CERTIFICATE_TRUSTED);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_object_unref (msg);
|
|
Packit Service |
ca3877 |
}
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
static void
|
|
Packit Service |
ca3877 |
do_ssl_tests (gconstpointer data)
|
|
Packit Service |
ca3877 |
{
|
|
Packit Service |
ca3877 |
SoupURI *uri = (SoupURI *)data;
|
|
Packit Service |
ca3877 |
SoupSession *session;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_test_bug ("700518");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
debug_printf (1, " plain\n");
|
|
Packit Service |
ca3877 |
session = soup_test_session_new (SOUP_TYPE_SESSION, NULL);
|
|
Packit Service |
ca3877 |
do_ssl_test_for_session (session, uri);
|
|
Packit Service |
ca3877 |
soup_test_session_abort_unref (session);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
debug_printf (1, " async\n");
|
|
Packit Service |
ca3877 |
session = soup_test_session_new (SOUP_TYPE_SESSION_ASYNC, NULL);
|
|
Packit Service |
ca3877 |
do_ssl_test_for_session (session, uri);
|
|
Packit Service |
ca3877 |
soup_test_session_abort_unref (session);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
debug_printf (1, " sync\n");
|
|
Packit Service |
ca3877 |
session = soup_test_session_new (SOUP_TYPE_SESSION_SYNC, NULL);
|
|
Packit Service |
ca3877 |
do_ssl_test_for_session (session, uri);
|
|
Packit Service |
ca3877 |
soup_test_session_abort_unref (session);
|
|
Packit Service |
ca3877 |
}
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
static void
|
|
Packit Service |
ca3877 |
do_session_property_tests (void)
|
|
Packit Service |
ca3877 |
{
|
|
Packit Service |
ca3877 |
gboolean use_system;
|
|
Packit Service |
ca3877 |
GTlsDatabase *tlsdb;
|
|
Packit Service |
ca3877 |
char *ca_file;
|
|
Packit Service |
ca3877 |
SoupSession *session;
|
|
Packit Service |
ca3877 |
GParamSpec *pspec;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_test_bug ("700518");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
G_GNUC_BEGIN_IGNORE_DEPRECATIONS;
|
|
Packit Service |
ca3877 |
session = soup_session_async_new ();
|
|
Packit Service |
ca3877 |
G_GNUC_END_IGNORE_DEPRECATIONS;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
/* Temporarily undeprecate SOUP_SESSION_SSL_CA_FILE to avoid warnings. */
|
|
Packit Service |
ca3877 |
pspec = g_object_class_find_property (g_type_class_peek (SOUP_TYPE_SESSION),
|
|
Packit Service |
ca3877 |
SOUP_SESSION_SSL_CA_FILE);
|
|
Packit Service |
ca3877 |
pspec->flags &= ~G_PARAM_DEPRECATED;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_object_get (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-use-system-ca-file", &use_system,
|
|
Packit Service |
ca3877 |
"tls-database", &tlsdb,
|
|
Packit Service |
ca3877 |
"ssl-ca-file", &ca_file,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
soup_test_assert (!use_system, "ssl-use-system-ca-file defaults to TRUE");
|
|
Packit Service |
ca3877 |
soup_test_assert (tlsdb == NULL, "tls-database set by default");
|
|
Packit Service |
ca3877 |
soup_test_assert (ca_file == NULL, "ca-file set by default");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_object_set (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-use-system-ca-file", TRUE,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
g_object_get (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-ca-file", &ca_file,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
soup_test_assert (ca_file == NULL, "setting ssl-use-system-ca-file set ssl-ca-file");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_object_set (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-ca-file",
|
|
Packit Service |
ca3877 |
g_test_get_filename (G_TEST_DIST, "test-cert.pem", NULL),
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
g_object_get (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-use-system-ca-file", &use_system,
|
|
Packit Service |
ca3877 |
"tls-database", &tlsdb,
|
|
Packit Service |
ca3877 |
"ssl-ca-file", &ca_file,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
soup_test_assert (ca_file == NULL, "setting ssl-ca-file did not fail");
|
|
Packit Service |
ca3877 |
soup_test_assert (!use_system, "setting ssl-ca-file set ssl-use-system-ca-file");
|
|
Packit Service |
ca3877 |
soup_test_assert (tlsdb == NULL, "setting ssl-ca-file set tls-database");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_object_set (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"tls-database", NULL,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
g_object_get (G_OBJECT (session),
|
|
Packit Service |
ca3877 |
"ssl-use-system-ca-file", &use_system,
|
|
Packit Service |
ca3877 |
"tls-database", &tlsdb,
|
|
Packit Service |
ca3877 |
"ssl-ca-file", &ca_file,
|
|
Packit Service |
ca3877 |
NULL);
|
|
Packit Service |
ca3877 |
soup_test_assert (tlsdb == NULL, "setting tls-database NULL failed");
|
|
Packit Service |
ca3877 |
soup_test_assert (!use_system, "setting tls-database NULL set ssl-use-system-ca-file");
|
|
Packit Service |
ca3877 |
soup_test_assert (ca_file == NULL, "setting tls-database NULL set ssl-ca-file");
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
soup_test_session_abort_unref (session);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
/* Re-deprecate SOUP_SESSION_SSL_CA_FILE */
|
|
Packit Service |
ca3877 |
pspec->flags |= G_PARAM_DEPRECATED;
|
|
Packit Service |
ca3877 |
}
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
static void
|
|
Packit Service |
ca3877 |
server_handler (SoupServer *server,
|
|
Packit Service |
ca3877 |
SoupMessage *msg,
|
|
Packit Service |
ca3877 |
const char *path,
|
|
Packit Service |
ca3877 |
GHashTable *query,
|
|
Packit Service |
ca3877 |
SoupClientContext *client,
|
|
Packit Service |
ca3877 |
gpointer user_data)
|
|
Packit Service |
ca3877 |
{
|
|
Packit Service |
ca3877 |
soup_message_set_status (msg, SOUP_STATUS_OK);
|
|
Packit Service |
ca3877 |
soup_message_set_response (msg, "text/plain",
|
|
Packit Service |
ca3877 |
SOUP_MEMORY_STATIC,
|
|
Packit Service |
ca3877 |
"ok\r\n", 4);
|
|
Packit Service |
ca3877 |
}
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
int
|
|
Packit Service |
ca3877 |
main (int argc, char **argv)
|
|
Packit Service |
ca3877 |
{
|
|
Packit Service |
ca3877 |
SoupServer *server;
|
|
Packit Service |
ca3877 |
SoupURI *uri;
|
|
Packit Service |
ca3877 |
guint port;
|
|
Packit Service |
ca3877 |
int ret;
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
/* Force this test to use the dummy TLS backend */
|
|
Packit Service |
ca3877 |
g_setenv ("GIO_USE_TLS", "dummy", TRUE);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
test_init (argc, argv, NULL);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
/* Make a non-SSL server and pretend that it's ssl, which is fine
|
|
Packit Service |
ca3877 |
* since we won't ever actually talk to it anyway. We don't
|
|
Packit Service |
ca3877 |
* currently test that failing to construct an SSL server works.
|
|
Packit Service |
ca3877 |
*/
|
|
Packit Service |
ca3877 |
server = soup_test_server_new (TRUE);
|
|
Packit Service |
ca3877 |
soup_server_add_handler (server, NULL, server_handler, NULL, NULL);
|
|
Packit Service |
ca3877 |
uri = soup_test_server_get_uri (server, "http", NULL);
|
|
Packit Service |
ca3877 |
port = uri->port;
|
|
Packit Service |
ca3877 |
soup_uri_set_scheme (uri, SOUP_URI_SCHEME_HTTPS);
|
|
Packit Service |
ca3877 |
soup_uri_set_port (uri, port);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
g_test_add_func ("/no-ssl/session-properties", do_session_property_tests);
|
|
Packit Service |
ca3877 |
g_test_add_data_func ("/no-ssl/request-error", uri, do_ssl_tests);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
ret = g_test_run ();
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
soup_uri_free (uri);
|
|
Packit Service |
ca3877 |
soup_test_server_quit_unref (server);
|
|
Packit Service |
ca3877 |
|
|
Packit Service |
ca3877 |
test_cleanup ();
|
|
Packit Service |
ca3877 |
return ret;
|
|
Packit Service |
ca3877 |
}
|