mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 22:46:15 +01:00
Merge branch 'wip/gdbus-flags-from-the-future' into 'master'
gdbus: Reject attempts to set future connection or server flags See merge request GNOME/glib!1934
This commit is contained in:
commit
a1db705bc2
@ -120,6 +120,13 @@
|
||||
|
||||
#include "glibintl.h"
|
||||
|
||||
#define G_DBUS_CONNECTION_FLAGS_ALL \
|
||||
(G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_CLIENT | \
|
||||
G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_SERVER | \
|
||||
G_DBUS_CONNECTION_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS | \
|
||||
G_DBUS_CONNECTION_FLAGS_MESSAGE_BUS_CONNECTION | \
|
||||
G_DBUS_CONNECTION_FLAGS_DELAY_MESSAGE_PROCESSING)
|
||||
|
||||
/**
|
||||
* SECTION:gdbusconnection
|
||||
* @short_description: D-Bus Connections
|
||||
@ -2711,6 +2718,7 @@ g_dbus_connection_new (GIOStream *stream,
|
||||
_g_dbus_initialize ();
|
||||
|
||||
g_return_if_fail (G_IS_IO_STREAM (stream));
|
||||
g_return_if_fail ((flags & ~G_DBUS_CONNECTION_FLAGS_ALL) == 0);
|
||||
|
||||
g_async_initable_new_async (G_TYPE_DBUS_CONNECTION,
|
||||
G_PRIORITY_DEFAULT,
|
||||
@ -2799,6 +2807,7 @@ g_dbus_connection_new_sync (GIOStream *stream,
|
||||
{
|
||||
_g_dbus_initialize ();
|
||||
g_return_val_if_fail (G_IS_IO_STREAM (stream), NULL);
|
||||
g_return_val_if_fail ((flags & ~G_DBUS_CONNECTION_FLAGS_ALL) == 0, NULL);
|
||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||
return g_initable_new (G_TYPE_DBUS_CONNECTION,
|
||||
cancellable,
|
||||
@ -2856,6 +2865,7 @@ g_dbus_connection_new_for_address (const gchar *address,
|
||||
_g_dbus_initialize ();
|
||||
|
||||
g_return_if_fail (address != NULL);
|
||||
g_return_if_fail ((flags & ~G_DBUS_CONNECTION_FLAGS_ALL) == 0);
|
||||
|
||||
g_async_initable_new_async (G_TYPE_DBUS_CONNECTION,
|
||||
G_PRIORITY_DEFAULT,
|
||||
@ -2943,6 +2953,7 @@ g_dbus_connection_new_for_address_sync (const gchar *address,
|
||||
_g_dbus_initialize ();
|
||||
|
||||
g_return_val_if_fail (address != NULL, NULL);
|
||||
g_return_val_if_fail ((flags & ~G_DBUS_CONNECTION_FLAGS_ALL) == 0, NULL);
|
||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||
return g_initable_new (G_TYPE_DBUS_CONNECTION,
|
||||
cancellable,
|
||||
|
@ -57,6 +57,10 @@
|
||||
|
||||
#include "glibintl.h"
|
||||
|
||||
#define G_DBUS_SERVER_FLAGS_ALL \
|
||||
(G_DBUS_SERVER_FLAGS_RUN_IN_THREAD | \
|
||||
G_DBUS_SERVER_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS)
|
||||
|
||||
/**
|
||||
* SECTION:gdbusserver
|
||||
* @short_description: Helper for accepting connections
|
||||
@ -512,6 +516,7 @@ g_dbus_server_new_sync (const gchar *address,
|
||||
|
||||
g_return_val_if_fail (address != NULL, NULL);
|
||||
g_return_val_if_fail (g_dbus_is_guid (guid), NULL);
|
||||
g_return_val_if_fail ((flags & ~G_DBUS_SERVER_FLAGS_ALL) == 0, NULL);
|
||||
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
|
||||
|
||||
server = g_initable_new (G_TYPE_DBUS_SERVER,
|
||||
|
@ -1139,6 +1139,183 @@ test_peer (void)
|
||||
|
||||
/* ---------------------------------------------------------------------------------------------------- */
|
||||
|
||||
#define VALID_GUID "0123456789abcdef0123456789abcdef"
|
||||
|
||||
static void
|
||||
test_peer_invalid_server (void)
|
||||
{
|
||||
GDBusServer *server;
|
||||
|
||||
if (!g_test_undefined ())
|
||||
{
|
||||
g_test_skip ("Not exercising programming errors");
|
||||
return;
|
||||
}
|
||||
|
||||
if (g_test_subprocess ())
|
||||
{
|
||||
/* This assumes we are not going to run out of GDBusServerFlags
|
||||
* any time soon */
|
||||
server = g_dbus_server_new_sync ("tcp:", (GDBusServerFlags) (1 << 30),
|
||||
VALID_GUID,
|
||||
NULL, NULL, NULL);
|
||||
g_assert_null (server);
|
||||
}
|
||||
else
|
||||
{
|
||||
g_test_trap_subprocess (NULL, 0, 0);
|
||||
g_test_trap_assert_failed ();
|
||||
g_test_trap_assert_stderr ("*CRITICAL*G_DBUS_SERVER_FLAGS_ALL*");
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
test_peer_invalid_conn_stream_sync (void)
|
||||
{
|
||||
GSocket *sock;
|
||||
GSocketConnection *socket_conn;
|
||||
GIOStream *iostream;
|
||||
GDBusConnection *conn;
|
||||
|
||||
if (!g_test_undefined ())
|
||||
{
|
||||
g_test_skip ("Not exercising programming errors");
|
||||
return;
|
||||
}
|
||||
|
||||
sock = g_socket_new (G_SOCKET_FAMILY_IPV4,
|
||||
G_SOCKET_TYPE_STREAM,
|
||||
G_SOCKET_PROTOCOL_TCP,
|
||||
NULL);
|
||||
|
||||
if (sock == NULL)
|
||||
{
|
||||
g_test_skip ("TCP not available?");
|
||||
return;
|
||||
}
|
||||
|
||||
socket_conn = g_socket_connection_factory_create_connection (sock);
|
||||
g_assert_nonnull (socket_conn);
|
||||
iostream = G_IO_STREAM (socket_conn);
|
||||
g_assert_nonnull (iostream);
|
||||
|
||||
if (g_test_subprocess ())
|
||||
{
|
||||
/* This assumes we are not going to run out of GDBusConnectionFlags
|
||||
* any time soon */
|
||||
conn = g_dbus_connection_new_sync (iostream, VALID_GUID,
|
||||
(GDBusConnectionFlags) (1 << 30),
|
||||
NULL, NULL, NULL);
|
||||
g_assert_null (conn);
|
||||
}
|
||||
else
|
||||
{
|
||||
g_test_trap_subprocess (NULL, 0, 0);
|
||||
g_test_trap_assert_failed ();
|
||||
g_test_trap_assert_stderr ("*CRITICAL*G_DBUS_CONNECTION_FLAGS_ALL*");
|
||||
}
|
||||
|
||||
g_clear_object (&sock);
|
||||
g_clear_object (&socket_conn);
|
||||
}
|
||||
|
||||
static void
|
||||
test_peer_invalid_conn_stream_async (void)
|
||||
{
|
||||
GSocket *sock;
|
||||
GSocketConnection *socket_conn;
|
||||
GIOStream *iostream;
|
||||
|
||||
if (!g_test_undefined ())
|
||||
{
|
||||
g_test_skip ("Not exercising programming errors");
|
||||
return;
|
||||
}
|
||||
|
||||
sock = g_socket_new (G_SOCKET_FAMILY_IPV4,
|
||||
G_SOCKET_TYPE_STREAM,
|
||||
G_SOCKET_PROTOCOL_TCP,
|
||||
NULL);
|
||||
|
||||
if (sock == NULL)
|
||||
{
|
||||
g_test_skip ("TCP not available?");
|
||||
return;
|
||||
}
|
||||
|
||||
socket_conn = g_socket_connection_factory_create_connection (sock);
|
||||
g_assert_nonnull (socket_conn);
|
||||
iostream = G_IO_STREAM (socket_conn);
|
||||
g_assert_nonnull (iostream);
|
||||
|
||||
if (g_test_subprocess ())
|
||||
{
|
||||
g_dbus_connection_new (iostream, VALID_GUID,
|
||||
(GDBusConnectionFlags) (1 << 30),
|
||||
NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
g_test_trap_subprocess (NULL, 0, 0);
|
||||
g_test_trap_assert_failed ();
|
||||
g_test_trap_assert_stderr ("*CRITICAL*G_DBUS_CONNECTION_FLAGS_ALL*");
|
||||
}
|
||||
|
||||
g_clear_object (&sock);
|
||||
g_clear_object (&socket_conn);
|
||||
}
|
||||
|
||||
static void
|
||||
test_peer_invalid_conn_addr_sync (void)
|
||||
{
|
||||
GDBusConnection *conn;
|
||||
|
||||
if (!g_test_undefined ())
|
||||
{
|
||||
g_test_skip ("Not exercising programming errors");
|
||||
return;
|
||||
}
|
||||
|
||||
if (g_test_subprocess ())
|
||||
{
|
||||
conn = g_dbus_connection_new_for_address_sync ("tcp:",
|
||||
(GDBusConnectionFlags) (1 << 30),
|
||||
NULL, NULL, NULL);
|
||||
g_assert_null (conn);
|
||||
}
|
||||
else
|
||||
{
|
||||
g_test_trap_subprocess (NULL, 0, 0);
|
||||
g_test_trap_assert_failed ();
|
||||
g_test_trap_assert_stderr ("*CRITICAL*G_DBUS_CONNECTION_FLAGS_ALL*");
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
test_peer_invalid_conn_addr_async (void)
|
||||
{
|
||||
if (!g_test_undefined ())
|
||||
{
|
||||
g_test_skip ("Not exercising programming errors");
|
||||
return;
|
||||
}
|
||||
|
||||
if (g_test_subprocess ())
|
||||
{
|
||||
g_dbus_connection_new_for_address ("tcp:",
|
||||
(GDBusConnectionFlags) (1 << 30),
|
||||
NULL, NULL, NULL, NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
g_test_trap_subprocess (NULL, 0, 0);
|
||||
g_test_trap_assert_failed ();
|
||||
g_test_trap_assert_stderr ("*CRITICAL*G_DBUS_CONNECTION_FLAGS_ALL*");
|
||||
}
|
||||
}
|
||||
|
||||
/* ---------------------------------------------------------------------------------------------------- */
|
||||
|
||||
static void
|
||||
test_peer_signals (void)
|
||||
{
|
||||
@ -2010,6 +2187,16 @@ main (int argc,
|
||||
test_interface_introspection_data = introspection_data->interfaces[0];
|
||||
|
||||
g_test_add_func ("/gdbus/peer-to-peer", test_peer);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/invalid/server",
|
||||
test_peer_invalid_server);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/invalid/conn/stream/async",
|
||||
test_peer_invalid_conn_stream_async);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/invalid/conn/stream/sync",
|
||||
test_peer_invalid_conn_stream_sync);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/invalid/conn/addr/async",
|
||||
test_peer_invalid_conn_addr_async);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/invalid/conn/addr/sync",
|
||||
test_peer_invalid_conn_addr_sync);
|
||||
g_test_add_func ("/gdbus/peer-to-peer/signals", test_peer_signals);
|
||||
g_test_add_func ("/gdbus/delayed-message-processing", delayed_message_processing);
|
||||
g_test_add_func ("/gdbus/nonce-tcp", test_nonce_tcp);
|
||||
|
Loading…
Reference in New Issue
Block a user