meson: gio/tests: add more gio tests

Need to fix up some of the tests a little, because the
test binary will not necessarily be run from the current
build sub-directory, and the build directory structure
might not always be a mirror of the source directory
structure, so pass location of glib-mkenums and
glib-compile-scheme and such directly.
This commit is contained in:
Tim-Philipp Müller 2017-02-24 09:46:36 +00:00 committed by Matthias Clasen
parent 1acd6de763
commit 613e00826e
6 changed files with 96 additions and 11 deletions

View File

@ -773,7 +773,7 @@ executable('gio-querymodules', 'gio-querymodules.c',
link_args : noseh_link_args, link_args : noseh_link_args,
dependencies : [libgio_dep, libgobject_dep, libgmodule_dep, libglib_dep]) dependencies : [libgio_dep, libgobject_dep, libgmodule_dep, libglib_dep])
executable('glib-compile-schemas', glib_compile_schemas = executable('glib-compile-schemas',
[gconstructor_as_data_h, 'gvdb/gvdb-builder.c', 'glib-compile-schemas.c'], [gconstructor_as_data_h, 'gvdb/gvdb-builder.c', 'glib-compile-schemas.c'],
install : true, install : true,
c_args : ['-DHAVE_CONFIG_H=1'], c_args : ['-DHAVE_CONFIG_H=1'],

View File

@ -2,6 +2,7 @@
#include <locale.h> #include <locale.h>
#include <string.h> #include <string.h>
#include <glib/gstdio.h>
#include <gio/gio.h> #include <gio/gio.h>
#include <gio/gdesktopappinfo.h> #include <gio/gdesktopappinfo.h>
@ -474,10 +475,18 @@ test_from_keyfile (void)
int int
main (int argc, char *argv[]) main (int argc, char *argv[])
{ {
const gchar *build_dir;
g_setenv ("XDG_CURRENT_DESKTOP", "GNOME", TRUE); g_setenv ("XDG_CURRENT_DESKTOP", "GNOME", TRUE);
g_test_init (&argc, &argv, NULL); g_test_init (&argc, &argv, NULL);
/* With Meson build we need to change into right directory, so that the
* appinfo-test binary can be found. */
build_dir = g_getenv ("G_TEST_BUILDDIR");
if (build_dir)
g_chdir (build_dir);
g_test_add_func ("/appinfo/basic", test_basic); g_test_add_func ("/appinfo/basic", test_basic);
g_test_add_func ("/appinfo/text", test_text); g_test_add_func ("/appinfo/text", test_text);
g_test_add_func ("/appinfo/launch", test_launch); g_test_add_func ("/appinfo/launch", test_launch);

View File

@ -18,6 +18,7 @@
*/ */
#include <glib/glib.h> #include <glib/glib.h>
#include <glib/gstdio.h>
#include <gio/gio.h> #include <gio/gio.h>
#include <gio/gdesktopappinfo.h> #include <gio/gdesktopappinfo.h>
#include <stdlib.h> #include <stdlib.h>
@ -759,8 +760,15 @@ int
main (int argc, main (int argc,
char *argv[]) char *argv[])
{ {
const gchar *build_dir;
gint result; gint result;
/* With Meson build we need to change into right directory, so that the
* appinfo-test binary can be found. */
build_dir = g_getenv ("G_TEST_BUILDDIR");
if (build_dir)
g_chdir (build_dir);
g_test_init (&argc, &argv, NULL); g_test_init (&argc, &argv, NULL);
basedir = g_get_current_dir (); basedir = g_get_current_dir ();

View File

@ -11,6 +11,11 @@ typedef struct {
const gchar *err; const gchar *err;
} SchemaTest; } SchemaTest;
/* Meson build defines this, autotools build does not */
#ifndef GLIB_COMPILE_SCHEMAS
#define GLIB_COMPILE_SCHEMAS "../glib-compile-schemas"
#endif
static void static void
test_schema_do_compile (gpointer data) test_schema_do_compile (gpointer data)
{ {
@ -18,7 +23,7 @@ test_schema_do_compile (gpointer data)
gchar *filename = g_strconcat (test->name, ".gschema.xml", NULL); gchar *filename = g_strconcat (test->name, ".gschema.xml", NULL);
gchar *path = g_test_build_filename (G_TEST_DIST, "schema-tests", filename, NULL); gchar *path = g_test_build_filename (G_TEST_DIST, "schema-tests", filename, NULL);
gchar *argv[] = { gchar *argv[] = {
"../glib-compile-schemas", GLIB_COMPILE_SCHEMAS,
"--strict", "--strict",
"--dry-run", "--dry-run",
"--schema-file", path, "--schema-file", path,

View File

@ -8,6 +8,8 @@
#include "testenum.h" #include "testenum.h"
static const gchar *locale_dir = ".";
static gboolean backend_set; static gboolean backend_set;
/* These tests rely on the schemas in org.gtk.test.gschema.xml /* These tests rely on the schemas in org.gtk.test.gschema.xml
@ -732,7 +734,7 @@ test_l10n (void)
gchar *str; gchar *str;
gchar *locale; gchar *locale;
bindtextdomain ("test", "."); bindtextdomain ("test", locale_dir);
bind_textdomain_codeset ("test", "UTF-8"); bind_textdomain_codeset ("test", "UTF-8");
locale = g_strdup (setlocale (LC_MESSAGES, NULL)); locale = g_strdup (setlocale (LC_MESSAGES, NULL));
@ -779,7 +781,7 @@ test_l10n_context (void)
gchar *str; gchar *str;
gchar *locale; gchar *locale;
bindtextdomain ("test", "."); bindtextdomain ("test", locale_dir);
bind_textdomain_codeset ("test", "UTF-8"); bind_textdomain_codeset ("test", "UTF-8");
locale = g_strdup (setlocale (LC_MESSAGES, NULL)); locale = g_strdup (setlocale (LC_MESSAGES, NULL));
@ -2604,6 +2606,14 @@ main (int argc, char *argv[])
gchar *enums; gchar *enums;
gint result; gint result;
/* Meson build sets this */
#ifdef TEST_LOCALE_PATH
if (g_str_has_suffix (TEST_LOCALE_PATH, "LC_MESSAGES"))
{
locale_dir = TEST_LOCALE_PATH G_DIR_SEPARATOR_S ".." G_DIR_SEPARATOR_S "..";
}
#endif
setlocale (LC_ALL, ""); setlocale (LC_ALL, "");
g_test_init (&argc, &argv, NULL); g_test_init (&argc, &argv, NULL);
@ -2619,8 +2629,13 @@ main (int argc, char *argv[])
if (!backend_set) if (!backend_set)
g_setenv ("GSETTINGS_BACKEND", "memory", TRUE); g_setenv ("GSETTINGS_BACKEND", "memory", TRUE);
/* Meson build defines this, autotools build does not */
#ifndef GLIB_MKENUMS
#define GLIB_MKENUMS "../../gobject/glib-mkenums"
#endif
g_remove ("org.gtk.test.enums.xml"); g_remove ("org.gtk.test.enums.xml");
g_assert (g_spawn_command_line_sync ("../../gobject/glib-mkenums " g_assert (g_spawn_command_line_sync (GLIB_MKENUMS " "
"--template " SRCDIR "/enums.xml.template " "--template " SRCDIR "/enums.xml.template "
SRCDIR "/testenum.h", SRCDIR "/testenum.h",
&enums, NULL, &result, NULL)); &enums, NULL, &result, NULL));
@ -2632,8 +2647,13 @@ main (int argc, char *argv[])
g_assert (g_file_set_contents ("org.gtk.test.gschema.xml", schema_text, -1, NULL)); g_assert (g_file_set_contents ("org.gtk.test.gschema.xml", schema_text, -1, NULL));
g_free (schema_text); g_free (schema_text);
/* Meson build defines this, autotools build does not */
#ifndef GLIB_COMPILE_SCHEMAS
#define GLIB_COMPILE_SCHEMAS "../glib-compile-schemas"
#endif
g_remove ("gschemas.compiled"); g_remove ("gschemas.compiled");
g_assert (g_spawn_command_line_sync ("../glib-compile-schemas --targetdir=. " g_assert (g_spawn_command_line_sync (GLIB_COMPILE_SCHEMAS " --targetdir=. "
"--schema-file=org.gtk.test.enums.xml " "--schema-file=org.gtk.test.enums.xml "
"--schema-file=org.gtk.test.gschema.xml", "--schema-file=org.gtk.test.gschema.xml",
NULL, NULL, &result, NULL)); NULL, NULL, &result, NULL));
@ -2641,7 +2661,7 @@ main (int argc, char *argv[])
g_remove ("schema-source/gschemas.compiled"); g_remove ("schema-source/gschemas.compiled");
g_mkdir ("schema-source", 0777); g_mkdir ("schema-source", 0777);
g_assert (g_spawn_command_line_sync ("../glib-compile-schemas --targetdir=schema-source " g_assert (g_spawn_command_line_sync (GLIB_COMPILE_SCHEMAS " --targetdir=schema-source "
"--schema-file=" SRCDIR "/org.gtk.schemasourcecheck.gschema.xml", "--schema-file=" SRCDIR "/org.gtk.schemasourcecheck.gschema.xml",
NULL, NULL, &result, NULL)); NULL, NULL, &result, NULL));
g_assert (result == 0); g_assert (result == 0);

View File

@ -71,6 +71,8 @@ test_c_args = [
'-DHAVE_CONFIG_H=1', '-DHAVE_CONFIG_H=1',
'-DG_LOG_DOMAIN="GLib-GIO"', '-DG_LOG_DOMAIN="GLib-GIO"',
'-DTEST_SERVICES="@0@/gio/tests/services"'.format(meson.build_root()), '-DTEST_SERVICES="@0@/gio/tests/services"'.format(meson.build_root()),
'-DGLIB_MKENUMS="@0@"'.format(glib_mkenums),
'-DGLIB_COMPILE_SCHEMAS="@0@"'.format(glib_compile_schemas.full_path()),
] ]
# Check for libdbus1 - Optional - is only used in the GDBus test cases # Check for libdbus1 - Optional - is only used in the GDBus test cases
@ -99,6 +101,14 @@ if host_machine.system() != 'windows'
'unix-fd', 'unix-fd',
'unix-streams', 'unix-streams',
'mimeapps', 'mimeapps',
'gschema-compile',
]
# Uninstalled because of the check-for-executable logic in DesktopAppInfo
# unable to find the installed executable
gio_tests += [
'appinfo',
'desktop-app-info',
] ]
test_extra_programs += [ test_extra_programs += [
@ -186,11 +196,44 @@ if host_machine.system() != 'windows'
dependencies : [libglib_dep, libgmodule_dep, libgio_dep]) dependencies : [libglib_dep, libgmodule_dep, libgio_dep])
test('gapplication', exe, env : test_env) test('gapplication', exe, env : test_env)
if host_machine.system() != 'windows' gio_tests += ['gdbus-unix-addresses']
gio_tests += ['gdbus-unix-addresses'] endif # have_dbus_daemon
endif
# This test is currently unreliable
executable('gdbus-overflow', 'gdbus-overflow.c',
install : false,
c_args : test_c_args,
dependencies : [libglib_dep, libgmodule_dep, libgio_dep])
exe = executable('gdbus-connection-flush', 'gdbus-connection-flush.c',
'test-io-stream.c', 'test-pipe-unix.c',
install : false,
c_args : test_c_args,
dependencies : [libglib_dep, libgmodule_dep, libgio_dep])
test('gdbus-connection-flush', exe, env : test_env)
exe = executable('gdbus-non-socket', 'gdbus-non-socket.c',
'gdbus-tests.c', 'test-io-stream.c', 'test-pipe-unix.c',
install : false,
c_args : test_c_args,
dependencies : [libglib_dep, libgmodule_dep, libgio_dep])
test('gdbus-non-socket', exe, env : test_env)
# Generate test.mo from de.po using msgfmt
msgfmt = find_program('msgfmt', required : false)
if msgfmt.found()
subdir('de/LC_MESSAGES')
# gsettings target exe already exists in gio directory
exe = executable('gsettings-test', 'gsettings.c', test_mo,
install : false,
c_args : test_c_args + [
'-DSRCDIR="@0@"'.format(meson.current_source_dir()),
'-DTEST_LOCALE_PATH="@0@"'.format(test_mo_dir),
],
dependencies : [libglib_dep, libgmodule_dep, libgio_dep])
test('gsettings', exe, env : test_env)
endif endif
endif endif # unix
# Test programs buildable on Windows only # Test programs buildable on Windows only
if host_machine.system() == 'windows' if host_machine.system() == 'windows'