1f08c3bdfSopenharmony_ci#! /bin/sh
2f08c3bdfSopenharmony_ci
3f08c3bdfSopenharmony_ci#  Copyright (c) International Business Machines  Corp., 2002
4f08c3bdfSopenharmony_ci#
5f08c3bdfSopenharmony_ci#  This program is free software;  you can redistribute it and/or modify
6f08c3bdfSopenharmony_ci#  it under the terms of the GNU General Public License as published by
7f08c3bdfSopenharmony_ci#  the Free Software Foundation; either version 2 of the License, or
8f08c3bdfSopenharmony_ci#  (at your option) any later version.
9f08c3bdfSopenharmony_ci#
10f08c3bdfSopenharmony_ci#  This program is distributed in the hope that it will be useful,
11f08c3bdfSopenharmony_ci#  but WITHOUT ANY WARRANTY;  without even the implied warranty of
12f08c3bdfSopenharmony_ci#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
13f08c3bdfSopenharmony_ci#  the GNU General Public License for more details.
14f08c3bdfSopenharmony_ci#
15f08c3bdfSopenharmony_ci#  You should have received a copy of the GNU General Public License
16f08c3bdfSopenharmony_ci#  along with this program;  if not, write to the Free Software
17f08c3bdfSopenharmony_ci#  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
18f08c3bdfSopenharmony_ci
19f08c3bdfSopenharmony_ci# 12/05/02  Port to bash -Robbie Williamson <robbiew@us.ibm.com>
20f08c3bdfSopenharmony_ci# 02/05/03  Modified - Manoj Iyer <manjo@mail.utexas.edu> use USCTEST macros
21f08c3bdfSopenharmony_ci#		   fixed bugs.
22f08c3bdfSopenharmony_ci# 07/26/05  Michael Reed  <mreedltp@vnet.ibm.com>
23f08c3bdfSopenharmony_ci#		   Made changes to account for the replacement of syslogd
24f08c3bdfSopenharmony_ci#		   with syslog-ng
25f08c3bdfSopenharmony_ci#
26f08c3bdfSopenharmony_ci##################################################################
27f08c3bdfSopenharmony_ci# case2: Test if messages of all levels are logged.
28f08c3bdfSopenharmony_ci#	For each level, a separate configuration file is
29f08c3bdfSopenharmony_ci#	created and that will be used as syslog.conf file.
30f08c3bdfSopenharmony_ci##################################################################
31f08c3bdfSopenharmony_ci
32f08c3bdfSopenharmony_ci# Number of levels.
33f08c3bdfSopenharmony_ciexport TST_TOTAL=8
34f08c3bdfSopenharmony_ci
35f08c3bdfSopenharmony_ci. syslog-lib.sh || exit 1
36f08c3bdfSopenharmony_ci
37f08c3bdfSopenharmony_cisyslog_case2()
38f08c3bdfSopenharmony_ci{
39f08c3bdfSopenharmony_ci	level_no=0
40f08c3bdfSopenharmony_ci	levels="emerg alert crit err warning notice info debug"
41f08c3bdfSopenharmony_ci	tst_resm TINFO "testing whether messages are logged into log file"
42f08c3bdfSopenharmony_ci
43f08c3bdfSopenharmony_ci	for level in $levels
44f08c3bdfSopenharmony_ci	do
45f08c3bdfSopenharmony_ci		tst_resm TINFO "Doing level: $level..."
46f08c3bdfSopenharmony_ci
47f08c3bdfSopenharmony_ci		case "$CONFIG_FILE" in
48f08c3bdfSopenharmony_ci		/etc/syslog.conf)
49f08c3bdfSopenharmony_ci			# Create the configuration file specific to this level
50f08c3bdfSopenharmony_ci			echo "mail.$level	$MAILLOG" >> $CONFIG_FILE
51f08c3bdfSopenharmony_ci			;;
52f08c3bdfSopenharmony_ci
53f08c3bdfSopenharmony_ci		/etc/rsyslog.conf)
54f08c3bdfSopenharmony_ci			# Create the configuration file specific to this level
55f08c3bdfSopenharmony_ci			echo "$RSYSLOG_CONFIG" > $CONFIG_FILE
56f08c3bdfSopenharmony_ci			echo "mail.$level	$MAILLOG" >> $CONFIG_FILE
57f08c3bdfSopenharmony_ci			;;
58f08c3bdfSopenharmony_ci
59f08c3bdfSopenharmony_ci		/etc/syslog-ng/syslog-ng.conf)
60f08c3bdfSopenharmony_ci			echo "source src{ internal(); unix-dgram(\"/dev/log\"); udp(ip(\"0.0.0.0\") port(514)); };" > $CONFIG_FILE
61f08c3bdfSopenharmony_ci			echo "filter f_syslog_$level { level($level) and facility(mail); };"  >> $CONFIG_FILE
62f08c3bdfSopenharmony_ci			echo "destination syslog-$level { file(\"$MAILLOG\"); };"  >> $CONFIG_FILE
63f08c3bdfSopenharmony_ci			echo "log { source(src); filter(f_syslog_$level); destination(syslog-$level); };"  >> $CONFIG_FILE;;
64f08c3bdfSopenharmony_ci		esac
65f08c3bdfSopenharmony_ci
66f08c3bdfSopenharmony_ci		restart_syslog_daemon
67f08c3bdfSopenharmony_ci
68f08c3bdfSopenharmony_ci		# Grepping pattern has to be changed whenever the executable name
69f08c3bdfSopenharmony_ci		# changes, ex: syslogtst executable.
70f08c3bdfSopenharmony_ci		# This check is neccessary for syslog-ng because $MAILLOG is
71f08c3bdfSopenharmony_ci		# only created after syslogtst
72f08c3bdfSopenharmony_ci		if [ -e "$MAILLOG" ]; then
73f08c3bdfSopenharmony_ci			oldvalue=`grep -c "syslogtst: mail $level test\." $MAILLOG`
74f08c3bdfSopenharmony_ci		else
75f08c3bdfSopenharmony_ci			oldvalue=0
76f08c3bdfSopenharmony_ci		fi
77f08c3bdfSopenharmony_ci
78f08c3bdfSopenharmony_ci		# syslogtst has to be called with additional level argument(0-7)
79f08c3bdfSopenharmony_ci		if ! syslogtst 2 $level_no 2>/dev/null; then
80f08c3bdfSopenharmony_ci			cleanup 1
81f08c3bdfSopenharmony_ci		fi
82f08c3bdfSopenharmony_ci		sleep 2
83f08c3bdfSopenharmony_ci
84f08c3bdfSopenharmony_ci		# check if $MAILLOG script exists
85f08c3bdfSopenharmony_ci		if [ ! -e "$MAILLOG" ]; then
86f08c3bdfSopenharmony_ci			tst_resm TBROK "$MAILLOG no such log file"
87f08c3bdfSopenharmony_ci			cleanup 1
88f08c3bdfSopenharmony_ci		fi
89f08c3bdfSopenharmony_ci
90f08c3bdfSopenharmony_ci		newvalue=`grep -c "syslogtst: mail $level test" $MAILLOG`
91f08c3bdfSopenharmony_ci		diff=$(( $newvalue - $oldvalue ))
92f08c3bdfSopenharmony_ci		if [ $diff -eq 0 ]; then
93f08c3bdfSopenharmony_ci			tst_resm TFAIL "***** Level $level failed *****"
94f08c3bdfSopenharmony_ci			status_flag=1
95f08c3bdfSopenharmony_ci		elif [ $diff -ge 1 ]; then
96f08c3bdfSopenharmony_ci			tst_resm TPASS "***** Level $level passed *****"
97f08c3bdfSopenharmony_ci		fi
98f08c3bdfSopenharmony_ci		# Increment the level_no for next level...
99f08c3bdfSopenharmony_ci		: $(( level_no += 1 ))
100f08c3bdfSopenharmony_ci
101f08c3bdfSopenharmony_ci		incr_tst_count
102f08c3bdfSopenharmony_ci	done
103f08c3bdfSopenharmony_ci}
104f08c3bdfSopenharmony_ci
105f08c3bdfSopenharmony_citst_resm TINFO "Test if messages of all levels are logged."
106f08c3bdfSopenharmony_citst_resm TINFO "For each level, a separate configuration file is"
107f08c3bdfSopenharmony_citst_resm TINFO "created and that will be used as syslog.conf file."
108f08c3bdfSopenharmony_ci
109f08c3bdfSopenharmony_cisetup
110f08c3bdfSopenharmony_cisyslog_case2
111f08c3bdfSopenharmony_cicleanup ${status_flag:=0}
112