aboutsummaryrefslogtreecommitdiff
path: root/plugins/tests/test-port-context.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2016-01-16 17:32:13 +0100
committerAleksander Morgado <aleksander@aleksander.es>2016-01-16 17:59:49 +0100
commit7136c0b32103eda1d62a16a47dfdb37b166fa610 (patch)
tree9067b9f1026a9227138a6701f6696d6b67a8fed2 /plugins/tests/test-port-context.c
parentdfd111f29112918d7f2046297670a7481a883354 (diff)
tests,port-context: explicitly close the socket that is added to the listener
Since GLib 2.42, the sockets that are added to socket listeners may no longer be closed automatically when the listener is finalized. In order to avoid that, we will keep our own socket reference and close/unref it ourselves. This issue was preventing adding new test cases with the same port names. $ ./test-service-generic --verbose GTest: random seed: R02S889153ee0f2e59c570f4edff9caa4176 GTest: run: /MM/Service/Generic/enable-disable Activating service name='org.freedesktop.ModemManager1' Successfully activated service 'org.freedesktop.ModemManager1' (MSG: DEBUG: client connection closed) (MSG: MESSAGE: Found modem at '/org/freedesktop/ModemManager1/Modem/0') ** Message: Found modem at '/org/freedesktop/ModemManager1/Modem/0' (MSG: DEBUG: client connection closed) GTest: result: OK GTest: run: /MM/Service/Generic/cme-error-detected Activating service name='org.freedesktop.ModemManager1' Successfully activated service 'org.freedesktop.ModemManager1' (MSG: FATAL-ERROR: Cannot bind socket: Error binding to address: Address already in use) ** (/home/aleksander/Development/foss/ModemManager/plugins/.libs/lt-test-service-generic:32043): ERROR **: Cannot bind socket: Error binding to address: Address already in use
Diffstat (limited to 'plugins/tests/test-port-context.c')
-rw-r--r--plugins/tests/test-port-context.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/plugins/tests/test-port-context.c b/plugins/tests/test-port-context.c
index d3a35728..8e957857 100644
--- a/plugins/tests/test-port-context.c
+++ b/plugins/tests/test-port-context.c
@@ -29,6 +29,7 @@ struct _TestPortContext {
GMutex ready_mutex;
GMainLoop *loop;
GMainContext *context;
+ GSocket *socket;
GSocketService *socket_service;
GList *clients;
GHashTable *commands;
@@ -280,6 +281,7 @@ create_socket_service (TestPortContext *self)
G_UNIX_SOCKET_ADDRESS_ABSTRACT));
if (!g_socket_bind (socket, address, TRUE, &error))
g_error ("Cannot bind socket: %s", error->message);
+ g_object_unref (address);
/* Listen */
if (!g_socket_listen (socket, &error))
@@ -297,19 +299,17 @@ create_socket_service (TestPortContext *self)
/* Start it */
g_socket_service_start (service);
- /* And store it */
+ /* And store both the service and the socket.
+ * Since GLib 2.42 the socket may not be explicitly closed when the
+ * listener is diposed, so we'll do it ourselves. */
self->socket_service = service;
+ self->socket = socket;
/* Signal that the thread is ready */
g_mutex_lock (&self->ready_mutex);
self->ready = TRUE;
g_cond_signal (&self->ready_cond);
g_mutex_unlock (&self->ready_mutex);
-
- if (socket)
- g_object_unref (socket);
- if (address)
- g_object_unref (address);
}
/*****************************************************************************/
@@ -389,6 +389,15 @@ test_port_context_free (TestPortContext *self)
if (self->commands)
g_hash_table_unref (self->commands);
g_list_free_full (self->clients, (GDestroyNotify)client_free);
+ if (self->socket) {
+ GError *error = NULL;
+
+ if (!g_socket_close (self->socket, &error)) {
+ g_debug ("Couldn't close socket: %s", error->message);
+ g_error_free (error);
+ }
+ g_object_unref (self->socket);
+ }
if (self->socket_service) {
if (g_socket_service_is_active (self->socket_service))
g_socket_service_stop (self->socket_service);