]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Add test to check if the exit callback is called in process_t upon process_exec(...
authorAlexander Færøy <ahf@torproject.org>
Thu, 17 Oct 2019 14:56:21 +0000 (16:56 +0200)
committerAlexander Færøy <ahf@torproject.org>
Thu, 17 Oct 2019 18:52:32 +0000 (20:52 +0200)
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

src/test/test_process_slow.c

index 91252c725d853f001ccb6784a70e834a8bea9801..f311e8b293ff8879f9a6c377f9a961b0144a7041 100644 (file)
@@ -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
 };