mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-28 23:16:14 +01:00
Fix gutils-user-database unit test
The gutils-user-database.c is broken in two ways and currently doesn't test anything: * It only overrides getpwuid, where the implementation used getpwnam_r if it exist, which should be every system for at least 20 years. * It only partly cargo-culted setting the environment for the local and installed tests, but failed to actually set the environment for either.
This commit is contained in:
parent
fcba22cfb9
commit
f7d930a58b
@ -47,3 +47,35 @@ getpwuid (uid_t uid)
|
||||
my_pw.pw_name = NULL;
|
||||
return &my_pw;
|
||||
}
|
||||
|
||||
int
|
||||
getpwnam_r (const char *name, struct passwd *pwd, char buf[], size_t buflen, struct passwd **result)
|
||||
{
|
||||
int code;
|
||||
|
||||
int (*real_getpwnam_r) (const char *,
|
||||
struct passwd *,
|
||||
char[],
|
||||
size_t,
|
||||
struct passwd **) = dlsym (RTLD_NEXT, "getpwnam_r");
|
||||
|
||||
code = real_getpwnam_r (name, pwd, buf, buflen, result);
|
||||
pwd->pw_name = NULL;
|
||||
return code;
|
||||
}
|
||||
|
||||
int
|
||||
getpwuid_r (uid_t uid, struct passwd *restrict pwd, char buf[], size_t buflen, struct passwd **result)
|
||||
{
|
||||
int code;
|
||||
|
||||
int (*real_getpwuid_r) (uid_t,
|
||||
struct passwd *,
|
||||
char[],
|
||||
size_t,
|
||||
struct passwd **) = dlsym (RTLD_NEXT, "getpwuid_r");
|
||||
|
||||
code = real_getpwuid_r (uid, pwd, buf, buflen, result);
|
||||
pwd->pw_name = NULL;
|
||||
return code;
|
||||
}
|
||||
|
@ -27,10 +27,10 @@ test_get_user_database_entry (void)
|
||||
const gchar *r = NULL;
|
||||
|
||||
r = g_get_user_name ();
|
||||
g_assert_nonnull (r);
|
||||
g_assert_cmpstr (r, ==, "somebody");
|
||||
|
||||
r = g_get_real_name ();
|
||||
g_assert_nonnull (r);
|
||||
g_assert_cmpstr (r, ==, "Unknown");
|
||||
}
|
||||
|
||||
int
|
||||
|
@ -356,12 +356,21 @@ subdir('path-test-subdir')
|
||||
foreach test_name, extra_args : glib_tests
|
||||
source = extra_args.get('source', test_name + '.c')
|
||||
install = installed_tests_enabled and extra_args.get('install', true)
|
||||
installed_tests_env = extra_args.get('installed_tests_env', {})
|
||||
|
||||
if install
|
||||
test_conf = configuration_data()
|
||||
test_conf.set('installed_tests_dir', installed_tests_execdir)
|
||||
test_conf.set('program', test_name)
|
||||
test_conf.set('env', '')
|
||||
test_env_override = ''
|
||||
if installed_tests_env != {}
|
||||
envs = []
|
||||
foreach var, value : installed_tests_env
|
||||
envs += '@0@=@1@'.format(var, value)
|
||||
endforeach
|
||||
test_env_override = '@0@ @1@ '.format(env_program.full_path(), ' '.join(envs))
|
||||
endif
|
||||
test_conf.set('env', test_env_override)
|
||||
configure_file(
|
||||
input: installed_tests_template_tap,
|
||||
output: test_name + '.test',
|
||||
@ -394,11 +403,16 @@ foreach test_name, extra_args : glib_tests
|
||||
depends += test_extra_programs_targets[program]
|
||||
endforeach
|
||||
|
||||
local_test_env = test_env
|
||||
foreach var, value : extra_args.get('env', {})
|
||||
local_test_env.append(var, value)
|
||||
endforeach
|
||||
|
||||
test(test_name, exe,
|
||||
args: extra_args.get('args', []),
|
||||
protocol : extra_args.get('protocol', test_protocol),
|
||||
depends : depends,
|
||||
env : test_env,
|
||||
env : local_test_env,
|
||||
timeout : timeout,
|
||||
suite : suite,
|
||||
should_fail : extra_args.get('should_fail', false),
|
||||
|
Loading…
Reference in New Issue
Block a user