mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-27 22:03:31 +01:00
Add test to check if the exit callback is called in process_t upon process_exec() failures.
This patch adds a test to check for whether the exit callback is always called when process_exec() fails, both on Windows and Unix. See: https://bugs.torproject.org/31810
This commit is contained in:
parent
cbed6ff843
commit
ee8db8a2eb
@ -328,8 +328,38 @@ test_callbacks_terminate(void *arg)
|
||||
process_free(process);
|
||||
}
|
||||
|
||||
static void
|
||||
test_nonexistent_executable(void *arg)
|
||||
{
|
||||
(void)arg;
|
||||
|
||||
/* Process callback data. */
|
||||
process_data_t *process_data = process_data_new();
|
||||
|
||||
/* Setup our process. */
|
||||
process_t *process = process_new("binary-does-not-exist");
|
||||
process_set_data(process, process_data);
|
||||
process_set_exit_callback(process, process_exit_callback);
|
||||
|
||||
/* Run our process. */
|
||||
process_exec(process);
|
||||
|
||||
/* Start our main loop. */
|
||||
run_main_loop(process_data);
|
||||
|
||||
/* Ensure that the exit callback was actually called even though the binary
|
||||
* did not exist.
|
||||
*/
|
||||
tt_assert(process_data->did_exit);
|
||||
|
||||
done:
|
||||
process_data_free(process_data);
|
||||
process_free(process);
|
||||
}
|
||||
|
||||
struct testcase_t slow_process_tests[] = {
|
||||
{ "callbacks", test_callbacks, 0, NULL, NULL },
|
||||
{ "callbacks_terminate", test_callbacks_terminate, 0, NULL, NULL },
|
||||
{ "nonexistent_executable", test_nonexistent_executable, 0, NULL, NULL },
|
||||
END_OF_TESTCASES
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user