2018-06-20 08:13:28 -04:00
|
|
|
/* Copyright (c) 2014-2018, The Tor Project, Inc. */
|
2015-09-15 17:20:44 +02:00
|
|
|
/* See LICENSE for licensing information */
|
|
|
|
|
2018-07-05 16:34:59 -04:00
|
|
|
#include "core/or/or.h"
|
2015-09-15 17:20:44 +02:00
|
|
|
|
|
|
|
#ifndef TOR_LOG_TEST_HELPERS_H
|
|
|
|
#define TOR_LOG_TEST_HELPERS_H
|
|
|
|
|
2016-08-31 13:03:59 -04:00
|
|
|
/** An element of mock_saved_logs(); records the log element that we
|
|
|
|
* received. */
|
2015-09-15 17:20:44 +02:00
|
|
|
typedef struct mock_saved_log_entry_t {
|
|
|
|
int severity;
|
|
|
|
const char *funcname;
|
|
|
|
const char *suffix;
|
|
|
|
const char *format;
|
|
|
|
char *generated_msg;
|
|
|
|
} mock_saved_log_entry_t;
|
|
|
|
|
|
|
|
void mock_clean_saved_logs(void);
|
|
|
|
const smartlist_t *mock_saved_logs(void);
|
2016-09-08 15:01:32 -04:00
|
|
|
void setup_capture_of_logs(int new_level);
|
|
|
|
void setup_full_capture_of_logs(int new_level);
|
|
|
|
void teardown_capture_of_logs(void);
|
2016-02-11 12:45:51 -05:00
|
|
|
|
2016-01-29 11:38:54 -05:00
|
|
|
int mock_saved_log_has_message(const char *msg);
|
2016-08-31 11:35:12 -04:00
|
|
|
int mock_saved_log_has_message_containing(const char *msg);
|
2018-06-09 10:34:17 +00:00
|
|
|
int mock_saved_log_has_message_not_containing(const char *msg);
|
2016-02-01 10:02:04 +11:00
|
|
|
int mock_saved_log_has_severity(int severity);
|
|
|
|
int mock_saved_log_has_entry(void);
|
2016-09-08 14:39:20 -04:00
|
|
|
int mock_saved_log_n_entries(void);
|
2016-09-08 10:33:01 -04:00
|
|
|
void mock_dump_saved_logs(void);
|
2016-02-01 10:02:04 +11:00
|
|
|
|
2016-09-08 10:33:01 -04:00
|
|
|
#define assert_log_predicate(predicate, failure_msg) \
|
|
|
|
do { \
|
|
|
|
if (!(predicate)) { \
|
2018-08-22 10:31:44 -04:00
|
|
|
TT_FAIL(failure_msg); \
|
2016-09-08 10:33:01 -04:00
|
|
|
mock_dump_saved_logs(); \
|
|
|
|
TT_EXIT_TEST_FUNCTION; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define expect_log_msg(str) \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message(str), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain \"%s\"", str));
|
2016-02-01 10:02:04 +11:00
|
|
|
|
2016-08-31 12:51:22 -04:00
|
|
|
#define expect_log_msg_containing(str) \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain \"%s\"", str));
|
2016-08-31 12:51:22 -04:00
|
|
|
|
2018-06-09 10:34:17 +00:00
|
|
|
#define expect_log_msg_not_containing(str) \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_not_containing(str), \
|
2018-09-04 20:21:07 -04:00
|
|
|
("expected log to not contain \"%s\"", str));
|
2018-06-09 10:34:17 +00:00
|
|
|
|
2016-09-08 11:47:16 -04:00
|
|
|
#define expect_log_msg_containing_either(str1, str2) \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str1) || \
|
|
|
|
mock_saved_log_has_message_containing(str2), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain \"%s\" or \"%s\"", str1, str2));
|
2016-11-15 20:33:31 -05:00
|
|
|
|
2016-11-16 13:03:20 +11:00
|
|
|
#define expect_log_msg_containing_either3(str1, str2, str3) \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str1) || \
|
|
|
|
mock_saved_log_has_message_containing(str2) || \
|
|
|
|
mock_saved_log_has_message_containing(str3), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain \"%s\" or \"%s\" or \"%s\"", \
|
|
|
|
str1, str2, str3))
|
2016-11-15 20:33:31 -05:00
|
|
|
|
2016-11-16 13:03:20 +11:00
|
|
|
#define expect_log_msg_containing_either4(str1, str2, str3, str4) \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str1) || \
|
|
|
|
mock_saved_log_has_message_containing(str2) || \
|
|
|
|
mock_saved_log_has_message_containing(str3) || \
|
|
|
|
mock_saved_log_has_message_containing(str4), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain \"%s\" or \"%s\" or \"%s\" or \"%s\"", \
|
|
|
|
str1, str2, str3, str4))
|
2016-11-15 20:33:31 -05:00
|
|
|
|
2016-09-08 14:39:20 -04:00
|
|
|
#define expect_single_log_msg(str) \
|
|
|
|
do { \
|
|
|
|
\
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str) && \
|
|
|
|
mock_saved_log_n_entries() == 1, \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain exactly 1 message \"%s\"", \
|
|
|
|
str)); \
|
2016-09-08 14:39:20 -04:00
|
|
|
} while (0);
|
|
|
|
|
2016-08-31 14:30:34 -04:00
|
|
|
#define expect_single_log_msg_containing(str) \
|
2016-09-08 14:39:20 -04:00
|
|
|
do { \
|
|
|
|
assert_log_predicate(mock_saved_log_has_message_containing(str)&& \
|
|
|
|
mock_saved_log_n_entries() == 1 , \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain 1 message, containing \"%s\"",\
|
|
|
|
str)); \
|
2016-08-31 14:30:34 -04:00
|
|
|
} while (0);
|
|
|
|
|
2016-02-01 10:02:04 +11:00
|
|
|
#define expect_no_log_msg(str) \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(!mock_saved_log_has_message(str), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to not contain \"%s\"",str));
|
2016-02-01 10:02:04 +11:00
|
|
|
|
2018-05-03 21:49:19 -05:00
|
|
|
#define expect_no_log_msg_containing(str) \
|
|
|
|
assert_log_predicate(!mock_saved_log_has_message_containing(str), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to not contain \"%s\"", str));
|
2018-05-03 21:49:19 -05:00
|
|
|
|
2016-02-01 10:02:04 +11:00
|
|
|
#define expect_log_severity(severity) \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(mock_saved_log_has_severity(severity), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain severity " # severity));
|
2016-02-01 10:02:04 +11:00
|
|
|
|
|
|
|
#define expect_no_log_severity(severity) \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(!mock_saved_log_has_severity(severity), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to not contain severity " # severity));
|
2016-02-01 10:02:04 +11:00
|
|
|
|
|
|
|
#define expect_log_entry() \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(mock_saved_log_has_entry(), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to contain entries"));
|
2016-02-01 10:02:04 +11:00
|
|
|
|
|
|
|
#define expect_no_log_entry() \
|
2016-09-08 10:33:01 -04:00
|
|
|
assert_log_predicate(!mock_saved_log_has_entry(), \
|
2018-08-22 10:31:44 -04:00
|
|
|
("expected log to not contain entries"));
|
2015-09-15 17:20:44 +02:00
|
|
|
|
2017-09-15 16:24:44 -04:00
|
|
|
#endif /* !defined(TOR_LOG_TEST_HELPERS_H) */
|