Skip to content
Snippets Groups Projects
Commit 4ed06acb authored by Alexander Hansen Færøy's avatar Alexander Hansen Færøy
Browse files

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
parent 7a64f6ea
No related branches found
No related tags found
No related merge requests found
......@@ -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
};
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment