mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-08 12:44:23 +01:00
common: Add test case for IPC with spawned process.
* common/Makefile.am (module_tests): Add t-exechelp. * common/t-exechelp.c [HAVE_W32_SYSTEM] (print_open_fds) (test_close_all_fds, main): Exclude the test_close_all_fds test. (run_server, test_pipe_stream): New. Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
22350d0768
commit
9433dfa5dd
@ -161,11 +161,11 @@ module_tests = t-stringhelp t-timestuff \
|
|||||||
t-convert t-percent t-gettime t-sysutils t-sexputil \
|
t-convert t-percent t-gettime t-sysutils t-sexputil \
|
||||||
t-session-env t-openpgp-oid t-ssh-utils \
|
t-session-env t-openpgp-oid t-ssh-utils \
|
||||||
t-mapstrings t-zb32 t-mbox-util t-iobuf t-strlist \
|
t-mapstrings t-zb32 t-mbox-util t-iobuf t-strlist \
|
||||||
t-name-value t-ccparray t-recsel t-w32-cmdline
|
t-name-value t-ccparray t-recsel t-w32-cmdline t-exechelp
|
||||||
if HAVE_W32_SYSTEM
|
if HAVE_W32_SYSTEM
|
||||||
module_tests += t-w32-reg
|
module_tests += t-w32-reg
|
||||||
else
|
else
|
||||||
module_tests += t-exechelp t-exectool
|
module_tests += t-exectool
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if MAINTAINER_MODE
|
if MAINTAINER_MODE
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
static int verbose;
|
static int verbose;
|
||||||
|
|
||||||
|
#ifndef HAVE_W32_SYSTEM
|
||||||
static void
|
static void
|
||||||
print_open_fds (int *array)
|
print_open_fds (int *array)
|
||||||
{
|
{
|
||||||
@ -169,20 +169,119 @@ test_close_all_fds (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static char buff12k[1024*12];
|
||||||
|
|
||||||
|
static void
|
||||||
|
run_server (void)
|
||||||
|
{
|
||||||
|
estream_t fp;
|
||||||
|
int i;
|
||||||
|
char *p;
|
||||||
|
unsigned int len;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
fp = es_fdopen_nc (1, "w");
|
||||||
|
if (fp == NULL)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "es_fdopen failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fill the buffer by ASCII chars. */
|
||||||
|
p = buff12k;
|
||||||
|
for (i = 0; i < sizeof (buff12k); i++)
|
||||||
|
if ((i % 64) == 63)
|
||||||
|
*p++ = '\n';
|
||||||
|
else
|
||||||
|
*p++ = (i % 64) + '@';
|
||||||
|
|
||||||
|
len = sizeof (buff12k);
|
||||||
|
|
||||||
|
ret = es_write (fp, (void *)&len, sizeof (len), NULL);
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "es_write (1) failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = es_write (fp, buff12k, sizeof (buff12k), NULL);
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "es_write (2) failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
es_fclose (fp);
|
||||||
|
exit (0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_pipe_stream (const char *pgmname)
|
||||||
|
{
|
||||||
|
gpg_error_t err;
|
||||||
|
gnupg_process_t proc;
|
||||||
|
estream_t outfp;
|
||||||
|
const char *argv[2];
|
||||||
|
unsigned int len;
|
||||||
|
size_t n;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
argv[0] = "--server";
|
||||||
|
argv[1] = NULL;
|
||||||
|
|
||||||
|
err = gnupg_process_spawn (pgmname, argv,
|
||||||
|
(GNUPG_PROCESS_STDOUT_PIPE
|
||||||
|
|GNUPG_PROCESS_STDERR_KEEP),
|
||||||
|
NULL, NULL, &proc);
|
||||||
|
if (err)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "gnupg_process_spawn failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
|
||||||
|
gnupg_process_get_streams (proc, 0, NULL, &outfp, NULL);
|
||||||
|
|
||||||
|
ret = es_read (outfp, (void *)&len, sizeof (len), NULL);
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
fprintf (stderr, "es_read (1) failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
ret = es_read (outfp, buff12k, sizeof (buff12k), &n);
|
||||||
|
if (ret || n != sizeof (buff12k))
|
||||||
|
{
|
||||||
|
fprintf (stderr, "es_read (2) failed\n");
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
es_fclose (outfp);
|
||||||
|
gnupg_process_release (proc);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
const char *myname = "no-pgm";
|
||||||
|
|
||||||
if (argc)
|
if (argc)
|
||||||
{ argc--; argv++; }
|
{
|
||||||
|
myname = argv[0];
|
||||||
|
argc--; argv++;
|
||||||
|
}
|
||||||
if (argc && !strcmp (argv[0], "--verbose"))
|
if (argc && !strcmp (argv[0], "--verbose"))
|
||||||
{
|
{
|
||||||
verbose = 1;
|
verbose = 1;
|
||||||
argc--; argv++;
|
argc--; argv++;
|
||||||
}
|
}
|
||||||
|
if (argc && !strcmp (argv[0], "--server"))
|
||||||
|
run_server ();
|
||||||
|
|
||||||
|
#ifndef HAVE_W32_SYSTEM
|
||||||
test_close_all_fds ();
|
test_close_all_fds ();
|
||||||
|
#endif
|
||||||
|
test_pipe_stream (myname);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user