mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-15 16:56:14 +01:00
gtestutils: add "options" to g_test_init(), make option-argv0 use gtester
Declare that the previously-unused "..." argument to g_test_init() is actually a NULL-terminated list of strings indicating testing options, and add an option "no_g_set_prgname", which keeps g_test_init() from calling g_set_prgname(). Then we can port glib/tests/option-argv0 to use gtester, by passing that option. https://bugzilla.gnome.org/show_bug.cgi?id=711796
This commit is contained in:
parent
f733075cd1
commit
41eacde630
@ -627,6 +627,7 @@ static GTestConfig mutable_test_config_vars = {
|
|||||||
TRUE, /* test_undefined */
|
TRUE, /* test_undefined */
|
||||||
};
|
};
|
||||||
const GTestConfig * const g_test_config_vars = &mutable_test_config_vars;
|
const GTestConfig * const g_test_config_vars = &mutable_test_config_vars;
|
||||||
|
static gboolean no_g_set_prgname = FALSE;
|
||||||
|
|
||||||
/* --- functions --- */
|
/* --- functions --- */
|
||||||
const char*
|
const char*
|
||||||
@ -1003,7 +1004,9 @@ parse_args (gint *argc_p,
|
|||||||
* Changed if any arguments were handled.
|
* Changed if any arguments were handled.
|
||||||
* @argv: Address of the @argv parameter of main().
|
* @argv: Address of the @argv parameter of main().
|
||||||
* Any parameters understood by g_test_init() stripped before return.
|
* Any parameters understood by g_test_init() stripped before return.
|
||||||
* @...: Reserved for future extension. Currently, you must pass %NULL.
|
* @...: %NULL-terminated list of special options. Currently the only
|
||||||
|
* defined option is <literal>"no_g_set_prgname"</literal>, which
|
||||||
|
* will cause g_test_init() to not call g_set_prgname().
|
||||||
*
|
*
|
||||||
* Initialize the GLib testing framework, e.g. by seeding the
|
* Initialize the GLib testing framework, e.g. by seeding the
|
||||||
* test random number generator, the name for g_get_prgname()
|
* test random number generator, the name for g_get_prgname()
|
||||||
@ -1094,9 +1097,10 @@ g_test_init (int *argc,
|
|||||||
{
|
{
|
||||||
static char seedstr[4 + 4 * 8 + 1];
|
static char seedstr[4 + 4 * 8 + 1];
|
||||||
va_list args;
|
va_list args;
|
||||||
gpointer vararg1;
|
gpointer option;
|
||||||
/* make warnings and criticals fatal for all test programs */
|
/* make warnings and criticals fatal for all test programs */
|
||||||
GLogLevelFlags fatal_mask = (GLogLevelFlags) g_log_set_always_fatal ((GLogLevelFlags) G_LOG_FATAL_MASK);
|
GLogLevelFlags fatal_mask = (GLogLevelFlags) g_log_set_always_fatal ((GLogLevelFlags) G_LOG_FATAL_MASK);
|
||||||
|
|
||||||
fatal_mask = (GLogLevelFlags) (fatal_mask | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL);
|
fatal_mask = (GLogLevelFlags) (fatal_mask | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL);
|
||||||
g_log_set_always_fatal (fatal_mask);
|
g_log_set_always_fatal (fatal_mask);
|
||||||
/* check caller args */
|
/* check caller args */
|
||||||
@ -1106,9 +1110,12 @@ g_test_init (int *argc,
|
|||||||
mutable_test_config_vars.test_initialized = TRUE;
|
mutable_test_config_vars.test_initialized = TRUE;
|
||||||
|
|
||||||
va_start (args, argv);
|
va_start (args, argv);
|
||||||
vararg1 = va_arg (args, gpointer); /* reserved for future extensions */
|
while ((option = va_arg (args, char *)))
|
||||||
|
{
|
||||||
|
if (g_strcmp0 (option, "no_g_set_prgname") == 0)
|
||||||
|
no_g_set_prgname = TRUE;
|
||||||
|
}
|
||||||
va_end (args);
|
va_end (args);
|
||||||
g_return_if_fail (vararg1 == NULL);
|
|
||||||
|
|
||||||
/* setup random seed string */
|
/* setup random seed string */
|
||||||
g_snprintf (seedstr, sizeof (seedstr), "R02S%08x%08x%08x%08x", g_random_int(), g_random_int(), g_random_int(), g_random_int());
|
g_snprintf (seedstr, sizeof (seedstr), "R02S%08x%08x%08x%08x", g_random_int(), g_random_int(), g_random_int(), g_random_int());
|
||||||
@ -1116,7 +1123,8 @@ g_test_init (int *argc,
|
|||||||
|
|
||||||
/* parse args, sets up mode, changes seed, etc. */
|
/* parse args, sets up mode, changes seed, etc. */
|
||||||
parse_args (argc, argv);
|
parse_args (argc, argv);
|
||||||
if (!g_get_prgname())
|
|
||||||
|
if (!g_get_prgname() && !no_g_set_prgname)
|
||||||
g_set_prgname ((*argv)[0]);
|
g_set_prgname ((*argv)[0]);
|
||||||
|
|
||||||
/* verify GRand reliability, needed for reliable seeds */
|
/* verify GRand reliability, needed for reliable seeds */
|
||||||
|
@ -107,7 +107,7 @@ void g_test_maximized_result (double maximized_quantity,
|
|||||||
GLIB_AVAILABLE_IN_ALL
|
GLIB_AVAILABLE_IN_ALL
|
||||||
void g_test_init (int *argc,
|
void g_test_init (int *argc,
|
||||||
char ***argv,
|
char ***argv,
|
||||||
...);
|
...) G_GNUC_NULL_TERMINATED;
|
||||||
/* query testing framework config */
|
/* query testing framework config */
|
||||||
#define g_test_initialized() (g_test_config_vars->test_initialized)
|
#define g_test_initialized() (g_test_config_vars->test_initialized)
|
||||||
#define g_test_quick() (g_test_config_vars->test_quick)
|
#define g_test_quick() (g_test_config_vars->test_quick)
|
||||||
|
@ -54,14 +54,11 @@ int
|
|||||||
main (int argc,
|
main (int argc,
|
||||||
char *argv[])
|
char *argv[])
|
||||||
{
|
{
|
||||||
/* Note - we can't actually use g_test_* because g_test_init mutates
|
g_test_init (&argc, &argv, "no_g_set_prgname", NULL);
|
||||||
* g_get_prgname() which is exactly what we wanted to test =/
|
|
||||||
*/
|
|
||||||
#if defined __linux || defined __OpenBSD__
|
#if defined __linux || defined __OpenBSD__
|
||||||
g_print ("/option/argv0: ");
|
g_test_add_func ("/option/argv0", test_platform_argv0);
|
||||||
test_platform_argv0 ();
|
|
||||||
g_print ("OK\n");
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user