summaryrefslogtreecommitdiff
path: root/regress/usr.sbin/syslogd/args-selector.pl
blob: d06dc9e7514f57981b9818ce1d86888279ac7ebb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# 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 Sys::Syslog;

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;