From 2d42a61205196476bc4b4034c2ce2fc45a1236d6 Mon Sep 17 00:00:00 2001 From: Alexander Bluhm Date: Mon, 29 Jun 2015 07:23:01 +0000 Subject: Test that selectors, which specify facility and severity level for each logfile, work as documented in syslog.conf(5). --- regress/usr.sbin/syslogd/args-selector.pl | 105 ++++++++++++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 regress/usr.sbin/syslogd/args-selector.pl (limited to 'regress') diff --git a/regress/usr.sbin/syslogd/args-selector.pl b/regress/usr.sbin/syslogd/args-selector.pl new file mode 100644 index 00000000000..f5f646bbd07 --- /dev/null +++ b/regress/usr.sbin/syslogd/args-selector.pl @@ -0,0 +1,105 @@ +# The client sends messages with different facility and severity. +# The syslogd writes into multiple files depending on priority. +# The syslogd writes it into a file and through a pipe. +# The syslogd passes it via UDP to the loghost. +# The server receives the message on its UDP socket. +# Find the message in client, file, pipe, syslogd, server log. +# Check that the messages appear in the correct log files. + +use strict; +use warnings; +use Cwd; +use Sys::Syslog; + +my $objdir = getcwd(); + +my (@messages, @priorities); +foreach my $fac (qw(local5 local6 local7)) { + foreach my $sev (qw(notice warning err)) { + my $msg = "$fac.$sev"; + push @messages, $msg; + no strict 'refs'; + my $prio = ("Sys::Syslog::LOG_".uc($fac))->() | + ("Sys::Syslog::LOG_".uc($sev))->(); + push @priorities, $prio; + } +} + +my %selector2messages = ( + "*.*" => [@messages], + "*.info" => [@messages], + "*.notice" => [@messages], + "*.warning" => [ grep { /\.(warning|err)$/ } @messages], + "*.err" => [ grep { /\.err$/ } @messages], + "*.crit" => [], + "*.none" => [], + "local5.*" => [qw(local5.notice local5.warning local5.err)], + "local5.info" => [qw(local5.notice local5.warning local5.err)], + "local5.notice" => [qw(local5.notice local5.warning local5.err)], + "local5.warning" => [qw(local5.warning local5.err)], + "local5.err" => [qw(local5.err)], + "local5.crit" => [], + "local5.none" => [], + "local5.warning;local5.err" => [qw(local5.err)], + "local5.err;local5.warning" => [qw(local5.warning local5.err)], + "local6.warning;local7.err" => [qw(local6.warning local6.err local7.err)], + "local6.err;local7.err" => [qw(local6.err local7.err)], + "local6,local7.err" => [qw(local6.err local7.err)], + "local6,local7.warning;local6.err" => [qw(local6.err local7.warning + local7.err)], + "*.*;local6,local7.none" => [qw(local5.notice local5.warning local5.err)], +); + +sub selector2config { + my %s2m = @_; + my $conf = ""; + my $i = 0; + foreach my $sel (sort keys %s2m) { + $conf .= "$sel\t$objdir/file-$i.log\n"; + $i++; + } + return $conf; +} + +sub messages2loggrep { + my %s2m = @_; + my @loggrep; + foreach my $sel (sort keys %s2m) { + my @m = @{$s2m{$sel}}; + my (%msg, %nomsg); + @msg{@m} = (); + @nomsg{@messages} = (); + delete @nomsg{@m}; + push @loggrep, { + (map { qr/: $_$/ => 1 } sort keys %msg), + (map { qr/: $_$/ => 0 } sort keys %nomsg), + }; + } + return @loggrep; +} + +our %args = ( + client => { + func => sub { + my $self = shift; + for (my $i = 0; $i < @messages; $i++) { + syslog($priorities[$i], $messages[$i]); + } + write_log($self); + }, + }, + syslogd => { + conf => selector2config(%selector2messages), + }, + multifile => [ + (map { { loggrep => $_ } } (messages2loggrep(%selector2messages))), + ], + server => { + loggrep => { map { qr/ <$_>/ => 1 } @priorities }, + }, + file => { + loggrep => { map { qr/: $_$/ => 1 } @messages }, + }, +); + +1; -- cgit v1.2.3