gio: do not cache document portal D-Bus proxy

By removing the cached global proxy in gdocumentportal.c, we can
re-enable the checks for proper shutdown of the session bus connection
in the dbus-appinfo.c test.
This commit is contained in:
James Henstridge 2019-12-17 17:33:04 +08:00
parent 926ff8c6a7
commit e24db62363
2 changed files with 41 additions and 56 deletions

View File

@ -37,56 +37,47 @@
#define HAVE_O_CLOEXEC 1
#endif
static GXdpDocuments *documents;
static char *documents_mountpoint;
static gboolean
init_document_portal (void)
get_document_portal (GXdpDocuments **documents,
char **documents_mountpoint,
GError **error)
{
static gsize documents_inited = 0;
GDBusConnection *connection = NULL;
if (g_once_init_enter (&documents_inited))
{
GError *error = NULL;
GDBusConnection *connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
*documents = NULL;
*documents_mountpoint = NULL;
if (connection != NULL)
connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, error);
if (connection == NULL)
{
documents = gxdp_documents_proxy_new_sync (connection, 0,
g_prefix_error (error, "Cannot connect to session bus when initializing document portal: ");
goto out;
}
*documents = gxdp_documents_proxy_new_sync (connection,
G_DBUS_PROXY_FLAGS_DO_NOT_LOAD_PROPERTIES |
G_DBUS_PROXY_FLAGS_DO_NOT_CONNECT_SIGNALS,
"org.freedesktop.portal.Documents",
"/org/freedesktop/portal/documents",
NULL, &error);
if (documents != NULL)
NULL, error);
if (*documents == NULL)
{
gxdp_documents_call_get_mount_point_sync (documents,
&documents_mountpoint,
NULL, &error);
if (error != NULL)
{
g_warning ("Cannot get document portal mount point: %s", error->message);
g_error_free (error);
}
}
else
{
g_warning ("Cannot create document portal proxy: %s", error->message);
g_error_free (error);
g_prefix_error (error, "Cannot create document portal proxy: ");
goto out;
}
g_object_unref (connection);
}
else
if (!gxdp_documents_call_get_mount_point_sync (*documents,
documents_mountpoint,
NULL, error))
{
g_warning ("Cannot connect to session bus when initializing document portal: %s",
error->message);
g_error_free (error);
g_clear_object (documents);
g_prefix_error (error, "Cannot get document portal mount point: ");
goto out;
}
g_once_init_leave (&documents_inited, 1);
}
return (documents != NULL && documents_mountpoint != NULL);
out:
g_clear_object (&connection);
return *documents != NULL;
}
/* Flags accepted by org.freedesktop.portal.Documents.AddFull */
@ -102,6 +93,8 @@ g_document_portal_add_documents (GList *uris,
const char *app_id,
GError **error)
{
GXdpDocuments *documents = NULL;
char *documents_mountpoint = NULL;
int length;
GList *ruris = NULL;
gboolean *as_is;
@ -113,10 +106,8 @@ g_document_portal_add_documents (GList *uris,
char **doc_ids = NULL;
GVariant *extra_out = NULL;
if (!init_document_portal ())
if (!get_document_portal (&documents, &documents_mountpoint, error))
{
g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_INITIALIZED,
"Document portal is not available");
return NULL;
}
@ -213,6 +204,8 @@ g_document_portal_add_documents (GList *uris,
}
out:
g_clear_object (&documents);
g_clear_pointer (&documents_mountpoint, g_free);
g_clear_object (&fd_list);
g_clear_pointer (&extra_out, g_variant_unref);
g_clear_pointer (&doc_ids, g_strfreev);

View File

@ -361,18 +361,10 @@ test_flatpak_doc_export (void)
int
main (int argc, char **argv)
{
int ret;
g_test_init (&argc, &argv, NULL);
g_test_add_func ("/appinfo/dbusappinfo", test_dbus_appinfo);
g_test_add_func ("/appinfo/flatpak-doc-export", test_flatpak_doc_export);
session_bus_up ();
ret = g_test_run ();
/* gdocumentportal.c holds a reference to the session bus
* connection, which prevents session_bus_down from completing
* successfully. */
session_bus_stop ();
return ret;
return session_bus_run ();
}