mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 07:56:17 +01:00
tests: Test g_subprocess_launcher_close() doesn’t close too many FDs
Expand an existing unit test to check that the target FD of a `g_subprocess_launcher_take_fd()` call doesn’t get closed when `g_subprocess_launcher_close()` is called. Only the source FD should be closed by the parent process. Signed-off-by: Philip Withnall <pwithnall@endlessos.org> Helps: #2332
This commit is contained in:
parent
55a75590d0
commit
50cf90dc56
@ -1494,23 +1494,44 @@ test_subprocess_launcher_close (void)
|
||||
GSubprocessLauncher *launcher;
|
||||
GSubprocess *proc;
|
||||
GPtrArray *args;
|
||||
int fd;
|
||||
int fd, fd2;
|
||||
gboolean is_open;
|
||||
|
||||
/* Open two arbitrary FDs. One of them, @fd, will be transferred to the
|
||||
* launcher, and the other’s FD integer will be used as its target FD, giving
|
||||
* the mapping `fd → fd2` if a child process were to be spawned.
|
||||
*
|
||||
* The launcher will then be closed, which should close @fd but *not* @fd2,
|
||||
* as the value of @fd2 is only valid as an FD in a child process. (A child
|
||||
* process is not actually spawned in this test.)
|
||||
*/
|
||||
fd = dup (0);
|
||||
fd2 = dup (0);
|
||||
launcher = g_subprocess_launcher_new (G_SUBPROCESS_FLAGS_NONE);
|
||||
g_subprocess_launcher_take_fd (launcher, fd, fd);
|
||||
g_subprocess_launcher_take_fd (launcher, fd, fd2);
|
||||
|
||||
is_open = fcntl (fd, F_GETFD) != -1;
|
||||
g_assert_true (is_open);
|
||||
is_open = fcntl (fd2, F_GETFD) != -1;
|
||||
g_assert_true (is_open);
|
||||
|
||||
g_subprocess_launcher_close (launcher);
|
||||
|
||||
is_open = fcntl (fd, F_GETFD) != -1;
|
||||
g_assert_false (is_open);
|
||||
is_open = fcntl (fd2, F_GETFD) != -1;
|
||||
g_assert_true (is_open);
|
||||
|
||||
/* Now test that actually trying to spawn the child gives %G_IO_ERROR_CLOSED,
|
||||
* as g_subprocess_launcher_close() has been called. */
|
||||
args = get_test_subprocess_args ("cat", NULL);
|
||||
proc = g_subprocess_launcher_spawnv (launcher, (const gchar * const *) args->pdata, error);
|
||||
g_ptr_array_free (args, TRUE);
|
||||
g_assert_null (proc);
|
||||
g_assert_error (local_error, G_IO_ERROR, G_IO_ERROR_CLOSED);
|
||||
g_clear_error (error);
|
||||
|
||||
close (fd2);
|
||||
g_object_unref (launcher);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user