test_util_process.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /* Copyright (c) 2010-2015, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. #define UTIL_PROCESS_PRIVATE
  4. #include "orconfig.h"
  5. #include "or.h"
  6. #include "test.h"
  7. #include "util_process.h"
  8. #include "log_test_helpers.h"
  9. #define NS_MODULE util_process
  10. static void
  11. temp_callback(int r, void *s)
  12. {
  13. (void)r;
  14. (void)s;
  15. }
  16. static void
  17. test_util_process_set_waitpid_callback(void *ignored)
  18. {
  19. (void)ignored;
  20. waitpid_callback_t *res1 = NULL, *res2 = NULL;
  21. int previous_log = setup_capture_of_logs(LOG_WARN);
  22. pid_t pid = (pid_t)42;
  23. res1 = set_waitpid_callback(pid, temp_callback, NULL);
  24. tt_assert(res1);
  25. res2 = set_waitpid_callback(pid, temp_callback, NULL);
  26. tt_assert(res2);
  27. tt_str_op(mock_saved_log_at(0), OP_EQ,
  28. "Replaced a waitpid monitor on pid 42. That should be "
  29. "impossible.\n");
  30. done:
  31. teardown_capture_of_logs(previous_log);
  32. clear_waitpid_callback(res1);
  33. clear_waitpid_callback(res2);
  34. }
  35. static void
  36. test_util_process_clear_waitpid_callback(void *ignored)
  37. {
  38. (void)ignored;
  39. waitpid_callback_t *res;
  40. int previous_log = setup_capture_of_logs(LOG_WARN);
  41. pid_t pid = (pid_t)43;
  42. clear_waitpid_callback(NULL);
  43. res = set_waitpid_callback(pid, temp_callback, NULL);
  44. clear_waitpid_callback(res);
  45. tt_int_op(mock_saved_log_number(), OP_EQ, 0);
  46. #if 0
  47. /* No. This is use-after-free. We don't _do_ that. XXXX */
  48. clear_waitpid_callback(res);
  49. tt_str_op(mock_saved_log_at(0), OP_EQ,
  50. "Couldn't remove waitpid monitor for pid 43.\n");
  51. #endif
  52. done:
  53. teardown_capture_of_logs(previous_log);
  54. }
  55. struct testcase_t util_process_tests[] = {
  56. { "set_waitpid_callback", test_util_process_set_waitpid_callback, 0,
  57. NULL, NULL },
  58. { "clear_waitpid_callback", test_util_process_clear_waitpid_callback, 0,
  59. NULL, NULL },
  60. END_OF_TESTCASES
  61. };