docs: Move the GTestDBus SECTION

Move it to the struct docs.

Signed-off-by: Philip Withnall <philip@tecnocode.co.uk>

Helps: #3037
This commit is contained in:
Philip Withnall 2023-10-25 15:08:03 +01:00
parent ed875eb4c9
commit 5817f52222

View File

@ -333,25 +333,23 @@ _g_test_watcher_remove_pid (GPid pid)
/* GTestDBus object implementation */ /* GTestDBus object implementation */
/** /**
* SECTION:gtestdbus * GTestDBus:
* @short_description: D-Bus testing helper
* @include: gio/gio.h
* *
* A helper class for testing code which uses D-Bus without touching the user's * A helper class for testing code which uses D-Bus without touching the users
* session bus. * session bus.
* *
* Note that #GTestDBus modifies the users environment, calling setenv(). * Note that `GTestDBus` modifies the users environment, calling
* This is not thread-safe, so all #GTestDBus calls should be completed before * [`setenv()`](man:setenv(3)). This is not thread-safe, so all `GTestDBus`
* threads are spawned, or should have appropriate locking to ensure no access * calls should be completed before threads are spawned, or should have
* conflicts to environment variables shared between #GTestDBus and other * appropriate locking to ensure no access conflicts to environment variables
* threads. * shared between `GTestDBus` and other threads.
* *
* ## Creating unit tests using GTestDBus * ## Creating unit tests using `GTestDBus`
* *
* Testing of D-Bus services can be tricky because normally we only ever run * Testing of D-Bus services can be tricky because normally we only ever run
* D-Bus services over an existing instance of the D-Bus daemon thus we * D-Bus services over an existing instance of the D-Bus daemon thus we
* usually don't activate D-Bus services that are not yet installed into the * usually dont activate D-Bus services that are not yet installed into the
* target system. The #GTestDBus object makes this easier for us by taking care * target system. The `GTestDBus` object makes this easier for us by taking care
* of the lower level tasks such as running a private D-Bus daemon and looking * of the lower level tasks such as running a private D-Bus daemon and looking
* up uninstalled services in customizable locations, typically in your source * up uninstalled services in customizable locations, typically in your source
* code tree. * code tree.
@ -364,20 +362,24 @@ _g_test_watcher_remove_pid (GPid pid)
* uninstalled service executable in your source tree. Using autotools we would * uninstalled service executable in your source tree. Using autotools we would
* achieve this by adding a file such as `my-server.service.in` in the services * achieve this by adding a file such as `my-server.service.in` in the services
* directory and have it processed by configure. * directory and have it processed by configure.
* |[ *
* ```
* [D-BUS Service] * [D-BUS Service]
* Name=org.gtk.GDBus.Examples.ObjectManager * Name=org.gtk.GDBus.Examples.ObjectManager
* Exec=@abs_top_builddir@/gio/tests/gdbus-example-objectmanager-server * Exec=@abs_top_builddir@/gio/tests/gdbus-example-objectmanager-server
* ]| * ```
*
* You will also need to indicate this service directory in your test * You will also need to indicate this service directory in your test
* fixtures, so you will need to pass the path while compiling your * fixtures, so you will need to pass the path while compiling your
* test cases. Typically this is done with autotools with an added * test cases. Typically this is done with autotools with an added
* preprocessor flag specified to compile your tests such as: * preprocessor flag specified to compile your tests such as:
* |[ *
* ```
* -DTEST_SERVICES=\""$(abs_top_builddir)/tests/services"\" * -DTEST_SERVICES=\""$(abs_top_builddir)/tests/services"\"
* ]| * ```
*
* Once you have a service definition file which is local to your source tree, * Once you have a service definition file which is local to your source tree,
* you can proceed to set up a GTest fixture using the #GTestDBus scaffolding. * you can proceed to set up a GTest fixture using the `GTestDBus` scaffolding.
* *
* An example of a test fixture for D-Bus services can be found * An example of a test fixture for D-Bus services can be found
* here: * here:
@ -386,42 +388,39 @@ _g_test_watcher_remove_pid (GPid pid)
* Note that these examples only deal with isolating the D-Bus aspect of your * Note that these examples only deal with isolating the D-Bus aspect of your
* service. To successfully run isolated unit tests on your service you may need * service. To successfully run isolated unit tests on your service you may need
* some additional modifications to your test case fixture. For example; if your * some additional modifications to your test case fixture. For example; if your
* service uses GSettings and installs a schema then it is important that your test service * service uses [class@Gio.Settings] and installs a schema then it is important
* not load the schema in the ordinary installed location (chances are that your service * that your test service not load the schema in the ordinary installed location
* and schema files are not yet installed, or worse; there is an older version of the * (chances are that your service and schema files are not yet installed, or
* schema file sitting in the install location). * worse; there is an older version of the schema file sitting in the install
* location).
* *
* Most of the time we can work around these obstacles using the * Most of the time we can work around these obstacles using the
* environment. Since the environment is inherited by the D-Bus daemon * environment. Since the environment is inherited by the D-Bus daemon
* created by #GTestDBus and then in turn inherited by any services the * created by `GTestDBus` and then in turn inherited by any services the
* D-Bus daemon activates, using the setup routine for your fixture is * D-Bus daemon activates, using the setup routine for your fixture is
* a practical place to help sandbox your runtime environment. For the * a practical place to help sandbox your runtime environment. For the
* rather typical GSettings case we can work around this by setting * rather typical GSettings case we can work around this by setting
* `GSETTINGS_SCHEMA_DIR` to the in tree directory holding your schemas * `GSETTINGS_SCHEMA_DIR` to the in tree directory holding your schemas
* in the above fixture_setup() routine. * in the above `fixture_setup()` routine.
* *
* The GSettings schemas need to be locally pre-compiled for this to work. This can be achieved * The GSettings schemas need to be locally pre-compiled for this to work. This
* by compiling the schemas locally as a step before running test cases, an autotools setup might * can be achieved by compiling the schemas locally as a step before running
* do the following in the directory holding schemas: * test cases, an autotools setup might do the following in the directory
* |[ * holding schemas:
*
* ```
* all-am: * all-am:
* $(GLIB_COMPILE_SCHEMAS) . * $(GLIB_COMPILE_SCHEMAS) .
* *
* CLEANFILES += gschemas.compiled * CLEANFILES += gschemas.compiled
* ]| * ```
*
* Since: 2.34
*/ */
typedef struct _GTestDBusClass GTestDBusClass; typedef struct _GTestDBusClass GTestDBusClass;
typedef struct _GTestDBusPrivate GTestDBusPrivate; typedef struct _GTestDBusPrivate GTestDBusPrivate;
/**
* GTestDBus:
*
* The #GTestDBus structure contains only private data and
* should only be accessed using the provided API.
*
* Since: 2.34
*/
struct _GTestDBus { struct _GTestDBus {
GObject parent; GObject parent;