1 /*
2  * Copyright (c) 2024, Meta
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #include <zephyr/posix/syslog.h>
8 #undef LOG_ERR
9 #include <zephyr/posix/unistd.h>
10 #include <zephyr/ztest.h>
11 
12 #define N_PRIOS  8
13 /* avoid clashing with Zephyr's LOG_ERR() */
14 #define _LOG_ERR 3
15 
ZTEST(xsi_system_logging,test_syslog)16 ZTEST(xsi_system_logging, test_syslog)
17 {
18 	int prios[N_PRIOS] = {
19 		LOG_EMERG,   LOG_ALERT,  LOG_CRIT, _LOG_ERR,
20 		LOG_WARNING, LOG_NOTICE, LOG_INFO, LOG_DEBUG,
21 	};
22 
23 	openlog("syslog", LOG_PID | LOG_CONS | LOG_NOWAIT, LOG_LOCAL7);
24 	(void)setlogmask(LOG_MASK(-1));
25 
26 	for (size_t i = 0; i < N_PRIOS; ++i) {
27 		syslog(i, "syslog priority %d", prios[i]);
28 	}
29 
30 	closelog();
31 
32 	/* yield briefly to logging thread */
33 	usleep(100000);
34 }
35 
36 ZTEST_SUITE(xsi_system_logging, NULL, NULL, NULL, NULL, NULL);
37