1 #include <test.h>
2 
3 #include <cf3.defs.h>
4 #include <cf3.extern.h>
5 
6 #include <syslog_client.h>
7 #include <string_lib.h>
8 
9 // This test uses syslog_client.c directly, without libpromises,
10 // this is necessary so we don't get "undefined symbol" errors:
11 char VFQNAME[CF_MAXVARSIZE];
12 
13 static struct sockaddr *got_address;
14 
15 #if SENDTO_RETURNS_SSIZE_T > 0
sendto(ARG_UNUSED int sockfd,ARG_UNUSED const void * buf,size_t len,ARG_UNUSED int flags,const struct sockaddr * dest_addr,ARG_UNUSED socklen_t addrlen)16 ssize_t sendto(ARG_UNUSED int sockfd, ARG_UNUSED const void *buf,
17                size_t len,
18                ARG_UNUSED int flags,
19                const struct sockaddr *dest_addr,
20                ARG_UNUSED socklen_t addrlen)
21 {
22     got_address = xmemdup(dest_addr, sizeof(struct sockaddr_in));
23     return len;
24 }
25 #else
26 /*
27  * We might be naives by thinking that size_t, socklen_t and such are the same size as int.
28  * Given that we are not using them here, we can live with that assumption.
29  */
sendto(ARG_UNUSED int sockfd,ARG_UNUSED const void * buf,int len,ARG_UNUSED int flags,const void * dest_addr,ARG_UNUSED int addrlen)30 int sendto(ARG_UNUSED int sockfd, ARG_UNUSED const void *buf,
31                int len,
32                ARG_UNUSED int flags,
33                const void *dest_addr,
34                ARG_UNUSED int addrlen)
35 {
36     got_address = xmemdup(dest_addr, sizeof(struct sockaddr_in));
37     return len;
38 }
39 #endif // SENDTO_RETURNS_SSIZE_T > 0
40 
test_set_port(void)41 static void test_set_port(void)
42 {
43     SetSyslogPort(5678);
44     RemoteSysLog(LOG_EMERG, "Test string");
45 
46     if (got_address->sa_family == AF_INET)
47     {
48         assert_int_equal(ntohs(((struct sockaddr_in *) got_address)->sin_port), 5678);
49     }
50     else if (got_address->sa_family == AF_INET6)
51     {
52         assert_int_equal(ntohs(((struct sockaddr_in6 *) got_address)->sin6_port), 5678);
53     }
54 
55     free(got_address);
56 }
57 
test_set_host(void)58 static void test_set_host(void)
59 {
60     SetSyslogHost("127.0.0.55");
61     RemoteSysLog(LOG_EMERG, "Test string");
62 
63     assert_int_equal(got_address->sa_family, AF_INET);
64 
65     assert_int_equal(ntohl(((struct sockaddr_in *) got_address)->sin_addr.s_addr), 0x7f000037);
66 }
67 
68 #define check_level(str, lvl) \
69 {\
70     assert_int_equal(LogLevelFromString(str), lvl);\
71     assert_true(StringEqual_IgnoreCase(str, LogLevelToString(lvl)));\
72 }
73 
test_log_level(void)74 static void test_log_level(void)
75 {
76     check_level("CRITICAL", LOG_LEVEL_CRIT);
77     check_level("Error", LOG_LEVEL_ERR);
78     check_level("warning", LOG_LEVEL_WARNING);
79     check_level("notice", LOG_LEVEL_NOTICE);
80     check_level("info", LOG_LEVEL_INFO);
81     check_level("verbose", LOG_LEVEL_VERBOSE);
82     check_level("debug", LOG_LEVEL_DEBUG);
83 
84     // LogLevelFromString should accept half typed strings:
85     assert_int_equal(LogLevelFromString("CRIT"), LOG_LEVEL_CRIT);
86     assert_int_equal(LogLevelFromString("ERR"), LOG_LEVEL_ERR);
87     assert_int_equal(LogLevelFromString("warn"), LOG_LEVEL_WARNING);
88     assert_int_equal(LogLevelFromString("I"), LOG_LEVEL_INFO);
89     assert_int_equal(LogLevelFromString("i"), LOG_LEVEL_INFO);
90     assert_int_equal(LogLevelFromString("information"), LOG_LEVEL_INFO);
91     assert_int_equal(LogLevelFromString("v"), LOG_LEVEL_VERBOSE);
92 
93     //LogLevelFromString should return NOTHING in case of error:
94     assert_int_equal(LogLevelFromString(""), LOG_LEVEL_NOTHING);
95     assert_int_equal(LogLevelFromString("IX"), LOG_LEVEL_NOTHING);
96     assert_int_equal(LogLevelFromString("Infotmation"), LOG_LEVEL_NOTHING);
97 }
98 
main()99 int main()
100 {
101     PRINT_TEST_BANNER();
102     const UnitTest tests[] =
103     {
104         unit_test(test_set_port),
105         unit_test(test_set_host),
106         unit_test(test_log_level),
107     };
108 
109     return run_tests(tests);
110 }
111