diff options
author | Gavin Carr <gonzai@users.sourceforge.net> | 2007-02-08 05:18:06 +0000 |
---|---|---|
committer | Gavin Carr <gonzai@users.sourceforge.net> | 2007-02-08 05:18:06 +0000 |
commit | 0e41613e9f547ab97365329572555936e84f77b2 (patch) | |
tree | 4d657ad1a7bb96ba4f4ff40037198edc58449aed /t/Nagios-Plugin-Getopt-03.t | |
parent | d56d5a0d2d4b29ac2a296bc39a7b80862a7f7e8f (diff) | |
download | monitoring-plugin-perl-0e41613e9f547ab97365329572555936e84f77b2.tar.gz |
Add initial --default-opts implementation to Nagios::Plugin::Getopt (II).
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/Nagios-Plugin/trunk@1617 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 't/Nagios-Plugin-Getopt-03.t')
-rw-r--r-- | t/Nagios-Plugin-Getopt-03.t | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/t/Nagios-Plugin-Getopt-03.t b/t/Nagios-Plugin-Getopt-03.t new file mode 100644 index 0000000..9dc39da --- /dev/null +++ b/t/Nagios-Plugin-Getopt-03.t | |||
@@ -0,0 +1,99 @@ | |||
1 | # Nagios::Plugin::Getopt --default-opts tests | ||
2 | |||
3 | use strict; | ||
4 | use File::Spec; | ||
5 | use File::Basename; | ||
6 | use IO::File; | ||
7 | |||
8 | use Test::More qw(no_plan); | ||
9 | BEGIN { use_ok('Nagios::Plugin::Getopt') }; | ||
10 | |||
11 | my $tdir = 'npg03'; | ||
12 | if (! -d $tdir) { | ||
13 | my $ttdir = File::Spec->catdir('t', $tdir); | ||
14 | die "missing '$tdir' directory\n" unless -d $ttdir; | ||
15 | $tdir = $ttdir; | ||
16 | } | ||
17 | |||
18 | # Load expected files | ||
19 | my %EXPECTED = (); | ||
20 | for my $efile (glob File::Spec->catfile($tdir, 'expected', '*')) { | ||
21 | my $fh = IO::File->new($efile, 'r') or die "Cannot open input file '$efile': $!"; | ||
22 | if (my $cmd = $fh->getline()) { # First line only! | ||
23 | chomp $cmd; | ||
24 | $cmd =~ s/^\s+//; | ||
25 | $cmd =~ s/\s+$//; | ||
26 | $EXPECTED{ basename($efile) } = $cmd; | ||
27 | } | ||
28 | } | ||
29 | |||
30 | $Nagios::Plugin::Getopt::DEFAULT_CONFIG_FILE = File::Spec->catfile($tdir, 'plugins.cfg'); | ||
31 | |||
32 | my %PARAM = ( | ||
33 | version => '0.01', | ||
34 | blurb => 'This plugin tests various stuff.', | ||
35 | usage => "Usage: %s -H <host> -w <warning_threshold> | ||
36 | -c <critical threshold>", | ||
37 | ); | ||
38 | |||
39 | sub ng_setup | ||
40 | { | ||
41 | my $arg = shift; | ||
42 | |||
43 | # Instantiate object | ||
44 | my $ng = Nagios::Plugin::Getopt->new(%PARAM); | ||
45 | |||
46 | if (ref $arg eq 'ARRAY' && @$arg) { | ||
47 | $ng->arg(%$_) foreach @$arg; | ||
48 | } | ||
49 | |||
50 | return $ng; | ||
51 | } | ||
52 | |||
53 | # Setup our Nagios::Plugin::Getopt object | ||
54 | my $ng; | ||
55 | my $arg = [ | ||
56 | { spec => 'S', help => '-S' }, | ||
57 | { spec => 'H=s', help => '-H' }, | ||
58 | { spec => 'p=s@', help => '-p' }, | ||
59 | { spec => 'username|u=s', help => '--username' }, | ||
60 | { spec => 'password=s', help => '--password' }, | ||
61 | { spec => 'critical=i', help => '--critical' }, | ||
62 | { spec => 'warning=i', help => '--warning' }, | ||
63 | { spec => 'expect=s', help => '--expect' }, | ||
64 | ]; | ||
65 | |||
66 | my %SKIP = map { $_ => 1 } qw(05_singlechar1 07_singlechar3); | ||
67 | |||
68 | # Process all test cases in $tdir/input | ||
69 | my $glob = $ARGV[0] || '*'; | ||
70 | for my $infile (glob File::Spec->catfile($tdir, 'input', $glob)) { | ||
71 | $ng = ng_setup($arg); | ||
72 | |||
73 | my $fh = IO::File->new($infile, 'r') or die "Cannot open input file '$infile': $!"; | ||
74 | $infile = basename($infile); | ||
75 | |||
76 | if (my $cmd = $fh->getline()) { # First line only! | ||
77 | $cmd =~ s/^\s+//; | ||
78 | my ($plugin, @args) = split /\s+/, $cmd; | ||
79 | |||
80 | # Fake out the plugin name | ||
81 | $ng->{_attr}->{plugin} = $plugin; | ||
82 | |||
83 | # Parse the options | ||
84 | SKIP: { | ||
85 | skip "Still discussing how overrides with multiple arguments should work ...", 1 if $SKIP{$infile}; | ||
86 | |||
87 | @ARGV = @args; | ||
88 | eval { $ng->getopts }; | ||
89 | if ($@) { | ||
90 | chomp $@; | ||
91 | ok($infile =~ m/_dies?$/, "$infile ($@)"); | ||
92 | } | ||
93 | else { | ||
94 | is($plugin . ' ' . $ng->_cmdline, $EXPECTED{$infile}, $infile); | ||
95 | } | ||
96 | } | ||
97 | } | ||
98 | } | ||
99 | |||