diff options
| author | Sven Nierlein <sven@nierlein.de> | 2014-01-20 00:54:34 +0100 | 
|---|---|---|
| committer | Sven Nierlein <sven@nierlein.de> | 2014-01-20 00:54:34 +0100 | 
| commit | b418181dfe80dd75169b6e8a619ac1932155dea2 (patch) | |
| tree | cad9c0ae0eae8e800cfff60555ead06ad33c6856 | |
| parent | 1cd8d1c52cbd47121f344c4074aec84653f412ce (diff) | |
| download | monitoring-plugin-perl-b418181dfe80dd75169b6e8a619ac1932155dea2.tar.gz | |
renamed module into Monitoring::Plugin
since the complete monitoring team has been renamed, we
also rename this module.
Signed-off-by: Sven Nierlein <sven@nierlein.de>
| -rw-r--r-- | .gitignore | 5 | ||||
| -rw-r--r-- | Changes | 5 | ||||
| -rw-r--r-- | MANIFEST | 64 | ||||
| -rw-r--r-- | MANIFEST.SKIP | 21 | ||||
| -rw-r--r-- | Makefile.PL | 45 | ||||
| -rw-r--r-- | README | 23 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin.pm (renamed from lib/Nagios/Plugin.pm) | 251 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Config.pm (renamed from lib/Nagios/Plugin/Config.pm) | 53 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/ExitResult.pm | 71 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Functions.pm (renamed from lib/Nagios/Plugin/Functions.pm) | 121 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Getopt.pm (renamed from lib/Nagios/Plugin/Getopt.pm) | 138 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Performance.pm (renamed from lib/Nagios/Plugin/Performance.pm) | 72 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Range.pm (renamed from lib/Nagios/Plugin/Range.pm) | 32 | ||||
| -rw-r--r-- | lib/Monitoring/Plugin/Threshold.pm (renamed from lib/Nagios/Plugin/Threshold.pm) | 50 | ||||
| -rw-r--r-- | lib/Nagios/Plugin/ExitResult.pm | 67 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-01.t (renamed from t/Nagios-Plugin-01.t) | 33 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-02.t | 160 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-03.t (renamed from t/Nagios-Plugin-03.t) | 53 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-04.t (renamed from t/Nagios-Plugin-04.t) | 26 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-05.t (renamed from t/Nagios-Plugin-05.t) | 7 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Functions-01.t | 161 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Functions-02.t (renamed from t/Nagios-Plugin-Functions-02.t) | 9 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Functions-03.t (renamed from t/Nagios-Plugin-Functions-03.t) | 2 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Functions-04.t (renamed from t/Nagios-Plugin-Functions-04.t) | 2 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Getopt-01.t (renamed from t/Nagios-Plugin-Getopt-01.t) | 17 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Getopt-02.t (renamed from t/Nagios-Plugin-Getopt-02.t) | 15 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Getopt-03.t (renamed from t/Nagios-Plugin-Getopt-03.t) | 29 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Getopt-04.t (renamed from t/Nagios-Plugin-Getopt-04.t) | 15 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Performance-02.t | 13 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Performance.t (renamed from t/Nagios-Plugin-Performance.t) | 104 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Range.t (renamed from t/Nagios-Plugin-Range.t) | 38 | ||||
| -rw-r--r-- | t/Monitoring-Plugin-Threshold.t (renamed from t/Nagios-Plugin-Threshold.t) | 58 | ||||
| -rw-r--r-- | t/Nagios-Plugin-02.t | 161 | ||||
| -rw-r--r-- | t/Nagios-Plugin-Functions-01.t | 161 | ||||
| -rw-r--r-- | t/Nagios-Plugin-Performance-02.t | 13 | ||||
| -rwxr-xr-x | t/check_stuff.pl | 45 | ||||
| -rwxr-xr-x | t/check_stuff.t | 10 | ||||
| -rw-r--r-- | t/npg03/README | 16 | 
38 files changed, 1104 insertions, 1062 deletions
| @@ -5,3 +5,8 @@ | |||
| 5 | /pm_to_blib | 5 | /pm_to_blib | 
| 6 | /.bzr | 6 | /.bzr | 
| 7 | /.bzrignore | 7 | /.bzrignore | 
| 8 | MYMETA.json | ||
| 9 | MYMETA.yml | ||
| 10 | Makefile.old | ||
| 11 | inc/ | ||
| 12 | MANIFEST.bak | ||
| @@ -1,4 +1,7 @@ | |||
| 1 | Revision history for Perl module Nagios::Plugin. | 1 | Revision history for Perl module Monitoring::Plugin. | 
| 2 | |||
| 3 | 0.37 20nd January 2014 | ||
| 4 | - renamed module due to trademark issues | ||
| 2 | 5 | ||
| 3 | 0.36 22nd December 2011 | 6 | 0.36 22nd December 2011 | 
| 4 | - Updated check_threshold to allow multiple check values to be checked at once | 7 | - Updated check_threshold to allow multiple check values to be checked at once | 
| @@ -1,33 +1,47 @@ | |||
| 1 | Changes | 1 | Changes | 
| 2 | lib/Nagios/Plugin.pm | 2 | inc/Module/AutoInstall.pm | 
| 3 | lib/Nagios/Plugin/Config.pm | 3 | inc/Module/Install.pm | 
| 4 | lib/Nagios/Plugin/ExitResult.pm | 4 | inc/Module/Install/AutoInstall.pm | 
| 5 | lib/Nagios/Plugin/Functions.pm | 5 | inc/Module/Install/Base.pm | 
| 6 | lib/Nagios/Plugin/Getopt.pm | 6 | inc/Module/Install/Can.pm | 
| 7 | lib/Nagios/Plugin/Performance.pm | 7 | inc/Module/Install/Fetch.pm | 
| 8 | lib/Nagios/Plugin/Range.pm | 8 | inc/Module/Install/Include.pm | 
| 9 | lib/Nagios/Plugin/Threshold.pm | 9 | inc/Module/Install/Makefile.pm | 
| 10 | inc/Module/Install/Metadata.pm | ||
| 11 | inc/Module/Install/Win32.pm | ||
| 12 | inc/Module/Install/WriteAll.pm | ||
| 13 | lib/Monitoring/Plugin.pm | ||
| 14 | lib/Monitoring/Plugin/Config.pm | ||
| 15 | lib/Monitoring/Plugin/ExitResult.pm | ||
| 16 | lib/Monitoring/Plugin/Functions.pm | ||
| 17 | lib/Monitoring/Plugin/Getopt.pm | ||
| 18 | lib/Monitoring/Plugin/Performance.pm | ||
| 19 | lib/Monitoring/Plugin/Range.pm | ||
| 20 | lib/Monitoring/Plugin/Threshold.pm | ||
| 10 | Makefile.PL | 21 | Makefile.PL | 
| 11 | MANIFEST This list of files | 22 | MANIFEST This list of files | 
| 12 | META.yml | 23 | META.yml | 
| 24 | notes | ||
| 13 | README | 25 | README | 
| 14 | t/check_stuff.pl | 26 | t/check_stuff.pl | 
| 15 | t/check_stuff.t | 27 | t/check_stuff.t | 
| 16 | t/Nagios-Plugin-01.t | 28 | t/Monitoring-Plugin-01.t | 
| 17 | t/Nagios-Plugin-02.t | 29 | t/Monitoring-Plugin-02.t | 
| 18 | t/Nagios-Plugin-03.t | 30 | t/Monitoring-Plugin-03.t | 
| 19 | t/Nagios-Plugin-04.t | 31 | t/Monitoring-Plugin-04.t | 
| 20 | t/Nagios-Plugin-Functions-01.t | 32 | t/Monitoring-Plugin-05.t | 
| 21 | t/Nagios-Plugin-Functions-02.t | 33 | t/Monitoring-Plugin-Functions-01.t | 
| 22 | t/Nagios-Plugin-Functions-03.t | 34 | t/Monitoring-Plugin-Functions-02.t | 
| 23 | t/Nagios-Plugin-Getopt-01.t | 35 | t/Monitoring-Plugin-Functions-03.t | 
| 24 | t/Nagios-Plugin-Getopt-02.t | 36 | t/Monitoring-Plugin-Functions-04.t | 
| 25 | t/Nagios-Plugin-Getopt-03.t | 37 | t/Monitoring-Plugin-Getopt-01.t | 
| 26 | t/Nagios-Plugin-Getopt-04.t | 38 | t/Monitoring-Plugin-Getopt-02.t | 
| 27 | t/Nagios-Plugin-Performance-02.t | 39 | t/Monitoring-Plugin-Getopt-03.t | 
| 28 | t/Nagios-Plugin-Performance.t | 40 | t/Monitoring-Plugin-Getopt-04.t | 
| 29 | t/Nagios-Plugin-Range.t | 41 | t/Monitoring-Plugin-Performance-02.t | 
| 30 | t/Nagios-Plugin-Threshold.t | 42 | t/Monitoring-Plugin-Performance.t | 
| 43 | t/Monitoring-Plugin-Range.t | ||
| 44 | t/Monitoring-Plugin-Threshold.t | ||
| 31 | t/npg03/expected/00_basic | 45 | t/npg03/expected/00_basic | 
| 32 | t/npg03/expected/00_noextra | 46 | t/npg03/expected/00_noextra | 
| 33 | t/npg03/expected/01_override1 | 47 | t/npg03/expected/01_override1 | 
| @@ -38,8 +52,10 @@ t/npg03/expected/05_disk3 | |||
| 38 | t/npg03/expected/05_disk4 | 52 | t/npg03/expected/05_disk4 | 
| 39 | t/npg03/expected/05_disk5 | 53 | t/npg03/expected/05_disk5 | 
| 40 | t/npg03/expected/05_disk6 | 54 | t/npg03/expected/05_disk6 | 
| 55 | t/npg03/expected/05_disk7 | ||
| 41 | t/npg03/expected/09_funnystuff | 56 | t/npg03/expected/09_funnystuff | 
| 42 | t/npg03/expected/12_nosection_implicit | 57 | t/npg03/expected/12_nosection_implicit | 
| 58 | t/npg03/expected/15_badsection_catch | ||
| 43 | t/npg03/input/00_basic | 59 | t/npg03/input/00_basic | 
| 44 | t/npg03/input/00_noextra | 60 | t/npg03/input/00_noextra | 
| 45 | t/npg03/input/01_override1 | 61 | t/npg03/input/01_override1 | 
| @@ -50,9 +66,11 @@ t/npg03/input/05_disk3 | |||
| 50 | t/npg03/input/05_disk4 | 66 | t/npg03/input/05_disk4 | 
| 51 | t/npg03/input/05_disk5 | 67 | t/npg03/input/05_disk5 | 
| 52 | t/npg03/input/05_disk6 | 68 | t/npg03/input/05_disk6 | 
| 69 | t/npg03/input/05_disk7 | ||
| 53 | t/npg03/input/09_funnystuff | 70 | t/npg03/input/09_funnystuff | 
| 54 | t/npg03/input/12_nosection_implicit | 71 | t/npg03/input/12_nosection_implicit | 
| 55 | t/npg03/input/13_nosection_explicit_dies | 72 | t/npg03/input/13_nosection_explicit_dies | 
| 56 | t/npg03/input/14_badsection_dies | 73 | t/npg03/input/14_badsection_dies | 
| 74 | t/npg03/input/15_badsection_catch | ||
| 57 | t/npg03/plugins.ini | 75 | t/npg03/plugins.ini | 
| 58 | t/npg03/README | 76 | t/npg03/README | 
| diff --git a/MANIFEST.SKIP b/MANIFEST.SKIP new file mode 100644 index 0000000..134a92b --- /dev/null +++ b/MANIFEST.SKIP | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | .DS_Store | ||
| 2 | \.swp | ||
| 3 | blib | ||
| 4 | tmp | ||
| 5 | \.git | ||
| 6 | ^Makefile$ | ||
| 7 | Makefile.old | ||
| 8 | MANIFEST.bak | ||
| 9 | MANIFEST.SKIP | ||
| 10 | MYMETA.yml | ||
| 11 | MYMETA.json | ||
| 12 | pm_to_blib | ||
| 13 | .*\.gz | ||
| 14 | # does not work for centos without F::C::R installed | ||
| 15 | inc/File/Copy/Recursive.pm | ||
| 16 | TODO | ||
| 17 | build-stamp | ||
| 18 | configure-stamp | ||
| 19 | nytprof/ | ||
| 20 | nytprof.out | ||
| 21 | .~ko-6.1.3-perllint~ | ||
| diff --git a/Makefile.PL b/Makefile.PL index c043edb..d1f0c2a 100644 --- a/Makefile.PL +++ b/Makefile.PL | |||
| @@ -1,22 +1,23 @@ | |||
| 1 | use 5.006; | 1 | use inc::Module::Install; | 
| 2 | use ExtUtils::MakeMaker; | 2 | |
| 3 | # See lib/ExtUtils/MakeMaker.pm for details of how to influence | 3 | name 'Monitoring-Plugin'; | 
| 4 | # the contents of the Makefile that is written. | 4 | all_from 'lib/Monitoring/Plugin/Functions.pm'; | 
| 5 | WriteMakefile( | 5 | author q{Monitoring Plugin Team <devel@monitoring-plugins.org>}; | 
| 6 | NAME => 'Nagios::Plugin', | 6 | license 'perl'; | 
| 7 | VERSION_FROM => 'lib/Nagios/Plugin/Functions.pm', # finds $VERSION | 7 | repository 'https://github.com/monitoring-plugins/monitoring-plugin-perl'; | 
| 8 | PREREQ_PM => { | 8 | |
| 9 | Params::Validate => 0, | 9 | requires 'Params::Validate' => 0; | 
| 10 | Class::Accessor => 0, | 10 | requires 'Class::Accessor' => 0; | 
| 11 | Test::More => 0.62, | 11 | requires 'Carp' => 0; | 
| 12 | Carp => 0, | 12 | requires 'Config::Tiny' => 0; | 
| 13 | Config::Tiny => 0, | 13 | requires 'File::Spec' => 0; | 
| 14 | File::Spec => 0, | 14 | requires 'File::Basename' => 0; | 
| 15 | File::Basename => 0, | 15 | requires 'IO::File' => 0; | 
| 16 | IO::File => 0, | 16 | requires 'Math::Calc::Units' => 0; # used in M::P::Performance | 
| 17 | Math::Calc::Units => 0, # used in N::P::Performance | 17 | |
| 18 | }, # e.g., Module::Name => 1.1 | 18 | |
| 19 | ($] >= 5.005 ? ## Add these new keywords supported since 5.005 | 19 | build_requires 'Test::More' => 0.62; | 
| 20 | (ABSTRACT_FROM => 'lib/Nagios/Plugin.pm', # retrieve abstract from module | 20 | |
| 21 | AUTHOR => 'Nagios Plugin Development Team <nagiosplug-devel@lists.sourceforge.net>') : ()), | 21 | auto_install; | 
| 22 | ); | 22 | |
| 23 | WriteAll; | ||
| @@ -1,13 +1,12 @@ | |||
| 1 | Nagios::Plugin | 1 | Monitoring::Plugin | 
| 2 | ============== | 2 | ================== | 
| 3 | 3 | ||
| 4 | These modules are meant for perl developers of plugins for Nagios | 4 | These modules are meant for perl developers of plugins for Naemon, Nagios, | 
| 5 | (http://nagiosplug.sourceforge.net). It is meant to simplify a lot | 5 | Icinga, Shinken and other compatible products. It is meant to | 
| 6 | of the common functions required to do checking of a particular | 6 | simplify a lot of the common functions required to do checking of a | 
| 7 | service. | 7 | particular service. | 
| 8 | 8 | This module is maintained by the Monitoring-Plugins team | |
| 9 | The modules are still in an experimental stage and will be considered | 9 | (https:://monitoring-plugins.org) | 
| 10 | stable when it reaches version 1.0. | ||
| 11 | 10 | ||
| 12 | INSTALLATION | 11 | INSTALLATION | 
| 13 | 12 | ||
| @@ -23,16 +22,14 @@ EXAMPLE SCRIPT | |||
| 23 | 22 | ||
| 24 | "Enough talk! Show me where to start!" | 23 | "Enough talk! Show me where to start!" | 
| 25 | 24 | ||
| 26 | See the file 'check_stuff.pl' in the 't' directory for a complete | 25 | See the file 'check_stuff.pl' in the 't' directory for a complete | 
| 27 | working example of a plugin script. | 26 | working example of a plugin script. | 
| 28 | 27 | ||
| 29 | 28 | ||
| 30 | COPYRIGHT AND LICENCE | 29 | COPYRIGHT AND LICENCE | 
| 31 | 30 | ||
| 32 | Copyright (C) 2006 by Nagios Plugin Development Team | 31 | Copyright (C) 2006-2014 by Monitoring Plugin Team | 
| 33 | 32 | ||
| 34 | This library is free software; you can redistribute it and/or modify | 33 | This library is free software; you can redistribute it and/or modify | 
| 35 | it under the same terms as Perl itself, either Perl version 5.8.4 or, | 34 | it under the same terms as Perl itself, either Perl version 5.8.4 or, | 
| 36 | at your option, any later version of Perl 5 you may have available. | 35 | at your option, any later version of Perl 5 you may have available. | 
| 37 | |||
| 38 | |||
| diff --git a/lib/Nagios/Plugin.pm b/lib/Monitoring/Plugin.pm index d85d35a..f9eb49e 100644 --- a/lib/Nagios/Plugin.pm +++ b/lib/Monitoring/Plugin.pm | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | 1 | ||
| 2 | package Nagios::Plugin; | 2 | package Monitoring::Plugin; | 
| 3 | 3 | ||
| 4 | use Nagios::Plugin::Functions qw(:codes %ERRORS %STATUS_TEXT @STATUS_CODES); | 4 | use Monitoring::Plugin::Functions qw(:codes %ERRORS %STATUS_TEXT @STATUS_CODES); | 
| 5 | use Params::Validate qw(:all); | 5 | use Params::Validate qw(:all); | 
| 6 | 6 | ||
| 7 | use strict; | 7 | use strict; | 
| @@ -10,10 +10,10 @@ use warnings; | |||
| 10 | use Carp; | 10 | use Carp; | 
| 11 | use base qw(Class::Accessor::Fast); | 11 | use base qw(Class::Accessor::Fast); | 
| 12 | 12 | ||
| 13 | Nagios::Plugin->mk_accessors(qw( | 13 | Monitoring::Plugin->mk_accessors(qw( | 
| 14 | shortname | 14 | shortname | 
| 15 | perfdata | 15 | perfdata | 
| 16 | messages | 16 | messages | 
| 17 | opts | 17 | opts | 
| 18 | threshold | 18 | threshold | 
| 19 | )); | 19 | )); | 
| @@ -25,8 +25,8 @@ our @EXPORT_OK = qw(%ERRORS %STATUS_TEXT); | |||
| 25 | 25 | ||
| 26 | # CPAN stupidly won't index this module without a literal $VERSION here, | 26 | # CPAN stupidly won't index this module without a literal $VERSION here, | 
| 27 | # so we're forced to duplicate it explicitly | 27 | # so we're forced to duplicate it explicitly | 
| 28 | # Make sure you update $Nagios::Plugin::Functions::VERSION too | 28 | # Make sure you update $Monitoring::Plugin::Functions::VERSION too | 
| 29 | our $VERSION = "0.36"; | 29 | our $VERSION = "0.37"; | 
| 30 | 30 | ||
| 31 | sub new { | 31 | sub new { | 
| 32 | my $class = shift; | 32 | my $class = shift; | 
| @@ -46,7 +46,7 @@ sub new { | |||
| 46 | }, | 46 | }, | 
| 47 | ); | 47 | ); | 
| 48 | 48 | ||
| 49 | my $shortname = Nagios::Plugin::Functions::get_shortname(\%args); | 49 | my $shortname = Monitoring::Plugin::Functions::get_shortname(\%args); | 
| 50 | delete $args{shortname} if (exists $args{shortname}); | 50 | delete $args{shortname} if (exists $args{shortname}); | 
| 51 | my $self = { | 51 | my $self = { | 
| 52 | shortname => $shortname, | 52 | shortname => $shortname, | 
| @@ -61,16 +61,16 @@ sub new { | |||
| 61 | }; | 61 | }; | 
| 62 | bless $self, $class; | 62 | bless $self, $class; | 
| 63 | if (exists $args{usage}) { | 63 | if (exists $args{usage}) { | 
| 64 | require Nagios::Plugin::Getopt; | 64 | require Monitoring::Plugin::Getopt; | 
| 65 | $self->opts( new Nagios::Plugin::Getopt(%args) ); | 65 | $self->opts( new Monitoring::Plugin::Getopt(%args) ); | 
| 66 | } | 66 | } | 
| 67 | return $self; | 67 | return $self; | 
| 68 | } | 68 | } | 
| 69 | 69 | ||
| 70 | sub add_perfdata { | 70 | sub add_perfdata { | 
| 71 | my ($self, %args) = @_; | 71 | my ($self, %args) = @_; | 
| 72 | require Nagios::Plugin::Performance; | 72 | require Monitoring::Plugin::Performance; | 
| 73 | my $perf = Nagios::Plugin::Performance->new(%args); | 73 | my $perf = Monitoring::Plugin::Performance->new(%args); | 
| 74 | push @{$self->perfdata}, $perf; | 74 | push @{$self->perfdata}, $perf; | 
| 75 | } | 75 | } | 
| 76 | sub all_perfoutput { | 76 | sub all_perfoutput { | 
| @@ -78,33 +78,41 @@ sub all_perfoutput { | |||
| 78 | return join(" ", map {$_->perfoutput} (@{$self->perfdata})); | 78 | return join(" ", map {$_->perfoutput} (@{$self->perfdata})); | 
| 79 | } | 79 | } | 
| 80 | 80 | ||
| 81 | sub set_thresholds { | 81 | sub set_thresholds { | 
| 82 | my $self = shift; | 82 | my $self = shift; | 
| 83 | require Nagios::Plugin::Threshold; | 83 | require Monitoring::Plugin::Threshold; | 
| 84 | return $self->threshold( Nagios::Plugin::Threshold->set_thresholds(@_)); | 84 | return $self->threshold( Monitoring::Plugin::Threshold->set_thresholds(@_)); | 
| 85 | } | 85 | } | 
| 86 | 86 | ||
| 87 | # NP::Functions wrappers | 87 | # MP::Functions wrappers | 
| 88 | sub plugin_exit { | ||
| 89 | my $self = shift; | ||
| 90 | Monitoring::Plugin::Functions::plugin_exit(@_, { plugin => $self }); | ||
| 91 | } | ||
| 92 | sub plugin_die { | ||
| 93 | my $self = shift; | ||
| 94 | Monitoring::Plugin::Functions::plugin_die(@_, { plugin => $self }); | ||
| 95 | } | ||
| 88 | sub nagios_exit { | 96 | sub nagios_exit { | 
| 89 | my $self = shift; | 97 | my $self = shift; | 
| 90 | Nagios::Plugin::Functions::nagios_exit(@_, { plugin => $self }); | 98 | Monitoring::Plugin::Functions::plugin_exit(@_, { plugin => $self }); | 
| 91 | } | 99 | } | 
| 92 | sub nagios_die { | 100 | sub nagios_die { | 
| 93 | my $self = shift; | 101 | my $self = shift; | 
| 94 | Nagios::Plugin::Functions::nagios_die(@_, { plugin => $self }); | 102 | Monitoring::Plugin::Functions::plugin_die(@_, { plugin => $self }); | 
| 95 | } | 103 | } | 
| 96 | sub die { | 104 | sub die { | 
| 97 | my $self = shift; | 105 | my $self = shift; | 
| 98 | Nagios::Plugin::Functions::nagios_die(@_, { plugin => $self }); | 106 | Monitoring::Plugin::Functions::plugin_die(@_, { plugin => $self }); | 
| 99 | } | 107 | } | 
| 100 | sub max_state { | 108 | sub max_state { | 
| 101 | Nagios::Plugin::Functions::max_state(@_); | 109 | Monitoring::Plugin::Functions::max_state(@_); | 
| 102 | } | 110 | } | 
| 103 | sub max_state_alt { | 111 | sub max_state_alt { | 
| 104 | Nagios::Plugin::Functions::max_state_alt(@_); | 112 | Monitoring::Plugin::Functions::max_state_alt(@_); | 
| 105 | } | 113 | } | 
| 106 | 114 | ||
| 107 | # top level interface to Nagios::Plugin::Threshold | 115 | # top level interface to Monitoring::Plugin::Threshold | 
| 108 | sub check_threshold { | 116 | sub check_threshold { | 
| 109 | my $self = shift; | 117 | my $self = shift; | 
| 110 | 118 | ||
| @@ -143,11 +151,11 @@ sub check_threshold { | |||
| 143 | else { | 151 | else { | 
| 144 | return UNKNOWN; | 152 | return UNKNOWN; | 
| 145 | } | 153 | } | 
| 146 | 154 | ||
| 147 | return $self->threshold->get_status($args{check}); | 155 | return $self->threshold->get_status($args{check}); | 
| 148 | } | 156 | } | 
| 149 | 157 | ||
| 150 | # top level interface to my Nagios::Plugin::Getopt object | 158 | # top level interface to my Monitoring::Plugin::Getopt object | 
| 151 | sub add_arg { | 159 | sub add_arg { | 
| 152 | my $self = shift; | 160 | my $self = shift; | 
| 153 | $self->opts->arg(@_) if $self->_check_for_opts; | 161 | $self->opts->arg(@_) if $self->_check_for_opts; | 
| @@ -160,15 +168,15 @@ sub getopts { | |||
| 160 | sub _check_for_opts { | 168 | sub _check_for_opts { | 
| 161 | my $self = shift; | 169 | my $self = shift; | 
| 162 | croak | 170 | croak | 
| 163 | "You have to supply a 'usage' param to Nagios::Plugin::new() if you want to use Getopts from your Nagios::Plugin object." | 171 | "You have to supply a 'usage' param to Monitoring::Plugin::new() if you want to use Getopts from your Monitoring::Plugin object." | 
| 164 | unless ref $self->opts() eq 'Nagios::Plugin::Getopt'; | 172 | unless ref $self->opts() eq 'Monitoring::Plugin::Getopt'; | 
| 165 | return $self; | 173 | return $self; | 
| 166 | } | 174 | } | 
| 167 | 175 | ||
| 168 | 176 | ||
| 169 | 177 | ||
| 170 | # ------------------------------------------------------------------------- | 178 | # ------------------------------------------------------------------------- | 
| 171 | # NP::Functions::check_messages helpers and wrappers | 179 | # MP::Functions::check_messages helpers and wrappers | 
| 172 | 180 | ||
| 173 | sub add_message { | 181 | sub add_message { | 
| 174 | my $self = shift; | 182 | my $self = shift; | 
| @@ -179,7 +187,7 @@ sub add_message { | |||
| 179 | 187 | ||
| 180 | # Store messages using strings rather than numeric codes | 188 | # Store messages using strings rather than numeric codes | 
| 181 | $code = $STATUS_TEXT{$code} if $STATUS_TEXT{$code}; | 189 | $code = $STATUS_TEXT{$code} if $STATUS_TEXT{$code}; | 
| 182 | $code = lc $code; | 190 | $code = lc $code; | 
| 183 | croak "Error code '$code' not supported by add_message" | 191 | croak "Error code '$code' not supported by add_message" | 
| 184 | if $code eq 'unknown' || $code eq 'dependent'; | 192 | if $code eq 'unknown' || $code eq 'dependent'; | 
| 185 | 193 | ||
| @@ -199,7 +207,7 @@ sub check_messages { | |||
| 199 | if ($code eq 'ok') { | 207 | if ($code eq 'ok') { | 
| 200 | $args{$code} = [ $args{$code} ]; | 208 | $args{$code} = [ $args{$code} ]; | 
| 201 | } else { | 209 | } else { | 
| 202 | croak "Invalid argument '$code'" | 210 | croak "Invalid argument '$code'" | 
| 203 | } | 211 | } | 
| 204 | } | 212 | } | 
| 205 | push @{$args{$code}}, @$messages; | 213 | push @{$args{$code}}, @$messages; | 
| @@ -209,7 +217,7 @@ sub check_messages { | |||
| 209 | } | 217 | } | 
| 210 | } | 218 | } | 
| 211 | 219 | ||
| 212 | Nagios::Plugin::Functions::check_messages(%args); | 220 | Monitoring::Plugin::Functions::check_messages(%args); | 
| 213 | } | 221 | } | 
| 214 | 222 | ||
| 215 | # ------------------------------------------------------------------------- | 223 | # ------------------------------------------------------------------------- | 
| @@ -222,23 +230,23 @@ __END__ | |||
| 222 | 230 | ||
| 223 | =head1 NAME | 231 | =head1 NAME | 
| 224 | 232 | ||
| 225 | Nagios::Plugin - A family of perl modules to streamline writing Nagios | 233 | Monitoring::Plugin - A family of perl modules to streamline writing Naemon, Nagios, | 
| 226 | plugins | 234 | Icinga or Shinken (and compatible) plugins. | 
| 227 | 235 | ||
| 228 | =head1 SYNOPSIS | 236 | =head1 SYNOPSIS | 
| 229 | 237 | ||
| 230 | # Constants OK, WARNING, CRITICAL, and UNKNOWN are exported by default | 238 | # Constants OK, WARNING, CRITICAL, and UNKNOWN are exported by default | 
| 231 | # See also Nagios::Plugin::Functions for a functional interface | 239 | # See also Monitoring::Plugin::Functions for a functional interface | 
| 232 | use Nagios::Plugin; | 240 | use Monitoring::Plugin; | 
| 233 | 241 | ||
| 234 | # Constructor | 242 | # Constructor | 
| 235 | $np = Nagios::Plugin->new; # OR | 243 | $np = Monitoring::Plugin->new; # OR | 
| 236 | $np = Nagios::Plugin->new( shortname => "PAGESIZE" ); # OR | 244 | $np = Monitoring::Plugin->new( shortname => "PAGESIZE" ); # OR | 
| 237 | 245 | ||
| 238 | 246 | ||
| 239 | # use Nagios::Plugin::Getopt to process the @ARGV command line options: | 247 | # use Monitoring::Plugin::Getopt to process the @ARGV command line options: | 
| 240 | # --verbose, --help, --usage, --timeout and --host are defined automatically. | 248 | # --verbose, --help, --usage, --timeout and --host are defined automatically. | 
| 241 | $np = Nagios::Plugin->new( | 249 | $np = Monitoring::Plugin->new( | 
| 242 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] " | 250 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] " | 
| 243 | . "[ -c|--critical=<threshold> ] [ -w|--warning=<threshold> ]", | 251 | . "[ -c|--critical=<threshold> ] [ -w|--warning=<threshold> ]", | 
| 244 | ); | 252 | ); | 
| @@ -247,7 +255,7 @@ plugins | |||
| 247 | $np->add_arg( | 255 | $np->add_arg( | 
| 248 | spec => 'warning|w=s', | 256 | spec => 'warning|w=s', | 
| 249 | help => '-w, --warning=INTEGER:INTEGER . See ' | 257 | help => '-w, --warning=INTEGER:INTEGER . See ' | 
| 250 | . 'http://nagiosplug.sourceforge.net/developer-guidelines.html#THRESHOLDFORMAT ' | 258 | . 'https://www.monitoring-plugins.org/doc/guidelines.html#THRESHOLDFORMAT ' | 
| 251 | . 'for the threshold format. ', | 259 | . 'for the threshold format. ', | 
| 252 | ); | 260 | ); | 
| 253 | 261 | ||
| @@ -255,29 +263,29 @@ plugins | |||
| 255 | $np->getopts; | 263 | $np->getopts; | 
| 256 | 264 | ||
| 257 | 265 | ||
| 258 | # Exit/return value methods - nagios_exit( CODE, MESSAGE ), | 266 | # Exit/return value methods - plugin_exit( CODE, MESSAGE ), | 
| 259 | # nagios_die( MESSAGE, [CODE]) | 267 | # plugin_die( MESSAGE, [CODE]) | 
| 260 | $page = retrieve_page($page1) | 268 | $page = retrieve_page($page1) | 
| 261 | or $np->nagios_exit( UNKNOWN, "Could not retrieve page" ); | 269 | or $np->plugin_exit( UNKNOWN, "Could not retrieve page" ); | 
| 262 | # Return code: 3; | 270 | # Return code: 3; | 
| 263 | # output: PAGESIZE UNKNOWN - Could not retrieve page | 271 | # output: PAGESIZE UNKNOWN - Could not retrieve page | 
| 264 | test_page($page) | 272 | test_page($page) | 
| 265 | or $np->nagios_exit( CRITICAL, "Bad page found" ); | 273 | or $np->plugin_exit( CRITICAL, "Bad page found" ); | 
| 266 | 274 | ||
| 267 | # nagios_die() is just like nagios_exit(), but return code defaults | 275 | # plugin_die() is just like plugin_exit(), but return code defaults | 
| 268 | # to UNKNOWN | 276 | # to UNKNOWN | 
| 269 | $page = retrieve_page($page2) | 277 | $page = retrieve_page($page2) | 
| 270 | or $np->nagios_die( "Could not retrieve page" ); | 278 | or $np->plugin_die( "Could not retrieve page" ); | 
| 271 | # Return code: 3; | 279 | # Return code: 3; | 
| 272 | # output: PAGESIZE UNKNOWN - Could not retrieve page | 280 | # output: PAGESIZE UNKNOWN - Could not retrieve page | 
| 273 | 281 | ||
| 274 | # Threshold methods | 282 | # Threshold methods | 
| 275 | $code = $np->check_threshold( | 283 | $code = $np->check_threshold( | 
| 276 | check => $value, | 284 | check => $value, | 
| 277 | warning => $warning_threshold, | 285 | warning => $warning_threshold, | 
| 278 | critical => $critical_threshold, | 286 | critical => $critical_threshold, | 
| 279 | ); | 287 | ); | 
| 280 | $np->nagios_exit( $code, "Threshold check failed" ) if $code != OK; | 288 | $np->plugin_exit( $code, "Threshold check failed" ) if $code != OK; | 
| 281 | 289 | ||
| 282 | 290 | ||
| 283 | # Message methods (EXPERIMENTAL AND SUBJECT TO CHANGE) - | 291 | # Message methods (EXPERIMENTAL AND SUBJECT TO CHANGE) - | 
| @@ -290,38 +298,38 @@ plugins | |||
| 290 | } | 298 | } | 
| 291 | } | 299 | } | 
| 292 | ($code, $message) = $np->check_messages(); | 300 | ($code, $message) = $np->check_messages(); | 
| 293 | nagios_exit( $code, $message ); | 301 | plugin_exit( $code, $message ); | 
| 294 | # If any items in collection matched m/Error/, returns CRITICAL and | 302 | # If any items in collection matched m/Error/, returns CRITICAL and | 
| 295 | # the joined set of Error messages; otherwise returns OK and the | 303 | # the joined set of Error messages; otherwise returns OK and the | 
| 296 | # joined set of ok messages | 304 | # joined set of ok messages | 
| 297 | 305 | ||
| 298 | 306 | ||
| 299 | # Perfdata methods | 307 | # Perfdata methods | 
| 300 | $np->add_perfdata( | 308 | $np->add_perfdata( | 
| 301 | label => "size", | 309 | label => "size", | 
| 302 | value => $value, | 310 | value => $value, | 
| 303 | uom => "kB", | 311 | uom => "kB", | 
| 304 | threshold => $threshold, | 312 | threshold => $threshold, | 
| 305 | ); | 313 | ); | 
| 306 | $np->add_perfdata( label => "time", ... ); | 314 | $np->add_perfdata( label => "time", ... ); | 
| 307 | $np->nagios_exit( OK, "page size at http://... was ${value}kB" ); | 315 | $np->plugin_exit( OK, "page size at http://... was ${value}kB" ); | 
| 308 | # Return code: 0; | 316 | # Return code: 0; | 
| 309 | # output: PAGESIZE OK - page size at http://... was 36kB \ | 317 | # output: PAGESIZE OK - page size at http://... was 36kB \ | 
| 310 | # | size=36kB;10:25;25: time=... | 318 | # | size=36kB;10:25;25: time=... | 
| 311 | 319 | ||
| 312 | 320 | ||
| 313 | =head1 DESCRIPTION | 321 | =head1 DESCRIPTION | 
| 314 | 322 | ||
| 315 | Nagios::Plugin and its associated Nagios::Plugin::* modules are a | 323 | Monitoring::Plugin and its associated Monitoring::Plugin::* modules are a | 
| 316 | family of perl modules to streamline writing Nagios plugins. The main | 324 | family of perl modules to streamline writing Monitoring plugins. The main | 
| 317 | end user modules are Nagios::Plugin, providing an object-oriented | 325 | end user modules are Monitoring::Plugin, providing an object-oriented | 
| 318 | interface to the entire Nagios::Plugin::* collection, and | 326 | interface to the entire Monitoring::Plugin::* collection, and | 
| 319 | Nagios::Plugin::Functions, providing a simpler functional interface to | 327 | Monitoring::Plugin::Functions, providing a simpler functional interface to | 
| 320 | a useful subset of the available functionality. | 328 | a useful subset of the available functionality. | 
| 321 | 329 | ||
| 322 | The purpose of the collection is to make it as simple as possible for | 330 | The purpose of the collection is to make it as simple as possible for | 
| 323 | developers to create plugins that conform the Nagios Plugin guidelines | 331 | developers to create plugins that conform the Monitoring Plugin guidelines | 
| 324 | (http://nagiosplug.sourceforge.net/developer-guidelines.html). | 332 | (https://www.monitoring-plugins.org/doc/guidelines.html). | 
| 325 | 333 | ||
| 326 | 334 | ||
| 327 | =head2 EXPORTS | 335 | =head2 EXPORTS | 
| @@ -346,7 +354,7 @@ corresponding status code. | |||
| 346 | =item %STATUS_TEXT | 354 | =item %STATUS_TEXT | 
| 347 | 355 | ||
| 348 | A hash mapping status code constants (OK, WARNING, CRITICAL, etc.) to the | 356 | A hash mapping status code constants (OK, WARNING, CRITICAL, etc.) to the | 
| 349 | corresponding error string ("OK", "WARNING, "CRITICAL", etc.) i.e. the | 357 | corresponding error string ("OK", "WARNING, "CRITICAL", etc.) i.e. the | 
| 350 | reverse of %ERRORS. | 358 | reverse of %ERRORS. | 
| 351 | 359 | ||
| 352 | =back | 360 | =back | 
| @@ -354,11 +362,11 @@ reverse of %ERRORS. | |||
| 354 | 362 | ||
| 355 | =head2 CONSTRUCTOR | 363 | =head2 CONSTRUCTOR | 
| 356 | 364 | ||
| 357 | Nagios::Plugin->new; | 365 | Monitoring::Plugin->new; | 
| 358 | 366 | ||
| 359 | Nagios::Plugin->new( shortname => 'PAGESIZE' ); | 367 | Monitoring::Plugin->new( shortname => 'PAGESIZE' ); | 
| 360 | 368 | ||
| 361 | Nagios::Plugin->new( | 369 | Monitoring::Plugin->new( | 
| 362 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] | 370 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] | 
| 363 | [ -c|--critical=<critical threshold> ] [ -w|--warning=<warning threshold> ] ", | 371 | [ -c|--critical=<critical threshold> ] [ -w|--warning=<warning threshold> ] ", | 
| 364 | version => $VERSION, | 372 | version => $VERSION, | 
| @@ -370,7 +378,7 @@ reverse of %ERRORS. | |||
| 370 | timeout => 15, | 378 | timeout => 15, | 
| 371 | ); | 379 | ); | 
| 372 | 380 | ||
| 373 | Instantiates a new Nagios::Plugin object. Accepts the following named | 381 | Instantiates a new Monitoring::Plugin object. Accepts the following named | 
| 374 | arguments: | 382 | arguments: | 
| 375 | 383 | ||
| 376 | =over 4 | 384 | =over 4 | 
| @@ -382,10 +390,10 @@ output by the various exit methods. Default: uc basename $0. | |||
| 382 | 390 | ||
| 383 | =item usage ("Usage: %s --foo --bar") | 391 | =item usage ("Usage: %s --foo --bar") | 
| 384 | 392 | ||
| 385 | Passing a value for the usage() argument makes Nagios::Plugin | 393 | Passing a value for the usage() argument makes Monitoring::Plugin | 
| 386 | instantiate its own C<Nagios::Plugin::Getopt> object so you can start | 394 | instantiate its own C<Monitoring::Plugin::Getopt> object so you can start | 
| 387 | doing command line argument processing. See | 395 | doing command line argument processing. See | 
| 388 | L<Nagios::Plugin::Getopt/CONSTRUCTOR> for more about "usage" and the | 396 | L<Monitoring::Plugin::Getopt/CONSTRUCTOR> for more about "usage" and the | 
| 389 | following options: | 397 | following options: | 
| 390 | 398 | ||
| 391 | =item version | 399 | =item version | 
| @@ -406,7 +414,7 @@ following options: | |||
| 406 | 414 | ||
| 407 | =head2 OPTION HANDLING METHODS | 415 | =head2 OPTION HANDLING METHODS | 
| 408 | 416 | ||
| 409 | C<Nagios::Plugin> provides these methods for accessing the functionality in C<Nagios::Plugin::Getopt>. | 417 | C<Monitoring::Plugin> provides these methods for accessing the functionality in C<Monitoring::Plugin::Getopt>. | 
| 410 | 418 | ||
| 411 | =over 4 | 419 | =over 4 | 
| 412 | 420 | ||
| @@ -416,7 +424,7 @@ Examples: | |||
| 416 | 424 | ||
| 417 | # Define --hello argument (named parameters) | 425 | # Define --hello argument (named parameters) | 
| 418 | $plugin->add_arg( | 426 | $plugin->add_arg( | 
| 419 | spec => 'hello=s', | 427 | spec => 'hello=s', | 
| 420 | help => "--hello\n Hello string", | 428 | help => "--hello\n Hello string", | 
| 421 | required => 1, | 429 | required => 1, | 
| 422 | ); | 430 | ); | 
| @@ -425,19 +433,19 @@ Examples: | |||
| 425 | # Parameter order is 'spec', 'help', 'default', 'required?' | 433 | # Parameter order is 'spec', 'help', 'default', 'required?' | 
| 426 | $plugin->add_arg('hello=s', "--hello\n Hello string", undef, 1); | 434 | $plugin->add_arg('hello=s', "--hello\n Hello string", undef, 1); | 
| 427 | 435 | ||
| 428 | See L<Nagios::Plugin::Getopt/ARGUMENTS> for more details. | 436 | See L<Monitoring::Plugin::Getopt/ARGUMENTS> for more details. | 
| 429 | 437 | ||
| 430 | =item getopts() | 438 | =item getopts() | 
| 431 | 439 | ||
| 432 | Parses and processes the command line options you've defined, | 440 | Parses and processes the command line options you've defined, | 
| 433 | automatically doing the right thing with help/usage/version arguments. | 441 | automatically doing the right thing with help/usage/version arguments. | 
| 434 | 442 | ||
| 435 | See L<Nagios::Plugin::Getopt/GETOPTS> for more details. | 443 | See L<Monitoring::Plugin::Getopt/GETOPTS> for more details. | 
| 436 | 444 | ||
| 437 | =item opts() | 445 | =item opts() | 
| 438 | 446 | ||
| 439 | Assuming you've instantiated it by passing 'usage' to new(), opts() | 447 | Assuming you've instantiated it by passing 'usage' to new(), opts() | 
| 440 | returns the Nagios::Plugin object's C<Nagios::Plugin::Getopt> object, | 448 | returns the Monitoring::Plugin object's C<Monitoring::Plugin::Getopt> object, | 
| 441 | with which you can do lots of great things. | 449 | with which you can do lots of great things. | 
| 442 | 450 | ||
| 443 | E.g. | 451 | E.g. | 
| @@ -456,7 +464,7 @@ E.g. | |||
| 456 | # $plugin->getopts; | 464 | # $plugin->getopts; | 
| 457 | print $plugin->opts->my_argument; | 465 | print $plugin->opts->my_argument; | 
| 458 | 466 | ||
| 459 | Again, see L<Nagios::Plugin::Getopt>. | 467 | Again, see L<Monitoring::Plugin::Getopt>. | 
| 460 | 468 | ||
| 461 | =back | 469 | =back | 
| 462 | 470 | ||
| @@ -464,33 +472,41 @@ Again, see L<Nagios::Plugin::Getopt>. | |||
| 464 | 472 | ||
| 465 | =over 4 | 473 | =over 4 | 
| 466 | 474 | ||
| 467 | =item nagios_exit( <CODE>, $message ) | 475 | =item plugin_exit( <CODE>, $message ) | 
| 468 | 476 | ||
| 469 | Exit with return code CODE, and a standard nagios message of the | 477 | Exit with return code CODE, and a standard nagios message of the | 
| 470 | form "SHORTNAME CODE - $message". | 478 | form "SHORTNAME CODE - $message". | 
| 471 | 479 | ||
| 472 | =item nagios_die( $message, [<CODE>] ) | 480 | =item plugin_die( $message, [<CODE>] ) | 
| 473 | 481 | ||
| 474 | Same as nagios_exit(), except that CODE is optional, defaulting | 482 | Same as plugin_exit(), except that CODE is optional, defaulting | 
| 475 | to UNKNOWN. NOTE: exceptions are not raised by default to calling code. | 483 | to UNKNOWN. NOTE: exceptions are not raised by default to calling code. | 
| 476 | Set C<$_use_die> flag if this functionality is required (see test code). | 484 | Set C<$_use_die> flag if this functionality is required (see test code). | 
| 477 | 485 | ||
| 486 | =item nagios_exit( <CODE>, $message ) | ||
| 487 | |||
| 488 | Alias for plugin_die(). Deprecated. | ||
| 489 | |||
| 490 | =item nagios_die( $message, [<CODE>] ) | ||
| 491 | |||
| 492 | Alias for plugin_die(). Deprecated. | ||
| 493 | |||
| 478 | =item die( $message, [<CODE>] ) | 494 | =item die( $message, [<CODE>] ) | 
| 479 | 495 | ||
| 480 | Alias for nagios_die(). Deprecated. | 496 | Alias for plugin_die(). Deprecated. | 
| 481 | 497 | ||
| 482 | =item max_state, max_state_alt | 498 | =item max_state, max_state_alt | 
| 483 | 499 | ||
| 484 | These are wrapper function for Nagios::Plugin::Functions::max_state and | 500 | These are wrapper function for Monitoring::Plugin::Functions::max_state and | 
| 485 | Nagios::Plugin::Functions::max_state_alt. | 501 | Monitoring::Plugin::Functions::max_state_alt. | 
| 486 | 502 | ||
| 487 | =back | 503 | =back | 
| 488 | 504 | ||
| 489 | =head2 THRESHOLD METHODS | 505 | =head2 THRESHOLD METHODS | 
| 490 | 506 | ||
| 491 | These provide a top level interface to the | 507 | These provide a top level interface to the | 
| 492 | C<Nagios::Plugin::Threshold> module; for more details, see | 508 | C<Monitoring::Plugin::Threshold> module; for more details, see | 
| 493 | L<Nagios::Plugin::Threshold> and L<Nagios::Plugin::Range>. | 509 | L<Monitoring::Plugin::Threshold> and L<Monitoring::Plugin::Range>. | 
| 494 | 510 | ||
| 495 | =over 4 | 511 | =over 4 | 
| 496 | 512 | ||
| @@ -512,9 +528,9 @@ WARNING constant. The thresholds may be: | |||
| 512 | You can specify $value as an array of values and each will be checked against | 528 | You can specify $value as an array of values and each will be checked against | 
| 513 | the thresholds. | 529 | the thresholds. | 
| 514 | 530 | ||
| 515 | The return value is ready to pass to C <nagios_exit>, e . g ., | 531 | The return value is ready to pass to C <plugin_exit>, e . g ., | 
| 516 | 532 | ||
| 517 | $p->nagios_exit( | 533 | $p->plugin_exit( | 
| 518 | return_code => $p->check_threshold($result), | 534 | return_code => $p->check_threshold($result), | 
| 519 | message => " sample result was $result" | 535 | message => " sample result was $result" | 
| 520 | ); | 536 | ); | 
| @@ -523,13 +539,13 @@ The return value is ready to pass to C <nagios_exit>, e . g ., | |||
| 523 | =item set_thresholds(warning => "10:25", critical => "~:25") | 539 | =item set_thresholds(warning => "10:25", critical => "~:25") | 
| 524 | 540 | ||
| 525 | Sets the acceptable ranges and creates the plugin's | 541 | Sets the acceptable ranges and creates the plugin's | 
| 526 | Nagios::Plugins::Threshold object. See | 542 | Monitoring::Plugins::Threshold object. See | 
| 527 | http://nagiosplug.sourceforge.net/developer-guidelines.html#THRESHOLDFORMAT | 543 | https://www.monitoring-plugins.org/doc/guidelines.html#THRESHOLDFORMAT | 
| 528 | for details and examples of the threshold format. | 544 | for details and examples of the threshold format. | 
| 529 | 545 | ||
| 530 | =item threshold() | 546 | =item threshold() | 
| 531 | 547 | ||
| 532 | Returns the object's C<Nagios::Plugin::Threshold> object, if it has | 548 | Returns the object's C<Monitoring::Plugin::Threshold> object, if it has | 
| 533 | been defined by calling set_thresholds(). You can pass a new | 549 | been defined by calling set_thresholds(). You can pass a new | 
| 534 | Threshold object to it to replace the old one too, but you shouldn't | 550 | Threshold object to it to replace the old one too, but you shouldn't | 
| 535 | need to do that from a plugin script. | 551 | need to do that from a plugin script. | 
| @@ -543,17 +559,17 @@ EXPERIMENTAL AND SUBJECT TO CHANGE | |||
| 543 | add_messages and check_messages are higher-level convenience methods to add | 559 | add_messages and check_messages are higher-level convenience methods to add | 
| 544 | and then check a set of messages, returning an appropriate return code | 560 | and then check a set of messages, returning an appropriate return code | 
| 545 | and/or result message. They are equivalent to maintaining a set of @critical, | 561 | and/or result message. They are equivalent to maintaining a set of @critical, | 
| 546 | @warning, and and @ok message arrays (add_message), and then doing a final | 562 | @warning, and and @ok message arrays (add_message), and then doing a final | 
| 547 | if test (check_messages) like this: | 563 | if test (check_messages) like this: | 
| 548 | 564 | ||
| 549 | if (@critical) { | 565 | if (@critical) { | 
| 550 | nagios_exit( CRITICAL, join(' ', @critical) ); | 566 | plugin_exit( CRITICAL, join(' ', @critical) ); | 
| 551 | } | 567 | } | 
| 552 | elsif (@warning) { | 568 | elsif (@warning) { | 
| 553 | nagios_exit( WARNING, join(' ', @warning) ); | 569 | plugin_exit( WARNING, join(' ', @warning) ); | 
| 554 | } | 570 | } | 
| 555 | else { | 571 | else { | 
| 556 | nagios_exit( OK, join(' ', @ok) ); | 572 | plugin_exit( OK, join(' ', @ok) ); | 
| 557 | } | 573 | } | 
| 558 | 574 | ||
| 559 | =over 4 | 575 | =over 4 | 
| @@ -571,7 +587,7 @@ Only CRITICAL, WARNING, and OK are accepted as valid codes. | |||
| 571 | Check the current set of messages and return an appropriate nagios return | 587 | Check the current set of messages and return an appropriate nagios return | 
| 572 | code and/or a result message. In scalar context, returns only a return | 588 | code and/or a result message. In scalar context, returns only a return | 
| 573 | code; in list context returns both a return code and an output message, | 589 | code; in list context returns both a return code and an output message, | 
| 574 | suitable for passing directly to nagios_exit() e.g. | 590 | suitable for passing directly to plugin_exit() e.g. | 
| 575 | 591 | ||
| 576 | $code = $np->check_messages; | 592 | $code = $np->check_messages; | 
| 577 | ($code, $message) = $np->check_messages; | 593 | ($code, $message) = $np->check_messages; | 
| @@ -587,7 +603,7 @@ check_messages accepts the following named arguments (none are required): | |||
| 587 | 603 | ||
| 588 | =item join => SCALAR | 604 | =item join => SCALAR | 
| 589 | 605 | ||
| 590 | A string used to join the relevant array to generate the message | 606 | A string used to join the relevant array to generate the message | 
| 591 | string returned in list context i.e. if the 'critical' array @crit | 607 | string returned in list context i.e. if the 'critical' array @crit | 
| 592 | is non-empty, check_messages would return: | 608 | is non-empty, check_messages would return: | 
| 593 | 609 | ||
| @@ -599,9 +615,9 @@ as the result message. Default: ' ' (space). | |||
| 599 | 615 | ||
| 600 | By default, only one set of messages are joined and returned in the | 616 | By default, only one set of messages are joined and returned in the | 
| 601 | result message i.e. if the result is CRITICAL, only the 'critical' | 617 | result message i.e. if the result is CRITICAL, only the 'critical' | 
| 602 | messages are included in the result; if WARNING, only the 'warning' | 618 | messages are included in the result; if WARNING, only the 'warning' | 
| 603 | messages are included; if OK, the 'ok' messages are included (if | 619 | messages are included; if OK, the 'ok' messages are included (if | 
| 604 | supplied) i.e. the default is to return an 'errors-only' type | 620 | supplied) i.e. the default is to return an 'errors-only' type | 
| 605 | message. | 621 | message. | 
| 606 | 622 | ||
| 607 | If join_all is supplied, however, it will be used as a string to | 623 | If join_all is supplied, however, it will be used as a string to | 
| @@ -635,10 +651,10 @@ Add a set of performance data to the object. May be called multiple times. | |||
| 635 | The performance data is included in the standard plugin output messages by | 651 | The performance data is included in the standard plugin output messages by | 
| 636 | the various exit methods. | 652 | the various exit methods. | 
| 637 | 653 | ||
| 638 | See the Nagios::Plugin::Performance documentation for more information on | 654 | See the Monitoring::Plugin::Performance documentation for more information on | 
| 639 | performance data and the various field definitions, as well as the relevant | 655 | performance data and the various field definitions, as well as the relevant | 
| 640 | section of the Nagios Plugin guidelines | 656 | section of the Monitoring Plugin guidelines | 
| 641 | (http://nagiosplug.sourceforge.net/developer-guidelines.html#AEN202). | 657 | (https://www.monitoring-plugins.org/doc/guidelines.html#AEN202). | 
| 642 | 658 | ||
| 643 | =back | 659 | =back | 
| 644 | 660 | ||
| @@ -648,50 +664,49 @@ section of the Nagios Plugin guidelines | |||
| 648 | "Enough talk! Show me some examples!" | 664 | "Enough talk! Show me some examples!" | 
| 649 | 665 | ||
| 650 | See the file 'check_stuff.pl' in the 't' directory included with the | 666 | See the file 'check_stuff.pl' in the 't' directory included with the | 
| 651 | Nagios::Plugin distribution for a complete working example of a plugin | 667 | Monitoring::Plugin distribution for a complete working example of a plugin | 
| 652 | script. | 668 | script. | 
| 653 | 669 | ||
| 654 | 670 | ||
| 655 | =head1 VERSIONING | 671 | =head1 VERSIONING | 
| 656 | 672 | ||
| 657 | The Nagios::Plugin::* modules are currently experimental and so the | 673 | The Monitoring::Plugin::* modules are currently experimental and so the | 
| 658 | interfaces may change up until Nagios::Plugin hits version 1.0, although | 674 | interfaces may change up until Monitoring::Plugin hits version 1.0, although | 
| 659 | every attempt will be made to keep them as backwards compatible as | 675 | every attempt will be made to keep them as backwards compatible as | 
| 660 | possible. | 676 | possible. | 
| 661 | 677 | ||
| 662 | 678 | ||
| 663 | =head1 SEE ALSO | 679 | =head1 SEE ALSO | 
| 664 | 680 | ||
| 665 | See L<Nagios::Plugin::Functions> for a simple functional interface to a subset | 681 | See L<Monitoring::Plugin::Functions> for a simple functional interface to a subset | 
| 666 | of the available Nagios::Plugin functionality. | 682 | of the available Monitoring::Plugin functionality. | 
| 667 | 683 | ||
| 668 | See also L<Nagios::Plugin::Getopt>, L<Nagios::Plugin::Range>, | 684 | See also L<Monitoring::Plugin::Getopt>, L<Monitoring::Plugin::Range>, | 
| 669 | L<Nagios::Plugin::Performance>, L<Nagios::Plugin::Range>, and | 685 | L<Monitoring::Plugin::Performance>, L<Monitoring::Plugin::Range>, and | 
| 670 | L<Nagios::Plugin::Threshold>. | 686 | L<Monitoring::Plugin::Threshold>. | 
| 671 | 687 | ||
| 672 | The Nagios Plugin project page is at http://nagiosplug.sourceforge.net. | 688 | The Monitoring Plugin project page is at http://monitoring-plugins.org. | 
| 673 | 689 | ||
| 674 | 690 | ||
| 675 | =head1 BUGS | 691 | =head1 BUGS | 
| 676 | 692 | ||
| 677 | Please report bugs in these modules to the Nagios Plugin development team: | 693 | Please report bugs in these modules to the Monitoring Plugin development team: | 
| 678 | nagiosplug-devel@lists.sourceforge.net. | 694 | devel@monitoring-plugins.org. | 
| 679 | 695 | ||
| 680 | 696 | ||
| 681 | =head1 AUTHOR | 697 | =head1 AUTHOR | 
| 682 | 698 | ||
| 683 | Maintained by the Nagios Plugin development team - | 699 | Maintained by the Monitoring Plugin development team - | 
| 684 | http://nagiosplug.sourceforge.net. | 700 | https://www.monitoring-plugins.org. | 
| 685 | 701 | ||
| 686 | Originally by Ton Voon, E<lt>ton.voon@altinity.comE<gt>. | 702 | Originally by Ton Voon, E<lt>ton.voon@altinity.comE<gt>. | 
| 687 | 703 | ||
| 688 | =head1 COPYRIGHT AND LICENSE | 704 | =head1 COPYRIGHT AND LICENSE | 
| 689 | 705 | ||
| 690 | Copyright (C) 2006 by Nagios Plugin Development Team | 706 | Copyright (C) 2006-2014 by Monitoring Plugin Team | 
| 691 | 707 | ||
| 692 | This library is free software; you can redistribute it and/or modify it | 708 | This library is free software; you can redistribute it and/or modify it | 
| 693 | under the same terms as Perl itself, either Perl version 5.8.4 or, at your | 709 | under the same terms as Perl itself, either Perl version 5.8.4 or, at your | 
| 694 | option, any later version of Perl 5 you may have available. | 710 | option, any later version of Perl 5 you may have available. | 
| 695 | 711 | ||
| 696 | =cut | 712 | =cut | 
| 697 | |||
| diff --git a/lib/Nagios/Plugin/Config.pm b/lib/Monitoring/Plugin/Config.pm index dd270e9..5e941d4 100644 --- a/lib/Nagios/Plugin/Config.pm +++ b/lib/Monitoring/Plugin/Config.pm | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | package Nagios::Plugin::Config; | 1 | package Monitoring::Plugin::Config; | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Carp; | 4 | use Carp; | 
| @@ -7,10 +7,11 @@ use base qw(Config::Tiny); | |||
| 7 | 7 | ||
| 8 | my $FILENAME1 = 'plugins.ini'; | 8 | my $FILENAME1 = 'plugins.ini'; | 
| 9 | my $FILENAME2 = 'nagios-plugins.ini'; | 9 | my $FILENAME2 = 'nagios-plugins.ini'; | 
| 10 | my $FILENAME3 = 'monitoring-plugins.ini'; | ||
| 10 | my $CURRENT_FILE = undef; | 11 | my $CURRENT_FILE = undef; | 
| 11 | 12 | ||
| 12 | # Config paths ending in nagios (search for $FILENAME1) | 13 | # Config paths ending in nagios (search for $FILENAME1) | 
| 13 | my @NAGIOS_CONFIG_PATH = qw(/etc/nagios /usr/local/nagios/etc /usr/local/etc/nagios /etc/opt/nagios); | 14 | my @MONITORING_CONFIG_PATH = qw(/etc/nagios /usr/local/nagios/etc /usr/local/etc/nagios /etc/opt/nagios); | 
| 14 | # Config paths not ending in nagios (search for $FILENAME2) | 15 | # Config paths not ending in nagios (search for $FILENAME2) | 
| 15 | my @CONFIG_PATH = qw(/etc /usr/local/etc /etc/opt); | 16 | my @CONFIG_PATH = qw(/etc /usr/local/etc /etc/opt); | 
| 16 | 17 | ||
| @@ -21,26 +22,30 @@ sub read | |||
| 21 | 22 | ||
| 22 | unless ($_[0]) { | 23 | unless ($_[0]) { | 
| 23 | SEARCH: { | 24 | SEARCH: { | 
| 24 | if ($ENV{NAGIOS_CONFIG_PATH}) { | 25 | if ($ENV{MONITORING_CONFIG_PATH} || $ENV{NAGIOS_CONFIG_PATH}) { | 
| 25 | for (split /:/, $ENV{NAGIOS_CONFIG_PATH}) { | 26 | for (split /:/, ($ENV{MONITORING_CONFIG_PATH} || $ENV{NAGIOS_CONFIG_PATH})) { | 
| 26 | my $file = File::Spec->catfile($_, $FILENAME1); | 27 | my $file = File::Spec->catfile($_, $FILENAME1); | 
| 27 | unshift(@_, $file), last SEARCH if -f $file; | 28 | unshift(@_, $file), last SEARCH if -f $file; | 
| 28 | $file = File::Spec->catfile($_, $FILENAME2); | 29 | $file = File::Spec->catfile($_, $FILENAME2); | 
| 29 | unshift(@_, $file), last SEARCH if -f $file; | 30 | unshift(@_, $file), last SEARCH if -f $file; | 
| 31 | $file = File::Spec->catfile($_, $FILENAME3); | ||
| 32 | unshift(@_, $file), last SEARCH if -f $file; | ||
| 30 | } | 33 | } | 
| 31 | } | 34 | } | 
| 32 | for (@NAGIOS_CONFIG_PATH) { | 35 | for (@MONITORING_CONFIG_PATH) { | 
| 33 | my $file = File::Spec->catfile($_, $FILENAME1); | 36 | my $file = File::Spec->catfile($_, $FILENAME1); | 
| 34 | unshift(@_, $file), last SEARCH if -f $file; | 37 | unshift(@_, $file), last SEARCH if -f $file; | 
| 35 | } | 38 | } | 
| 36 | for (@CONFIG_PATH) { | 39 | for (@CONFIG_PATH) { | 
| 37 | my $file = File::Spec->catfile($_, $FILENAME2); | 40 | my $file = File::Spec->catfile($_, $FILENAME2); | 
| 38 | unshift(@_, $file), last SEARCH if -f $file; | 41 | unshift(@_, $file), last SEARCH if -f $file; | 
| 42 | $file = File::Spec->catfile($_, $FILENAME3); | ||
| 43 | unshift(@_, $file), last SEARCH if -f $file; | ||
| 39 | } | 44 | } | 
| 40 | } | 45 | } | 
| 41 | 46 | ||
| 42 | # Use die instead of croak, so we can pass a clean message downstream | 47 | # Use die instead of croak, so we can pass a clean message downstream | 
| 43 | die "Cannot find '$FILENAME1' or '$FILENAME2' in any standard location.\n" unless $_[0]; | 48 | die "Cannot find '$FILENAME1', '$FILENAME2' or '$FILENAME3' in any standard location.\n" unless $_[0]; | 
| 44 | } | 49 | } | 
| 45 | 50 | ||
| 46 | $CURRENT_FILE = $_[0]; | 51 | $CURRENT_FILE = $_[0]; | 
| @@ -94,15 +99,15 @@ sub np_getfile { return $CURRENT_FILE; } | |||
| 94 | 99 | ||
| 95 | =head1 NAME | 100 | =head1 NAME | 
| 96 | 101 | ||
| 97 | Nagios::Plugin::Config - read nagios plugin .ini style config files | 102 | Monitoring::Plugin::Config - read nagios plugin .ini style config files | 
| 98 | 103 | ||
| 99 | =head1 SYNOPSIS | 104 | =head1 SYNOPSIS | 
| 100 | 105 | ||
| 101 | # Read given nagios plugin config file | 106 | # Read given nagios plugin config file | 
| 102 | $Config = Nagios::Plugin::Config->read( '/etc/nagios/plugins.ini' ); | 107 | $Config = Monitoring::Plugin::Config->read( '/etc/nagios/plugins.ini' ); | 
| 103 | 108 | ||
| 104 | # Search for and read default nagios plugin config file | 109 | # Search for and read default nagios plugin config file | 
| 105 | $Config = Nagios::Plugin::Config->read(); | 110 | $Config = Monitoring::Plugin::Config->read(); | 
| 106 | 111 | ||
| 107 | # Access sections and properties (returns scalars or arrayrefs) | 112 | # Access sections and properties (returns scalars or arrayrefs) | 
| 108 | $rootproperty = $Config->{_}->{rootproperty}; | 113 | $rootproperty = $Config->{_}->{rootproperty}; | 
| @@ -111,22 +116,22 @@ Nagios::Plugin::Config - read nagios plugin .ini style config files | |||
| 111 | 116 | ||
| 112 | =head1 DESCRIPTION | 117 | =head1 DESCRIPTION | 
| 113 | 118 | ||
| 114 | Nagios::Plugin::Config is a subclass of the excellent Config::Tiny, | 119 | Monitoring::Plugin::Config is a subclass of the excellent Config::Tiny, | 
| 115 | with the following changes: | 120 | with the following changes: | 
| 116 | 121 | ||
| 117 | =over 4 | 122 | =over 4 | 
| 118 | 123 | ||
| 119 | =item | 124 | =item | 
| 120 | 125 | ||
| 121 | Repeated keys are allowed within sections, returning lists instead of scalars | 126 | Repeated keys are allowed within sections, returning lists instead of scalars | 
| 122 | 127 | ||
| 123 | =item | 128 | =item | 
| 124 | 129 | ||
| 125 | Write functionality has been removed i.e. access is read only | 130 | Write functionality has been removed i.e. access is read only | 
| 126 | 131 | ||
| 127 | =item | 132 | =item | 
| 128 | 133 | ||
| 129 | Nagios::Plugin::Config searches for a default nagios plugins file if no explicit | 134 | Monitoring::Plugin::Config searches for a default nagios plugins file if no explicit | 
| 130 | filename is given to C<read()>. The current standard locations checked are: | 135 | filename is given to C<read()>. The current standard locations checked are: | 
| 131 | 136 | ||
| 132 | =over 4 | 137 | =over 4 | 
| @@ -137,15 +142,15 @@ filename is given to C<read()>. The current standard locations checked are: | |||
| 137 | 142 | ||
| 138 | =item /usr/local/etc/nagios /etc/opt/nagios/plugins.ini | 143 | =item /usr/local/etc/nagios /etc/opt/nagios/plugins.ini | 
| 139 | 144 | ||
| 140 | =item /etc/nagios-plugins.ini | 145 | =item /etc/nagios-plugins.ini | 
| 141 | 146 | ||
| 142 | =item /usr/local/etc/nagios-plugins.ini | 147 | =item /usr/local/etc/nagios-plugins.ini | 
| 143 | 148 | ||
| 144 | =item /etc/opt/nagios-plugins.ini | 149 | =item /etc/opt/nagios-plugins.ini | 
| 145 | 150 | ||
| 146 | =back | 151 | =back | 
| 147 | 152 | ||
| 148 | To use a custom location, set a C<NAGIOS_CONFIG_PATH> environment variable | 153 | To use a custom location, set a C<NAGIOS_CONFIG_PATH> environment variable | 
| 149 | to the set of directories that should be checked. The first C<plugins.ini> or | 154 | to the set of directories that should be checked. The first C<plugins.ini> or | 
| 150 | C<nagios-plugins.ini> file found will be used. | 155 | C<nagios-plugins.ini> file found will be used. | 
| 151 | 156 | ||
| @@ -154,21 +159,19 @@ C<nagios-plugins.ini> file found will be used. | |||
| 154 | 159 | ||
| 155 | =head1 SEE ALSO | 160 | =head1 SEE ALSO | 
| 156 | 161 | ||
| 157 | L<Config::Tiny>, L<Nagios::Plugin> | 162 | L<Config::Tiny>, L<Monitoring::Plugin> | 
| 158 | 163 | ||
| 159 | 164 | ||
| 160 | =head1 AUTHORS | 165 | =head1 AUTHOR | 
| 161 | 166 | ||
| 162 | This code is maintained by the Nagios Plugin Development Team: | 167 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 163 | L<http://nagiosplug.sourceforge.net>. | 168 | https://monitoring-plugins.org | 
| 164 | 169 | ||
| 170 | =head1 COPYRIGHT AND LICENSE | ||
| 165 | 171 | ||
| 166 | =head1 COPYRIGHT and LICENCE | 172 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 167 | |||
| 168 | Copyright (C) 2006-2007 by Nagios Plugin Development Team | ||
| 169 | 173 | ||
| 170 | This library is free software; you can redistribute it and/or modify | 174 | This library is free software; you can redistribute it and/or modify | 
| 171 | it under the same terms as Perl itself. | 175 | it under the same terms as Perl itself. | 
| 172 | 176 | ||
| 173 | =cut | 177 | =cut | 
| 174 | |||
| diff --git a/lib/Monitoring/Plugin/ExitResult.pm b/lib/Monitoring/Plugin/ExitResult.pm new file mode 100644 index 0000000..aa9f5da --- /dev/null +++ b/lib/Monitoring/Plugin/ExitResult.pm | |||
| @@ -0,0 +1,71 @@ | |||
| 1 | # Tiny helper class to return both output and return_code when testing | ||
| 2 | |||
| 3 | package Monitoring::Plugin::ExitResult; | ||
| 4 | |||
| 5 | use strict; | ||
| 6 | |||
| 7 | # Stringify to message | ||
| 8 | use overload '""' => sub { shift->{message} }; | ||
| 9 | |||
| 10 | # Constructor | ||
| 11 | sub new { | ||
| 12 | my $class = shift; | ||
| 13 | return bless { return_code => $_[0], message => $_[1] }, $class; | ||
| 14 | } | ||
| 15 | |||
| 16 | # Accessors | ||
| 17 | sub message { shift->{message} } | ||
| 18 | sub return_code { shift->{return_code} } | ||
| 19 | sub code { shift->{return_code} } | ||
| 20 | |||
| 21 | 1; | ||
| 22 | |||
| 23 | __END__ | ||
| 24 | |||
| 25 | =head1 NAME | ||
| 26 | |||
| 27 | Monitoring::Plugin::ExitResult - Helper class for returning both output and | ||
| 28 | return codes when testing. | ||
| 29 | |||
| 30 | =head1 SYNOPSIS | ||
| 31 | |||
| 32 | use Test::More; | ||
| 33 | use Monitoring::Plugin::Functions; | ||
| 34 | |||
| 35 | # In a test file somewhere | ||
| 36 | Monitoring::Plugin::Functions::_fake_exit(1); | ||
| 37 | |||
| 38 | # Later ... | ||
| 39 | $e = plugin_exit( CRITICAL, 'aiiii ...' ); | ||
| 40 | print $e->message; | ||
| 41 | print $e->return_code; | ||
| 42 | |||
| 43 | # MP::ExitResult also stringifies to the message output | ||
| 44 | like(plugin_exit( WARNING, 'foobar'), qr/^foo/, 'matches!'); | ||
| 45 | |||
| 46 | |||
| 47 | |||
| 48 | =head1 DESCRIPTION | ||
| 49 | |||
| 50 | Monitoring::Plugin::ExitResult is a tiny helper class intended for use | ||
| 51 | when testing other Monitoring::Plugin modules. A Monitoring::Plugin::ExitResult | ||
| 52 | object is returned by plugin_exit() and friends when | ||
| 53 | Monitoring::Plugin::Functions::_fake_exit has been set, instead of doing a | ||
| 54 | conventional print + exit. | ||
| 55 | |||
| 56 | =head1 AUTHOR | ||
| 57 | |||
| 58 | This code is maintained by the Monitoring Plugin Development Team: see | ||
| 59 | https://monitoring-plugins.org | ||
| 60 | |||
| 61 | Originally: | ||
| 62 | Gavin Carr , E<lt>gavin@openfusion.com.auE<gt> | ||
| 63 | |||
| 64 | =head1 COPYRIGHT AND LICENSE | ||
| 65 | |||
| 66 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | ||
| 67 | |||
| 68 | This library is free software; you can redistribute it and/or modify | ||
| 69 | it under the same terms as Perl itself. | ||
| 70 | |||
| 71 | =cut | ||
| diff --git a/lib/Nagios/Plugin/Functions.pm b/lib/Monitoring/Plugin/Functions.pm index 14fe661..d2856e8 100644 --- a/lib/Nagios/Plugin/Functions.pm +++ b/lib/Monitoring/Plugin/Functions.pm | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # Functional interface to basic Nagios::Plugin constants, exports, | 1 | # Functional interface to basic Monitoring::Plugin constants, exports, | 
| 2 | # and functions | 2 | # and functions | 
| 3 | 3 | ||
| 4 | package Nagios::Plugin::Functions; | 4 | package Monitoring::Plugin::Functions; | 
| 5 | 5 | ||
| 6 | use 5.006; | 6 | use 5.006; | 
| 7 | 7 | ||
| @@ -11,19 +11,19 @@ use File::Basename; | |||
| 11 | use Params::Validate qw(:types validate); | 11 | use Params::Validate qw(:types validate); | 
| 12 | use Math::Calc::Units; | 12 | use Math::Calc::Units; | 
| 13 | 13 | ||
| 14 | # Remember to update Nagios::Plugins as well | 14 | # Remember to update Monitoring::Plugins as well | 
| 15 | our $VERSION = "0.36"; | 15 | our $VERSION = "0.37"; | 
| 16 | 16 | ||
| 17 | our @STATUS_CODES = qw(OK WARNING CRITICAL UNKNOWN DEPENDENT); | 17 | our @STATUS_CODES = qw(OK WARNING CRITICAL UNKNOWN DEPENDENT); | 
| 18 | 18 | ||
| 19 | require Exporter; | 19 | require Exporter; | 
| 20 | our @ISA = qw(Exporter); | 20 | our @ISA = qw(Exporter); | 
| 21 | our @EXPORT = (@STATUS_CODES, qw(nagios_exit nagios_die check_messages)); | 21 | our @EXPORT = (@STATUS_CODES, qw(plugin_exit plugin_die check_messages)); | 
| 22 | our @EXPORT_OK = qw(%ERRORS %STATUS_TEXT @STATUS_CODES get_shortname max_state max_state_alt convert $value_re); | 22 | our @EXPORT_OK = qw(%ERRORS %STATUS_TEXT @STATUS_CODES get_shortname max_state max_state_alt convert $value_re); | 
| 23 | our %EXPORT_TAGS = ( | 23 | our %EXPORT_TAGS = ( | 
| 24 | all => [ @EXPORT, @EXPORT_OK ], | 24 | all => [ @EXPORT, @EXPORT_OK ], | 
| 25 | codes => [ @STATUS_CODES ], | 25 | codes => [ @STATUS_CODES ], | 
| 26 | functions => [ qw(nagios_exit nagios_die check_messages max_state max_state_alt convert) ], | 26 | functions => [ qw(plugin_exit plugin_die check_messages max_state max_state_alt convert) ], | 
| 27 | ); | 27 | ); | 
| 28 | 28 | ||
| 29 | use constant OK => 0; | 29 | use constant OK => 0; | 
| @@ -61,7 +61,7 @@ sub get_shortname { | |||
| 61 | return $arg->{shortname} if (defined($arg->{shortname})); | 61 | return $arg->{shortname} if (defined($arg->{shortname})); | 
| 62 | $shortname = $arg->{plugin} if (defined( $arg->{plugin})); | 62 | $shortname = $arg->{plugin} if (defined( $arg->{plugin})); | 
| 63 | 63 | ||
| 64 | $shortname = uc basename($shortname || $ENV{NAGIOS_PLUGIN} || $0); | 64 | $shortname = uc basename($shortname || $ENV{PLUGIN_NAME} || $ENV{NAGIOS_PLUGIN} || $0); | 
| 65 | $shortname =~ s/^CHECK_(?:BY_)?//; # Remove any leading CHECK_[BY_] | 65 | $shortname =~ s/^CHECK_(?:BY_)?//; # Remove any leading CHECK_[BY_] | 
| 66 | $shortname =~ s/\..*$//; # Remove any trailing suffix | 66 | $shortname =~ s/\..*$//; # Remove any trailing suffix | 
| 67 | return $shortname; | 67 | return $shortname; | 
| @@ -85,8 +85,8 @@ sub max_state_alt { | |||
| 85 | return UNKNOWN; | 85 | return UNKNOWN; | 
| 86 | } | 86 | } | 
| 87 | 87 | ||
| 88 | # nagios_exit( $code, $message ) | 88 | # plugin_exit( $code, $message ) | 
| 89 | sub nagios_exit { | 89 | sub plugin_exit { | 
| 90 | my ($code, $message, $arg) = @_; | 90 | my ($code, $message, $arg) = @_; | 
| 91 | 91 | ||
| 92 | # Handle named parameters | 92 | # Handle named parameters | 
| @@ -124,21 +124,21 @@ sub nagios_exit { | |||
| 124 | $output = "$shortname $output" if $shortname; | 124 | $output = "$shortname $output" if $shortname; | 
| 125 | if ($arg->{plugin}) { | 125 | if ($arg->{plugin}) { | 
| 126 | my $plugin = $arg->{plugin}; | 126 | my $plugin = $arg->{plugin}; | 
| 127 | $output .= " | ". $plugin->all_perfoutput | 127 | $output .= " | ". $plugin->all_perfoutput | 
| 128 | if $plugin->perfdata && $plugin->all_perfoutput; | 128 | if $plugin->perfdata && $plugin->all_perfoutput; | 
| 129 | } | 129 | } | 
| 130 | $output .= "\n"; | 130 | $output .= "\n"; | 
| 131 | 131 | ||
| 132 | # Don't actually exit if _fake_exit set | 132 | # Don't actually exit if _fake_exit set | 
| 133 | if ($_fake_exit) { | 133 | if ($_fake_exit) { | 
| 134 | require Nagios::Plugin::ExitResult; | 134 | require Monitoring::Plugin::ExitResult; | 
| 135 | return Nagios::Plugin::ExitResult->new($code, $output); | 135 | return Monitoring::Plugin::ExitResult->new($code, $output); | 
| 136 | } | 136 | } | 
| 137 | 137 | ||
| 138 | _nagios_exit($code, $output); | 138 | _plugin_exit($code, $output); | 
| 139 | } | 139 | } | 
| 140 | 140 | ||
| 141 | sub _nagios_exit { | 141 | sub _plugin_exit { | 
| 142 | my ($code, $output) = @_; | 142 | my ($code, $output) = @_; | 
| 143 | # Print output and exit; die if flag set and called via a die in stack backtrace | 143 | # Print output and exit; die if flag set and called via a die in stack backtrace | 
| 144 | if ($_use_die) { | 144 | if ($_use_die) { | 
| @@ -155,34 +155,34 @@ sub _nagios_exit { | |||
| 155 | exit $code; | 155 | exit $code; | 
| 156 | } | 156 | } | 
| 157 | 157 | ||
| 158 | # nagios_die( $message, [ $code ]) OR nagios_die( $code, $message ) | 158 | # plugin_die( $message, [ $code ]) OR plugin_die( $code, $message ) | 
| 159 | # Default $code: UNKNOWN | 159 | # Default $code: UNKNOWN | 
| 160 | sub nagios_die { | 160 | sub plugin_die { | 
| 161 | my ($arg1, $arg2, $rest) = @_; | 161 | my ($arg1, $arg2, $rest) = @_; | 
| 162 | 162 | ||
| 163 | # Named parameters | 163 | # Named parameters | 
| 164 | if (defined $arg1 && ($arg1 eq 'return_code' || $arg1 eq 'message')) { | 164 | if (defined $arg1 && ($arg1 eq 'return_code' || $arg1 eq 'message')) { | 
| 165 | return nagios_exit(@_); | 165 | return plugin_exit(@_); | 
| 166 | } | 166 | } | 
| 167 | 167 | ||
| 168 | # ($code, $message) | 168 | # ($code, $message) | 
| 169 | elsif (defined $arg1 && (exists $ERRORS{$arg1} || exists $STATUS_TEXT{$arg1})) { | 169 | elsif (defined $arg1 && (exists $ERRORS{$arg1} || exists $STATUS_TEXT{$arg1})) { | 
| 170 | return nagios_exit(@_); | 170 | return plugin_exit(@_); | 
| 171 | } | 171 | } | 
| 172 | 172 | ||
| 173 | # ($message, $code) | 173 | # ($message, $code) | 
| 174 | elsif (defined $arg2 && (exists $ERRORS{$arg2} || exists $STATUS_TEXT{$arg2})) { | 174 | elsif (defined $arg2 && (exists $ERRORS{$arg2} || exists $STATUS_TEXT{$arg2})) { | 
| 175 | return nagios_exit($arg2, $arg1, $rest); | 175 | return plugin_exit($arg2, $arg1, $rest); | 
| 176 | } | 176 | } | 
| 177 | 177 | ||
| 178 | # Else just assume $arg1 is the message and hope for the best | 178 | # Else just assume $arg1 is the message and hope for the best | 
| 179 | else { | 179 | else { | 
| 180 | return nagios_exit( UNKNOWN, $arg1, $arg2 ); | 180 | return plugin_exit( UNKNOWN, $arg1, $arg2 ); | 
| 181 | } | 181 | } | 
| 182 | } | 182 | } | 
| 183 | 183 | ||
| 184 | # For backwards compatibility | 184 | # For backwards compatibility | 
| 185 | sub die { nagios_die(@_); } | 185 | sub die { plugin_die(@_); } | 
| 186 | 186 | ||
| 187 | 187 | ||
| 188 | # ------------------------------------------------------------------------ | 188 | # ------------------------------------------------------------------------ | 
| @@ -197,9 +197,9 @@ sub convert | |||
| 197 | } | 197 | } | 
| 198 | 198 | ||
| 199 | # ------------------------------------------------------------------------ | 199 | # ------------------------------------------------------------------------ | 
| 200 | # check_messages - return a status and/or message based on a set of | 200 | # check_messages - return a status and/or message based on a set of | 
| 201 | # message arrays. | 201 | # message arrays. | 
| 202 | # Returns a nagios status code in scalar context. | 202 | # Returns a nagios status code in scalar context. | 
| 203 | # Returns a code and a message in list context. | 203 | # Returns a code and a message in list context. | 
| 204 | # The message is join($join, @array) for the relevant array for the code, | 204 | # The message is join($join, @array) for the relevant array for the code, | 
| 205 | # or join($join_all, $message) for all arrays if $join_all is set. | 205 | # or join($join_all, $message) for all arrays if $join_all is set. | 
| @@ -222,18 +222,18 @@ sub check_messages { | |||
| 222 | # Compose message | 222 | # Compose message | 
| 223 | my $message = ''; | 223 | my $message = ''; | 
| 224 | if ($arg{join_all}) { | 224 | if ($arg{join_all}) { | 
| 225 | $message = join( $arg{join_all}, | 225 | $message = join( $arg{join_all}, | 
| 226 | map { @$_ ? join( $arg{'join'}, @$_) : () } | 226 | map { @$_ ? join( $arg{'join'}, @$_) : () } | 
| 227 | $arg{critical}, | 227 | $arg{critical}, | 
| 228 | $arg{warning}, | 228 | $arg{warning}, | 
| 229 | $arg{ok} ? (ref $arg{ok} ? $arg{ok} : [ $arg{ok} ]) : [] | 229 | $arg{ok} ? (ref $arg{ok} ? $arg{ok} : [ $arg{ok} ]) : [] | 
| 230 | ); | 230 | ); | 
| 231 | } | 231 | } | 
| 232 | 232 | ||
| 233 | else { | 233 | else { | 
| 234 | $message ||= join( $arg{'join'}, @{$arg{critical}} ) | 234 | $message ||= join( $arg{'join'}, @{$arg{critical}} ) | 
| 235 | if $code == CRITICAL; | 235 | if $code == CRITICAL; | 
| 236 | $message ||= join( $arg{'join'}, @{$arg{warning}} ) | 236 | $message ||= join( $arg{'join'}, @{$arg{warning}} ) | 
| 237 | if $code == WARNING; | 237 | if $code == WARNING; | 
| 238 | $message ||= ref $arg{ok} ? join( $arg{'join'}, @{$arg{ok}} ) : $arg{ok} | 238 | $message ||= ref $arg{ok} ? join( $arg{'join'}, @{$arg{ok}} ) : $arg{ok} | 
| 239 | if $arg{ok}; | 239 | if $arg{ok}; | 
| @@ -252,28 +252,28 @@ __END__ | |||
| 252 | 252 | ||
| 253 | =head1 NAME | 253 | =head1 NAME | 
| 254 | 254 | ||
| 255 | Nagios::Plugin::Functions - functions to simplify the creation of | 255 | Monitoring::Plugin::Functions - functions to simplify the creation of | 
| 256 | Nagios plugins | 256 | Nagios plugins | 
| 257 | 257 | ||
| 258 | =head1 SYNOPSIS | 258 | =head1 SYNOPSIS | 
| 259 | 259 | ||
| 260 | # Constants OK, WARNING, CRITICAL, and UNKNOWN exported by default | 260 | # Constants OK, WARNING, CRITICAL, and UNKNOWN exported by default | 
| 261 | use Nagios::Plugin::Functions; | 261 | use Monitoring::Plugin::Functions; | 
| 262 | 262 | ||
| 263 | # nagios_exit( CODE, $message ) - exit with error code CODE, | 263 | # plugin_exit( CODE, $message ) - exit with error code CODE, | 
| 264 | # and message "PLUGIN CODE - $message" | 264 | # and message "PLUGIN CODE - $message" | 
| 265 | nagios_exit( CRITICAL, $critical_error ) if $critical_error; | 265 | plugin_exit( CRITICAL, $critical_error ) if $critical_error; | 
| 266 | nagios_exit( WARNING, $warning_error ) if $warning_error; | 266 | plugin_exit( WARNING, $warning_error ) if $warning_error; | 
| 267 | nagios_exit( OK, $result ); | 267 | plugin_exit( OK, $result ); | 
| 268 | 268 | ||
| 269 | # nagios_die( $message, [$CODE] ) - just like nagios_exit(), | 269 | # plugin_die( $message, [$CODE] ) - just like plugin_exit(), | 
| 270 | # but CODE is optional, defaulting to UNKNOWN | 270 | # but CODE is optional, defaulting to UNKNOWN | 
| 271 | do_something() | 271 | do_something() | 
| 272 | or nagios_die("do_something() failed horribly"); | 272 | or plugin_die("do_something() failed horribly"); | 
| 273 | do_something_critical() | 273 | do_something_critical() | 
| 274 | or nagios_die("do_something_critical() failed", CRITICAL); | 274 | or plugin_die("do_something_critical() failed", CRITICAL); | 
| 275 | 275 | ||
| 276 | # check_messages - check a set of message arrays, returning a | 276 | # check_messages - check a set of message arrays, returning a | 
| 277 | # CODE and/or a result message | 277 | # CODE and/or a result message | 
| 278 | $code = check_messages(critical => \@crit, warning => \@warn); | 278 | $code = check_messages(critical => \@crit, warning => \@warn); | 
| 279 | ($code, $message) = check_messages( | 279 | ($code, $message) = check_messages( | 
| @@ -281,18 +281,18 @@ Nagios plugins | |||
| 281 | ok => \@ok ); | 281 | ok => \@ok ); | 
| 282 | 282 | ||
| 283 | # get_shortname - return the default short name for this plugin | 283 | # get_shortname - return the default short name for this plugin | 
| 284 | # (as used by nagios_exit/die; not exported by default) | 284 | # (as used by plugin_exit/die; not exported by default) | 
| 285 | $shortname = get_shortname(); | 285 | $shortname = get_shortname(); | 
| 286 | 286 | ||
| 287 | 287 | ||
| 288 | =head1 DESCRIPTION | 288 | =head1 DESCRIPTION | 
| 289 | 289 | ||
| 290 | This module is part of the Nagios::Plugin family, a set of modules | 290 | This module is part of the Monitoring::Plugin family, a set of modules | 
| 291 | for simplifying the creation of Nagios plugins. This module exports | 291 | for simplifying the creation of Nagios plugins. This module exports | 
| 292 | convenience functions for the class methods provided by | 292 | convenience functions for the class methods provided by | 
| 293 | Nagios::Plugin. It is intended for those who prefer a simpler | 293 | Monitoring::Plugin. It is intended for those who prefer a simpler | 
| 294 | functional interface, and who do not need the additional | 294 | functional interface, and who do not need the additional | 
| 295 | functionality of Nagios::Plugin. | 295 | functionality of Monitoring::Plugin. | 
| 296 | 296 | ||
| 297 | =head2 EXPORTS | 297 | =head2 EXPORTS | 
| 298 | 298 | ||
| @@ -306,8 +306,8 @@ Nagios status code constants are exported by default: | |||
| 306 | 306 | ||
| 307 | as are the following functions: | 307 | as are the following functions: | 
| 308 | 308 | ||
| 309 | nagios_exit | 309 | plugin_exit | 
| 310 | nagios_die | 310 | plugin_die | 
| 311 | check_messages | 311 | check_messages | 
| 312 | 312 | ||
| 313 | The following variables and functions are exported only on request: | 313 | The following variables and functions are exported only on request: | 
| @@ -325,14 +325,14 @@ The following functions are supported: | |||
| 325 | 325 | ||
| 326 | =over 4 | 326 | =over 4 | 
| 327 | 327 | ||
| 328 | =item nagios_exit( <CODE>, $message ) | 328 | =item plugin_exit( <CODE>, $message ) | 
| 329 | 329 | ||
| 330 | Exit with return code CODE, and a standard nagios message of the | 330 | Exit with return code CODE, and a standard nagios message of the | 
| 331 | form "PLUGIN CODE - $message". | 331 | form "PLUGIN CODE - $message". | 
| 332 | 332 | ||
| 333 | =item nagios_die( $message, [CODE] ) | 333 | =item plugin_die( $message, [CODE] ) | 
| 334 | 334 | ||
| 335 | Same as nagios_exit(), except that CODE is optional, defaulting | 335 | Same as plugin_exit(), except that CODE is optional, defaulting | 
| 336 | to UNKNOWN. NOTE: exceptions are not raised by default to calling code. | 336 | to UNKNOWN. NOTE: exceptions are not raised by default to calling code. | 
| 337 | Set C<$_use_die> flag if this functionality is required (see test code). | 337 | Set C<$_use_die> flag if this functionality is required (see test code). | 
| 338 | 338 | ||
| @@ -354,7 +354,7 @@ check_messages() accepts the following named arguments: | |||
| 354 | 354 | ||
| 355 | =item critical => ARRAYREF | 355 | =item critical => ARRAYREF | 
| 356 | 356 | ||
| 357 | An arrayref of critical error messages - check_messages() returns | 357 | An arrayref of critical error messages - check_messages() returns | 
| 358 | CRITICAL if this arrayref is non-empty. Mandatory. | 358 | CRITICAL if this arrayref is non-empty. Mandatory. | 
| 359 | 359 | ||
| 360 | =item warning => ARRAYREF | 360 | =item warning => ARRAYREF | 
| @@ -371,7 +371,7 @@ are empty. Optional. | |||
| 371 | 371 | ||
| 372 | =item join => SCALAR | 372 | =item join => SCALAR | 
| 373 | 373 | ||
| 374 | A string used to join the relevant array to generate the message | 374 | A string used to join the relevant array to generate the message | 
| 375 | string returned in list context i.e. if the 'critical' array @crit | 375 | string returned in list context i.e. if the 'critical' array @crit | 
| 376 | is non-empty, check_messages would return: | 376 | is non-empty, check_messages would return: | 
| 377 | 377 | ||
| @@ -383,9 +383,9 @@ as the result message. Optional; default: ' ' (space). | |||
| 383 | 383 | ||
| 384 | By default, only one set of messages are joined and returned in the | 384 | By default, only one set of messages are joined and returned in the | 
| 385 | result message i.e. if the result is CRITICAL, only the 'critical' | 385 | result message i.e. if the result is CRITICAL, only the 'critical' | 
| 386 | messages are included in the result; if WARNING, only the 'warning' | 386 | messages are included in the result; if WARNING, only the 'warning' | 
| 387 | messages are included; if OK, the 'ok' messages are included (if | 387 | messages are included; if OK, the 'ok' messages are included (if | 
| 388 | supplied) i.e. the default is to return an 'errors-only' type | 388 | supplied) i.e. the default is to return an 'errors-only' type | 
| 389 | message. | 389 | message. | 
| 390 | 390 | ||
| 391 | If join_all is supplied, however, it will be used as a string to | 391 | If join_all is supplied, however, it will be used as a string to | 
| @@ -397,9 +397,9 @@ all messages are joined and returned. | |||
| 397 | =item get_shortname | 397 | =item get_shortname | 
| 398 | 398 | ||
| 399 | Return the default shortname used for this plugin i.e. the first | 399 | Return the default shortname used for this plugin i.e. the first | 
| 400 | token reported by nagios_exit/nagios_die. The default is basically | 400 | token reported by plugin_exit/plugin_die. The default is basically | 
| 401 | 401 | ||
| 402 | uc basename( $ENV{NAGIOS_PLUGIN} || $0 ) | 402 | uc basename( $ENV{PLUGIN_NAME} || $ENV{NAGIOS_PLUGIN} || $0 ) | 
| 403 | 403 | ||
| 404 | with any leading 'CHECK_' and trailing file suffixes removed. | 404 | with any leading 'CHECK_' and trailing file suffixes removed. | 
| 405 | 405 | ||
| @@ -427,18 +427,17 @@ internal tests performed can return UNKNOWN. | |||
| 427 | 427 | ||
| 428 | =head1 SEE ALSO | 428 | =head1 SEE ALSO | 
| 429 | 429 | ||
| 430 | Nagios::Plugin; the nagios plugin developer guidelines at | 430 | Monitoring::Plugin; the nagios plugin developer guidelines at | 
| 431 | http://nagiosplug.sourceforge.net/developer-guidelines.html. | 431 | https://www.monitoring-plugins.org/doc/guidelines.html. | 
| 432 | 432 | ||
| 433 | =head1 AUTHOR | ||
| 433 | 434 | ||
| 434 | =head1 AUTHORS | 435 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 435 | 436 | https://monitoring-plugins.org | |
| 436 | This code is maintained by the Nagios Plugin Development Team: http://nagiosplug.sourceforge.net | ||
| 437 | |||
| 438 | 437 | ||
| 439 | =head1 COPYRIGHT AND LICENSE | 438 | =head1 COPYRIGHT AND LICENSE | 
| 440 | 439 | ||
| 441 | Copyright (C) 2006 by Nagios Plugin Development Team | 440 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 442 | 441 | ||
| 443 | This library is free software; you can redistribute it and/or modify | 442 | This library is free software; you can redistribute it and/or modify | 
| 444 | it under the same terms as Perl itself. | 443 | it under the same terms as Perl itself. | 
| diff --git a/lib/Nagios/Plugin/Getopt.pm b/lib/Monitoring/Plugin/Getopt.pm index 22ff642..ce1c0f9 100644 --- a/lib/Nagios/Plugin/Getopt.pm +++ b/lib/Monitoring/Plugin/Getopt.pm | |||
| @@ -1,9 +1,9 @@ | |||
| 1 | # | 1 | # | 
| 2 | # Nagios::Plugin::Getopt - OO perl module providing standardised argument | 2 | # Monitoring::Plugin::Getopt - OO perl module providing standardised argument | 
| 3 | # processing for nagios plugins | 3 | # processing for nagios plugins | 
| 4 | # | 4 | # | 
| 5 | 5 | ||
| 6 | package Nagios::Plugin::Getopt; | 6 | package Monitoring::Plugin::Getopt; | 
| 7 | 7 | ||
| 8 | use strict; | 8 | use strict; | 
| 9 | use File::Basename; | 9 | use File::Basename; | 
| @@ -12,18 +12,18 @@ use Carp; | |||
| 12 | use Params::Validate qw(:all); | 12 | use Params::Validate qw(:all); | 
| 13 | use base qw(Class::Accessor); | 13 | use base qw(Class::Accessor); | 
| 14 | 14 | ||
| 15 | use Nagios::Plugin::Functions; | 15 | use Monitoring::Plugin::Functions; | 
| 16 | use Nagios::Plugin::Config; | 16 | use Monitoring::Plugin::Config; | 
| 17 | use vars qw($VERSION); | 17 | use vars qw($VERSION); | 
| 18 | $VERSION = $Nagios::Plugin::Functions::VERSION; | 18 | $VERSION = $Monitoring::Plugin::Functions::VERSION; | 
| 19 | 19 | ||
| 20 | # Standard defaults | 20 | # Standard defaults | 
| 21 | my %DEFAULT = ( | 21 | my %DEFAULT = ( | 
| 22 | timeout => 15, | 22 | timeout => 15, | 
| 23 | verbose => 0, | 23 | verbose => 0, | 
| 24 | license => | 24 | license => | 
| 25 | "This nagios plugin is free software, and comes with ABSOLUTELY NO WARRANTY. | 25 | "This nagios plugin is free software, and comes with ABSOLUTELY NO WARRANTY. | 
| 26 | It may be used, redistributed and/or modified under the terms of the GNU | 26 | It may be used, redistributed and/or modified under the terms of the GNU | 
| 27 | General Public Licence (see http://www.fsf.org/licensing/licenses/gpl.txt).", | 27 | General Public Licence (see http://www.fsf.org/licensing/licenses/gpl.txt).", | 
| 28 | ); | 28 | ); | 
| 29 | # Standard arguments | 29 | # Standard arguments | 
| @@ -60,7 +60,7 @@ sub _die | |||
| 60 | my $self = shift; | 60 | my $self = shift; | 
| 61 | my ($msg) = @_; | 61 | my ($msg) = @_; | 
| 62 | $msg .= "\n" unless substr($msg, -1) eq "\n"; | 62 | $msg .= "\n" unless substr($msg, -1) eq "\n"; | 
| 63 | Nagios::Plugin::Functions::_nagios_exit(3, $msg); | 63 | Monitoring::Plugin::Functions::_plugin_exit(3, $msg); | 
| 64 | } | 64 | } | 
| 65 | 65 | ||
| 66 | # Return the given attribute, if set, including a final newline | 66 | # Return the given attribute, if set, including a final newline | 
| @@ -182,7 +182,7 @@ sub _help | |||
| 182 | } | 182 | } | 
| 183 | 183 | ||
| 184 | # Return a Getopt::Long-compatible option array from the current set of specs | 184 | # Return a Getopt::Long-compatible option array from the current set of specs | 
| 185 | sub _process_specs_getopt_long | 185 | sub _process_specs_getopt_long | 
| 186 | { | 186 | { | 
| 187 | my $self = shift; | 187 | my $self = shift; | 
| 188 | 188 | ||
| @@ -217,7 +217,7 @@ sub _check_required_opts | |||
| 217 | } | 217 | } | 
| 218 | } | 218 | } | 
| 219 | if (@missing) { | 219 | if (@missing) { | 
| 220 | $self->_die($self->_usage . "\n" . | 220 | $self->_die($self->_usage . "\n" . | 
| 221 | join("\n", map { sprintf "Missing argument: %s", $_ } @missing) . "\n"); | 221 | join("\n", map { sprintf "Missing argument: %s", $_ } @missing) . "\n"); | 
| 222 | } | 222 | } | 
| 223 | } | 223 | } | 
| @@ -243,7 +243,7 @@ sub _load_config_section | |||
| 243 | $section ||= $self->{_attr}->{plugin}; | 243 | $section ||= $self->{_attr}->{plugin}; | 
| 244 | 244 | ||
| 245 | my $Config; | 245 | my $Config; | 
| 246 | eval { $Config = Nagios::Plugin::Config->read($file); }; | 246 | eval { $Config = Monitoring::Plugin::Config->read($file); }; | 
| 247 | $self->_die($@) if ($@); #TODO: add test? | 247 | $self->_die($@) if ($@); #TODO: add test? | 
| 248 | 248 | ||
| 249 | # TODO: is this check sane? Does --extra-opts=foo require a [foo] section? | 249 | # TODO: is this check sane? Does --extra-opts=foo require a [foo] section? | 
| @@ -295,7 +295,7 @@ sub _cmdline | |||
| 295 | next if $key =~ m/^_/; | 295 | next if $key =~ m/^_/; | 
| 296 | 296 | ||
| 297 | # Skip defaults and internals | 297 | # Skip defaults and internals | 
| 298 | next if exists $DEFAULT{$key} && $hash->{$key} eq $DEFAULT{$key}; | 298 | next if exists $DEFAULT{$key} && $hash->{$key} eq $DEFAULT{$key}; | 
| 299 | next if grep { $key eq $_ } qw(help usage version extra-opts); | 299 | next if grep { $key eq $_ } qw(help usage version extra-opts); | 
| 300 | next unless defined $hash->{$key}; | 300 | next unless defined $hash->{$key}; | 
| 301 | 301 | ||
| @@ -307,7 +307,7 @@ sub _cmdline | |||
| 307 | $value = $self->_cmdline_value($value); | 307 | $value = $self->_cmdline_value($value); | 
| 308 | if (length($key) > 1) { | 308 | if (length($key) > 1) { | 
| 309 | push @args, sprintf "--%s=%s", $key, $value; | 309 | push @args, sprintf "--%s=%s", $key, $value; | 
| 310 | } | 310 | } | 
| 311 | else { | 311 | else { | 
| 312 | push @args, "-$key", $value; | 312 | push @args, "-$key", $value; | 
| 313 | } | 313 | } | 
| @@ -445,7 +445,7 @@ sub _init | |||
| 445 | my $self = shift; | 445 | my $self = shift; | 
| 446 | 446 | ||
| 447 | # Check params | 447 | # Check params | 
| 448 | my $plugin = basename($ENV{NAGIOS_PLUGIN} || $0); | 448 | my $plugin = basename($ENV{PLUGIN_NAME} || $ENV{NAGIOS_PLUGIN} || $0); | 
| 449 | my %attr = validate( @_, { | 449 | my %attr = validate( @_, { | 
| 450 | usage => 1, | 450 | usage => 1, | 
| 451 | version => 0, | 451 | version => 0, | 
| @@ -470,7 +470,7 @@ sub _init | |||
| 470 | $self | 470 | $self | 
| 471 | } | 471 | } | 
| 472 | 472 | ||
| 473 | sub new | 473 | sub new | 
| 474 | { | 474 | { | 
| 475 | my $class = shift; | 475 | my $class = shift; | 
| 476 | my $self = bless {}, $class; | 476 | my $self = bless {}, $class; | 
| @@ -485,20 +485,20 @@ __END__ | |||
| 485 | 485 | ||
| 486 | =head1 NAME | 486 | =head1 NAME | 
| 487 | 487 | ||
| 488 | Nagios::Plugin::Getopt - OO perl module providing standardised argument | 488 | Monitoring::Plugin::Getopt - OO perl module providing standardised argument | 
| 489 | processing for Nagios plugins | 489 | processing for Nagios plugins | 
| 490 | 490 | ||
| 491 | 491 | ||
| 492 | =head1 SYNOPSIS | 492 | =head1 SYNOPSIS | 
| 493 | 493 | ||
| 494 | use Nagios::Plugin::Getopt; | 494 | use Monitoring::Plugin::Getopt; | 
| 495 | 495 | ||
| 496 | # Instantiate object (usage is mandatory) | 496 | # Instantiate object (usage is mandatory) | 
| 497 | $ng = Nagios::Plugin::Getopt->new( | 497 | $ng = Monitoring::Plugin::Getopt->new( | 
| 498 | usage => "Usage: %s -H <host> -w <warning> -c <critical>", | 498 | usage => "Usage: %s -H <host> -w <warning> -c <critical>", | 
| 499 | version => '0.1', | 499 | version => '0.1', | 
| 500 | url => 'http://www.openfusion.com.au/labs/nagios/', | 500 | url => 'http://www.openfusion.com.au/labs/nagios/', | 
| 501 | blurb => 'This plugin tests various stuff.', | 501 | blurb => 'This plugin tests various stuff.', | 
| 502 | ); | 502 | ); | 
| 503 | 503 | ||
| 504 | # Add argument - named parameters (spec and help are mandatory) | 504 | # Add argument - named parameters (spec and help are mandatory) | 
| @@ -509,7 +509,7 @@ processing for Nagios plugins | |||
| 509 | default => 10, | 509 | default => 10, | 
| 510 | ); | 510 | ); | 
| 511 | 511 | ||
| 512 | # Add argument - positional parameters - arg spec, help text, | 512 | # Add argument - positional parameters - arg spec, help text, | 
| 513 | # default value, required? (first two mandatory) | 513 | # default value, required? (first two mandatory) | 
| 514 | $ng->arg( | 514 | $ng->arg( | 
| 515 | 'warning|w=i', | 515 | 'warning|w=i', | 
| @@ -528,23 +528,23 @@ processing for Nagios plugins | |||
| 528 | 528 | ||
| 529 | =head1 DESCRIPTION | 529 | =head1 DESCRIPTION | 
| 530 | 530 | ||
| 531 | Nagios::Plugin::Getopt is an OO perl module providing standardised and | 531 | Monitoring::Plugin::Getopt is an OO perl module providing standardised and | 
| 532 | simplified argument processing for Nagios plugins. It implements | 532 | simplified argument processing for Nagios plugins. It implements | 
| 533 | a number of standard arguments itself (--help, --version, | 533 | a number of standard arguments itself (--help, --version, | 
| 534 | --usage, --timeout, --verbose, and their short form counterparts), | 534 | --usage, --timeout, --verbose, and their short form counterparts), | 
| 535 | produces standardised nagios plugin help output, and allows | 535 | produces standardised nagios plugin help output, and allows | 
| 536 | additional arguments to be easily defined. | 536 | additional arguments to be easily defined. | 
| 537 | 537 | ||
| 538 | 538 | ||
| 539 | =head2 CONSTRUCTOR | 539 | =head2 CONSTRUCTOR | 
| 540 | 540 | ||
| 541 | # Instantiate object (usage is mandatory) | 541 | # Instantiate object (usage is mandatory) | 
| 542 | $ng = Nagios::Plugin::Getopt->new( | 542 | $ng = Monitoring::Plugin::Getopt->new( | 
| 543 | usage => 'Usage: %s --hello', | 543 | usage => 'Usage: %s --hello', | 
| 544 | version => '0.01', | 544 | version => '0.01', | 
| 545 | ); | 545 | ); | 
| 546 | 546 | ||
| 547 | The Nagios::Plugin::Getopt constructor accepts the following named | 547 | The Monitoring::Plugin::Getopt constructor accepts the following named | 
| 548 | arguments: | 548 | arguments: | 
| 549 | 549 | ||
| 550 | =over 4 | 550 | =over 4 | 
| @@ -573,7 +573,7 @@ the longer --help output. e.g. | |||
| 573 | 573 | ||
| 574 | =item url | 574 | =item url | 
| 575 | 575 | ||
| 576 | URL for info about this plugin, included in the --version/-V output, | 576 | URL for info about this plugin, included in the --version/-V output, | 
| 577 | and in the longer --help output (see preceding 'version' example). | 577 | and in the longer --help output (see preceding 'version' example). | 
| 578 | 578 | ||
| 579 | =item blurb | 579 | =item blurb | 
| @@ -583,20 +583,20 @@ Short plugin description, included in the longer --help output | |||
| 583 | 583 | ||
| 584 | =item license | 584 | =item license | 
| 585 | 585 | ||
| 586 | License text, included in the longer --help output (see below for an | 586 | License text, included in the longer --help output (see below for an | 
| 587 | example). By default, this is set to the standard nagios plugins | 587 | example). By default, this is set to the standard nagios plugins | 
| 588 | GPL license text: | 588 | GPL license text: | 
| 589 | 589 | ||
| 590 | This nagios plugin is free software, and comes with ABSOLUTELY | 590 | This nagios plugin is free software, and comes with ABSOLUTELY | 
| 591 | NO WARRANTY. It may be used, redistributed and/or modified under | 591 | NO WARRANTY. It may be used, redistributed and/or modified under | 
| 592 | the terms of the GNU General Public Licence (see | 592 | the terms of the GNU General Public Licence (see | 
| 593 | http://www.fsf.org/licensing/licenses/gpl.txt). | 593 | http://www.fsf.org/licensing/licenses/gpl.txt). | 
| 594 | 594 | ||
| 595 | Provide your own to replace this text in the help output. | 595 | Provide your own to replace this text in the help output. | 
| 596 | 596 | ||
| 597 | =item extra | 597 | =item extra | 
| 598 | 598 | ||
| 599 | Extra text to be appended at the end of the longer --help output. | 599 | Extra text to be appended at the end of the longer --help output. | 
| 600 | 600 | ||
| 601 | =item plugin | 601 | =item plugin | 
| 602 | 602 | ||
| @@ -605,7 +605,7 @@ usually correct, but you can set it explicitly if not. | |||
| 605 | 605 | ||
| 606 | =item timeout | 606 | =item timeout | 
| 607 | 607 | ||
| 608 | Timeout period in seconds, overriding the standard timeout default | 608 | Timeout period in seconds, overriding the standard timeout default | 
| 609 | (15 seconds). | 609 | (15 seconds). | 
| 610 | 610 | ||
| 611 | =back | 611 | =back | 
| @@ -630,8 +630,8 @@ example: | |||
| 630 | $ ./check_tcp_range -h | 630 | $ ./check_tcp_range -h | 
| 631 | check_tcp_range 0.2 [http://www.openfusion.com.au/labs/nagios/] | 631 | check_tcp_range 0.2 [http://www.openfusion.com.au/labs/nagios/] | 
| 632 | 632 | ||
| 633 | This nagios plugin is free software, and comes with ABSOLUTELY NO WARRANTY. | 633 | This nagios plugin is free software, and comes with ABSOLUTELY NO WARRANTY. | 
| 634 | It may be used, redistributed and/or modified under the terms of the GNU | 634 | It may be used, redistributed and/or modified under the terms of the GNU | 
| 635 | General Public Licence (see http://www.fsf.org/licensing/licenses/gpl.txt). | 635 | General Public Licence (see http://www.fsf.org/licensing/licenses/gpl.txt). | 
| 636 | 636 | ||
| 637 | This plugin tests arbitrary ranges/sets of tcp ports for a host. | 637 | This plugin tests arbitrary ranges/sets of tcp ports for a host. | 
| @@ -647,7 +647,7 @@ example: | |||
| 647 | Host name or IP address | 647 | Host name or IP address | 
| 648 | -p, --ports=STRING | 648 | -p, --ports=STRING | 
| 649 | Port numbers to check. Format: comma-separated, colons for ranges, | 649 | Port numbers to check. Format: comma-separated, colons for ranges, | 
| 650 | no spaces e.g. 8700:8705,8710:8715,8760 | 650 | no spaces e.g. 8700:8705,8710:8715,8760 | 
| 651 | -t, --timeout=INTEGER | 651 | -t, --timeout=INTEGER | 
| 652 | Seconds before plugin times out (default: 15) | 652 | Seconds before plugin times out (default: 15) | 
| 653 | -v, --verbose | 653 | -v, --verbose | 
| @@ -656,14 +656,14 @@ example: | |||
| 656 | 656 | ||
| 657 | =head2 ARGUMENTS | 657 | =head2 ARGUMENTS | 
| 658 | 658 | ||
| 659 | You can define arguments for your plugin using the arg() method, which | 659 | You can define arguments for your plugin using the arg() method, which | 
| 660 | supports both named and positional arguments. In both cases | 660 | supports both named and positional arguments. In both cases | 
| 661 | the C<spec> and C<help> arguments are required, while the C<label>, | 661 | the C<spec> and C<help> arguments are required, while the C<label>, | 
| 662 | C<default>, and C<required> arguments are optional: | 662 | C<default>, and C<required> arguments are optional: | 
| 663 | 663 | ||
| 664 | # Define --hello argument (named parameters) | 664 | # Define --hello argument (named parameters) | 
| 665 | $ng->arg( | 665 | $ng->arg( | 
| 666 | spec => 'hello|h=s', | 666 | spec => 'hello|h=s', | 
| 667 | help => "Hello string", | 667 | help => "Hello string", | 
| 668 | required => 1, | 668 | required => 1, | 
| 669 | ); | 669 | ); | 
| @@ -710,12 +710,12 @@ The help string is munged in two ways: | |||
| 710 | 710 | ||
| 711 | =item | 711 | =item | 
| 712 | 712 | ||
| 713 | First, if the help string does NOT begins with a '-' sign, it is prefixed | 713 | First, if the help string does NOT begins with a '-' sign, it is prefixed | 
| 714 | by an expanded form of the C<spec> argument. For instance, the following | 714 | by an expanded form of the C<spec> argument. For instance, the following | 
| 715 | hello argument: | 715 | hello argument: | 
| 716 | 716 | ||
| 717 | $ng->arg( | 717 | $ng->arg( | 
| 718 | spec => 'hello|h=s', | 718 | spec => 'hello|h=s', | 
| 719 | help => "Hello string", | 719 | help => "Hello string", | 
| 720 | ); | 720 | ); | 
| 721 | 721 | ||
| @@ -727,9 +727,9 @@ would be displayed in the help output as: | |||
| 727 | where the '-h, --hello=STRING' part is derived from the spec definition | 727 | where the '-h, --hello=STRING' part is derived from the spec definition | 
| 728 | (by convention with short args first, then long, then label/type, if any). | 728 | (by convention with short args first, then long, then label/type, if any). | 
| 729 | 729 | ||
| 730 | =item | 730 | =item | 
| 731 | 731 | ||
| 732 | Second, if the string contains a '%s' it will be formatted via | 732 | Second, if the string contains a '%s' it will be formatted via | 
| 733 | C<sprintf> with the 'default' as the argument i.e. | 733 | C<sprintf> with the 'default' as the argument i.e. | 
| 734 | 734 | ||
| 735 | sprintf($help, $default) | 735 | sprintf($help, $default) | 
| @@ -756,18 +756,18 @@ would be displayed in the help output as: | |||
| 756 | Exit with WARNING status if less than PERCENT of disk space is free | 756 | Exit with WARNING status if less than PERCENT of disk space is free | 
| 757 | 757 | ||
| 758 | Note that in this case we've also specified explicit labels in another | 758 | Note that in this case we've also specified explicit labels in another | 
| 759 | arrayref corresponding to the C<help> one - if this had been omitted | 759 | arrayref corresponding to the C<help> one - if this had been omitted | 
| 760 | the types would have defaulted to 'STRING', instead of 'BYTES' and | 760 | the types would have defaulted to 'STRING', instead of 'BYTES' and | 
| 761 | 'PERCENT%'. | 761 | 'PERCENT%'. | 
| 762 | 762 | ||
| 763 | 763 | ||
| 764 | =item label | 764 | =item label | 
| 765 | 765 | ||
| 766 | The C<label> argument is a scalar or an arrayref (see 'Multi-line help' | 766 | The C<label> argument is a scalar or an arrayref (see 'Multi-line help' | 
| 767 | description above) that overrides the standard type expansion when generating | 767 | description above) that overrides the standard type expansion when generating | 
| 768 | help text from the spec definition. By default, C<spec=i> arguments are | 768 | help text from the spec definition. By default, C<spec=i> arguments are | 
| 769 | labelled as C<=INTEGER> in the help text, and C<spec=s> arguments are labelled | 769 | labelled as C<=INTEGER> in the help text, and C<spec=s> arguments are labelled | 
| 770 | as C<=STRING>. By supplying your own C<label> argument you can override these | 770 | as C<=STRING>. By supplying your own C<label> argument you can override these | 
| 771 | standard 'INTEGER' and 'STRING' designations. | 771 | standard 'INTEGER' and 'STRING' designations. | 
| 772 | 772 | ||
| 773 | For multi-line help, you can supply an ordered list (arrayref) of labels to | 773 | For multi-line help, you can supply an ordered list (arrayref) of labels to | 
| @@ -789,13 +789,13 @@ if none is explicitly supplied. | |||
| 789 | 789 | ||
| 790 | =item required | 790 | =item required | 
| 791 | 791 | ||
| 792 | The C<required> argument is a boolean used to indicate that this argument | 792 | The C<required> argument is a boolean used to indicate that this argument | 
| 793 | is mandatory (Nagios::Plugin::Getopt will exit with your usage message and | 793 | is mandatory (Monitoring::Plugin::Getopt will exit with your usage message and | 
| 794 | a 'Missing argument' indicator if any required arguments are not supplied). | 794 | a 'Missing argument' indicator if any required arguments are not supplied). | 
| 795 | 795 | ||
| 796 | =back | 796 | =back | 
| 797 | 797 | ||
| 798 | Note that --help lists your arguments in the order they are defined, so | 798 | Note that --help lists your arguments in the order they are defined, so | 
| 799 | you should order your C<arg()> calls accordingly. | 799 | you should order your C<arg()> calls accordingly. | 
| 800 | 800 | ||
| 801 | 801 | ||
| @@ -809,7 +809,7 @@ method, which takes no arguments: | |||
| 809 | 809 | ||
| 810 | This parses the command line arguments passed to your plugin using | 810 | This parses the command line arguments passed to your plugin using | 
| 811 | Getopt::Long and the builtin and provided argument specifications. | 811 | Getopt::Long and the builtin and provided argument specifications. | 
| 812 | Flags and argument values are recorded within the object, and can | 812 | Flags and argument values are recorded within the object, and can | 
| 813 | be accessed either using the generic get() accessor, or using named | 813 | be accessed either using the generic get() accessor, or using named | 
| 814 | accessors corresponding to your argument names. For example: | 814 | accessors corresponding to your argument names. For example: | 
| 815 | 815 | ||
| @@ -824,14 +824,14 @@ accessors corresponding to your argument names. For example: | |||
| 824 | # ... | 824 | # ... | 
| 825 | } | 825 | } | 
| 826 | 826 | ||
| 827 | Note that where you have defined alternate argument names, the first is | 827 | Note that where you have defined alternate argument names, the first is | 
| 828 | considered the citation form. All the builtin arguments are available | 828 | considered the citation form. All the builtin arguments are available | 
| 829 | using their long variant names. | 829 | using their long variant names. | 
| 830 | 830 | ||
| 831 | 831 | ||
| 832 | =head2 BUILTIN PROCESSING | 832 | =head2 BUILTIN PROCESSING | 
| 833 | 833 | ||
| 834 | The C<getopts()> method also handles processing of the immediate builtin | 834 | The C<getopts()> method also handles processing of the immediate builtin | 
| 835 | arguments, namely --usage, --version, --help, as well as checking all | 835 | arguments, namely --usage, --version, --help, as well as checking all | 
| 836 | required arguments have been supplied, so you don't have to handle | 836 | required arguments have been supplied, so you don't have to handle | 
| 837 | those yourself. This means that your plugin will exit from the getopts() | 837 | those yourself. This means that your plugin will exit from the getopts() | 
| @@ -842,32 +842,28 @@ C<getopts()> also sets up a default ALRM timeout handler so you can use an | |||
| 842 | 842 | ||
| 843 | alarm $ng->timeout; | 843 | alarm $ng->timeout; | 
| 844 | 844 | ||
| 845 | around any blocking operations within your plugin (which you are free | 845 | around any blocking operations within your plugin (which you are free | 
| 846 | to override if you want to use a custom timeout message). | 846 | to override if you want to use a custom timeout message). | 
| 847 | 847 | ||
| 848 | 848 | ||
| 849 | =head1 SEE ALSO | 849 | =head1 SEE ALSO | 
| 850 | 850 | ||
| 851 | Nagios::Plugin, Getopt::Long | 851 | Monitoring::Plugin, Getopt::Long | 
| 852 | 852 | ||
| 853 | 853 | ||
| 854 | =head1 AUTHOR | 854 | =head1 AUTHOR | 
| 855 | 855 | ||
| 856 | Gavin Carr <gavin@openfusion.com.au> | 856 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 857 | https://monitoring-plugins.org | ||
| 857 | 858 | ||
| 859 | Originally: | ||
| 860 | Gavin Carr <gavin@openfusion.com.au> | ||
| 858 | 861 | ||
| 859 | =head1 COPYRIGHT AND LICENSE | 862 | =head1 COPYRIGHT AND LICENSE | 
| 860 | 863 | ||
| 861 | Copyright (C) 2006-2007 by the Nagios Plugin Development Team. | 864 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 862 | 865 | ||
| 863 | This module is free software. It may be used, redistributed | 866 | This library is free software; you can redistribute it and/or modify | 
| 864 | and/or modified under either the terms of the Perl Artistic | 867 | it under the same terms as Perl itself. | 
| 865 | License (see http://www.perl.com/perl/misc/Artistic.html) | ||
| 866 | or the GNU General Public Licence (see | ||
| 867 | http://www.fsf.org/licensing/licenses/gpl.txt). | ||
| 868 | 868 | ||
| 869 | =cut | 869 | =cut | 
| 870 | |||
| 871 | # arch-tag: c917effc-7400-4ee5-a5d6-baa9316a3abf | ||
| 872 | # vim:smartindent:sw=2:et | ||
| 873 | |||
| diff --git a/lib/Nagios/Plugin/Performance.pm b/lib/Monitoring/Plugin/Performance.pm index 9248fea..90fc9f4 100644 --- a/lib/Nagios/Plugin/Performance.pm +++ b/lib/Monitoring/Plugin/Performance.pm | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | package Nagios::Plugin::Performance; | 1 | package Monitoring::Plugin::Performance; | 
| 2 | 2 | ||
| 3 | use 5.006; | 3 | use 5.006; | 
| 4 | 4 | ||
| @@ -11,15 +11,15 @@ __PACKAGE__->mk_ro_accessors( | |||
| 11 | qw(label value uom warning critical min max) | 11 | qw(label value uom warning critical min max) | 
| 12 | ); | 12 | ); | 
| 13 | 13 | ||
| 14 | use Nagios::Plugin::Functions; | 14 | use Monitoring::Plugin::Functions; | 
| 15 | use Nagios::Plugin::Threshold; | 15 | use Monitoring::Plugin::Threshold; | 
| 16 | use Nagios::Plugin::Range; | 16 | use Monitoring::Plugin::Range; | 
| 17 | our ($VERSION) = $Nagios::Plugin::Functions::VERSION; | 17 | our ($VERSION) = $Monitoring::Plugin::Functions::VERSION; | 
| 18 | 18 | ||
| 19 | sub import { | 19 | sub import { | 
| 20 | my ($class, %attr) = @_; | 20 | my ($class, %attr) = @_; | 
| 21 | $_ = $attr{use_die} || 0; | 21 | $_ = $attr{use_die} || 0; | 
| 22 | Nagios::Plugin::Functions::_use_die($_); | 22 | Monitoring::Plugin::Functions::_use_die($_); | 
| 23 | } | 23 | } | 
| 24 | 24 | ||
| 25 | # This is NOT the same as N::P::Functions::value_re. We leave that to be the strict | 25 | # This is NOT the same as N::P::Functions::value_re. We leave that to be the strict | 
| @@ -46,7 +46,7 @@ sub _parse { | |||
| 46 | return undef if $not_value; | 46 | return undef if $not_value; | 
| 47 | } | 47 | } | 
| 48 | my $p = $class->new( | 48 | my $p = $class->new( | 
| 49 | label => $info[0], value => $performance_value, uom => $info[2], warning => $info[3], critical => $info[4], | 49 | label => $info[0], value => $performance_value, uom => $info[2], warning => $info[3], critical => $info[4], | 
| 50 | min => $info[5], max => $info[6] | 50 | min => $info[5], max => $info[6] | 
| 51 | ); | 51 | ); | 
| 52 | return $p; | 52 | return $p; | 
| @@ -128,13 +128,13 @@ sub clean_label { | |||
| 128 | sub threshold | 128 | sub threshold | 
| 129 | { | 129 | { | 
| 130 | my $self = shift; | 130 | my $self = shift; | 
| 131 | return Nagios::Plugin::Threshold->set_thresholds( | 131 | return Monitoring::Plugin::Threshold->set_thresholds( | 
| 132 | warning => $self->warning, critical => $self->critical | 132 | warning => $self->warning, critical => $self->critical | 
| 133 | ); | 133 | ); | 
| 134 | } | 134 | } | 
| 135 | 135 | ||
| 136 | # Constructor - unpack thresholds, map args to hashref | 136 | # Constructor - unpack thresholds, map args to hashref | 
| 137 | sub new | 137 | sub new | 
| 138 | { | 138 | { | 
| 139 | my $class = shift; | 139 | my $class = shift; | 
| 140 | my %arg = @_; | 140 | my %arg = @_; | 
| @@ -154,15 +154,15 @@ __END__ | |||
| 154 | 154 | ||
| 155 | =head1 NAME | 155 | =head1 NAME | 
| 156 | 156 | ||
| 157 | Nagios::Plugin::Performance - class for handling Nagios::Plugin | 157 | Monitoring::Plugin::Performance - class for handling Monitoring::Plugin | 
| 158 | performance data. | 158 | performance data. | 
| 159 | 159 | ||
| 160 | =head1 SYNOPSIS | 160 | =head1 SYNOPSIS | 
| 161 | 161 | ||
| 162 | use Nagios::Plugin::Performance use_die => 1; | 162 | use Monitoring::Plugin::Performance use_die => 1; | 
| 163 | 163 | ||
| 164 | # Constructor (also accepts a 'threshold' obj instead of warning/critical) | 164 | # Constructor (also accepts a 'threshold' obj instead of warning/critical) | 
| 165 | $p = Nagios::Plugin::Performance->new( | 165 | $p = Monitoring::Plugin::Performance->new( | 
| 166 | label => 'size', | 166 | label => 'size', | 
| 167 | value => $value, | 167 | value => $value, | 
| 168 | uom => "kB", | 168 | uom => "kB", | 
| @@ -173,9 +173,9 @@ performance data. | |||
| 173 | ); | 173 | ); | 
| 174 | 174 | ||
| 175 | # Parser | 175 | # Parser | 
| 176 | @perf = Nagios::Plugin::Performance->parse_perfstring( | 176 | @perf = Monitoring::Plugin::Performance->parse_perfstring( | 
| 177 | "/=382MB;15264;15269;; /var=218MB;9443;9448" | 177 | "/=382MB;15264;15269;; /var=218MB;9443;9448" | 
| 178 | ) | 178 | ) | 
| 179 | or warn("Failed to parse perfstring"); | 179 | or warn("Failed to parse perfstring"); | 
| 180 | 180 | ||
| 181 | # Accessors | 181 | # Accessors | 
| @@ -197,14 +197,14 @@ performance data. | |||
| 197 | 197 | ||
| 198 | =head1 DESCRIPTION | 198 | =head1 DESCRIPTION | 
| 199 | 199 | ||
| 200 | Nagios::Plugin class for handling performance data. This is a public | 200 | Monitoring::Plugin class for handling performance data. This is a public | 
| 201 | interface because it could be used by performance graphing routines, | 201 | interface because it could be used by performance graphing routines, | 
| 202 | such as nagiostat (http://nagiostat.sourceforge.net), perfparse | 202 | such as nagiostat (http://nagiostat.sourceforge.net), perfparse | 
| 203 | (http://perfparse.sourceforge.net), nagiosgraph | 203 | (http://perfparse.sourceforge.net), nagiosgraph | 
| 204 | (http://nagiosgraph.sourceforge.net) or NagiosGrapher | 204 | (http://nagiosgraph.sourceforge.net) or NagiosGrapher | 
| 205 | (http://www.nagiosexchange.org/NagiosGrapher.84.0.html). | 205 | (http://www.nagiosexchange.org/NagiosGrapher.84.0.html). | 
| 206 | 206 | ||
| 207 | Nagios::Plugin::Performance offers both a parsing interface (via | 207 | Monitoring::Plugin::Performance offers both a parsing interface (via | 
| 208 | parse_perfstring), for turning nagios performance output strings into | 208 | parse_perfstring), for turning nagios performance output strings into | 
| 209 | their components, and a composition interface (via new), for turning | 209 | their components, and a composition interface (via new), for turning | 
| 210 | components into perfdata strings. | 210 | components into perfdata strings. | 
| @@ -213,7 +213,7 @@ components into perfdata strings. | |||
| 213 | 213 | ||
| 214 | If you are using this module for the purposes of parsing perf data, you | 214 | If you are using this module for the purposes of parsing perf data, you | 
| 215 | will probably want to set use_die => 1 at use time. This forces | 215 | will probably want to set use_die => 1 at use time. This forces | 
| 216 | &Nagios::Plugin::Functions::nagios_exit to call die() - rather than exit() - | 216 | &Monitoring::Plugin::Functions::plugin_exit to call die() - rather than exit() - | 
| 217 | when an error occurs. This is then trappable by an eval. If you don't set use_die, | 217 | when an error occurs. This is then trappable by an eval. If you don't set use_die, | 
| 218 | then an error in these modules will cause your script to exit | 218 | then an error in these modules will cause your script to exit | 
| 219 | 219 | ||
| @@ -221,14 +221,14 @@ then an error in these modules will cause your script to exit | |||
| 221 | 221 | ||
| 222 | =over 4 | 222 | =over 4 | 
| 223 | 223 | ||
| 224 | =item Nagios::Plugin::Performance->new(%attributes) | 224 | =item Monitoring::Plugin::Performance->new(%attributes) | 
| 225 | 225 | ||
| 226 | Instantiates a new Nagios::Plugin::Performance object with the given | 226 | Instantiates a new Monitoring::Plugin::Performance object with the given | 
| 227 | attributes. | 227 | attributes. | 
| 228 | 228 | ||
| 229 | =item Nagios::Plugin::Performance->parse_perfstring($string) | 229 | =item Monitoring::Plugin::Performance->parse_perfstring($string) | 
| 230 | 230 | ||
| 231 | Returns an array of Nagios::Plugin::Performance objects based on the string | 231 | Returns an array of Monitoring::Plugin::Performance objects based on the string | 
| 232 | entered. If there is an error parsing the string - which may consists of several | 232 | entered. If there is an error parsing the string - which may consists of several | 
| 233 | sets of data - will return an array with all the successfully parsed sets. | 233 | sets of data - will return an array with all the successfully parsed sets. | 
| 234 | 234 | ||
| @@ -247,18 +247,18 @@ These all return scalars. min and max are not well supported yet. | |||
| 247 | 247 | ||
| 248 | =item threshold | 248 | =item threshold | 
| 249 | 249 | ||
| 250 | Returns a Nagios::Plugin::Threshold object holding the warning and critical | 250 | Returns a Monitoring::Plugin::Threshold object holding the warning and critical | 
| 251 | ranges for this performance data (if any). | 251 | ranges for this performance data (if any). | 
| 252 | 252 | ||
| 253 | =item rrdlabel | 253 | =item rrdlabel | 
| 254 | 254 | ||
| 255 | Returns a string based on 'label' that is suitable for use as dataset name of | 255 | Returns a string based on 'label' that is suitable for use as dataset name of | 
| 256 | an RRD i.e. munges label to be 1-19 characters long with only characters | 256 | an RRD i.e. munges label to be 1-19 characters long with only characters | 
| 257 | [a-zA-Z0-9_]. | 257 | [a-zA-Z0-9_]. | 
| 258 | 258 | ||
| 259 | This calls $self->clean_label and then truncates to 19 characters. | 259 | This calls $self->clean_label and then truncates to 19 characters. | 
| 260 | 260 | ||
| 261 | There is no guarantee that multiple N:P:Performance objects will have unique | 261 | There is no guarantee that multiple N:P:Performance objects will have unique | 
| 262 | rrdlabels. | 262 | rrdlabels. | 
| 263 | 263 | ||
| 264 | =item clean_label | 264 | =item clean_label | 
| @@ -270,25 +270,25 @@ It also converts "/" to "root" and "/{name}" to "{name}". | |||
| 270 | 270 | ||
| 271 | =item perfoutput | 271 | =item perfoutput | 
| 272 | 272 | ||
| 273 | Outputs the data in Nagios::Plugin perfdata format i.e. | 273 | Outputs the data in Monitoring::Plugin perfdata format i.e. | 
| 274 | label=value[uom];[warn];[crit];[min];[max]. | 274 | label=value[uom];[warn];[crit];[min];[max]. | 
| 275 | 275 | ||
| 276 | =back | 276 | =back | 
| 277 | 277 | ||
| 278 | =head1 SEE ALSO | 278 | =head1 SEE ALSO | 
| 279 | 279 | ||
| 280 | Nagios::Plugin, Nagios::Plugin::Threshold, http://nagiosplug.sourceforge.net. | 280 | Monitoring::Plugin, Monitoring::Plugin::Threshold, https://www.monitoring-plugins.org/doc/guidelines.html | 
| 281 | 281 | ||
| 282 | =head1 AUTHOR | 282 | =head1 AUTHOR | 
| 283 | 283 | ||
| 284 | This code is maintained by the Nagios Plugin Development Team: see | 284 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 285 | http://nagiosplug.sourceforge.net. | 285 | https://monitoring-plugins.org | 
| 286 | 286 | ||
| 287 | =head1 COPYRIGHT AND LICENSE | 287 | =head1 COPYRIGHT AND LICENSE | 
| 288 | 288 | ||
| 289 | Copyright (C) 2006-2007 Nagios Plugin Development Team | 289 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 290 | 290 | ||
| 291 | This library is free software; you can redistribute it and/or modify | 291 | This library is free software; you can redistribute it and/or modify | 
| 292 | it under the same terms as Perl itself. | 292 | it under the same terms as Perl itself. | 
| 293 | 293 | ||
| 294 | =cut | 294 | =cut | 
| diff --git a/lib/Nagios/Plugin/Range.pm b/lib/Monitoring/Plugin/Range.pm index 536f6bb..af19577 100644 --- a/lib/Nagios/Plugin/Range.pm +++ b/lib/Monitoring/Plugin/Range.pm | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | package Nagios::Plugin::Range; | 1 | package Monitoring::Plugin::Range; | 
| 2 | 2 | ||
| 3 | use 5.006; | 3 | use 5.006; | 
| 4 | 4 | ||
| @@ -11,8 +11,8 @@ __PACKAGE__->mk_accessors( | |||
| 11 | qw(start end start_infinity end_infinity alert_on) | 11 | qw(start end start_infinity end_infinity alert_on) | 
| 12 | ); | 12 | ); | 
| 13 | 13 | ||
| 14 | use Nagios::Plugin::Functions qw(:DEFAULT $value_re); | 14 | use Monitoring::Plugin::Functions qw(:DEFAULT $value_re); | 
| 15 | our ($VERSION) = $Nagios::Plugin::Functions::VERSION; | 15 | our ($VERSION) = $Monitoring::Plugin::Functions::VERSION; | 
| 16 | 16 | ||
| 17 | use overload | 17 | use overload | 
| 18 | 'eq' => sub { shift->_stringify }, | 18 | 'eq' => sub { shift->_stringify }, | 
| @@ -26,7 +26,7 @@ sub _stringify { | |||
| 26 | my $self = shift; | 26 | my $self = shift; | 
| 27 | return "" unless $self->is_set; | 27 | return "" unless $self->is_set; | 
| 28 | return (($self->alert_on) ? "@" : "") . | 28 | return (($self->alert_on) ? "@" : "") . | 
| 29 | (($self->start_infinity == 1) ? "~:" : (($self->start == 0)?"":$self->start.":")) . | 29 | (($self->start_infinity == 1) ? "~:" : (($self->start == 0)?"":$self->start.":")) . | 
| 30 | (($self->end_infinity == 1) ? "" : $self->end); | 30 | (($self->end_infinity == 1) ? "" : $self->end); | 
| 31 | } | 31 | } | 
| 32 | 32 | ||
| @@ -47,7 +47,7 @@ sub _set_range_end { | |||
| 47 | $self->end_infinity(0); | 47 | $self->end_infinity(0); | 
| 48 | } | 48 | } | 
| 49 | 49 | ||
| 50 | # Returns a N::P::Range object if the string is a conforms to a Nagios Plugin range string, otherwise null | 50 | # Returns a N::P::Range object if the string is a conforms to a Monitoring Plugin range string, otherwise null | 
| 51 | sub parse_range_string { | 51 | sub parse_range_string { | 
| 52 | my ($class, $string) = @_; | 52 | my ($class, $string) = @_; | 
| 53 | my $valid = 0; | 53 | my $valid = 0; | 
| @@ -118,7 +118,7 @@ sub check_range { | |||
| 118 | } | 118 | } | 
| 119 | 119 | ||
| 120 | # Constructor - map args to hashref for SUPER | 120 | # Constructor - map args to hashref for SUPER | 
| 121 | sub new | 121 | sub new | 
| 122 | { | 122 | { | 
| 123 | shift->SUPER::new({ @_ }); | 123 | shift->SUPER::new({ @_ }); | 
| 124 | } | 124 | } | 
| @@ -129,18 +129,18 @@ __END__ | |||
| 129 | 129 | ||
| 130 | =head1 NAME | 130 | =head1 NAME | 
| 131 | 131 | ||
| 132 | Nagios::Plugin::Range - class for handling Nagios::Plugin range data. | 132 | Monitoring::Plugin::Range - class for handling Monitoring::Plugin range data. | 
| 133 | 133 | ||
| 134 | =head1 SYNOPSIS | 134 | =head1 SYNOPSIS | 
| 135 | 135 | ||
| 136 | # NB: This is an internal Nagios::Plugin class. | 136 | # NB: This is an internal Monitoring::Plugin class. | 
| 137 | # See Nagios::Plugin itself for public interfaces. | 137 | # See Monitoring::Plugin itself for public interfaces. | 
| 138 | 138 | ||
| 139 | # Instantiate an empty range object | 139 | # Instantiate an empty range object | 
| 140 | $r = Nagios::Plugin::Range->new; | 140 | $r = Monitoring::Plugin::Range->new; | 
| 141 | 141 | ||
| 142 | # Instantiate by parsing a standard nagios range string | 142 | # Instantiate by parsing a standard nagios range string | 
| 143 | $r = Nagios::Plugin::Range->parse_range_string( $range_str ); | 143 | $r = Monitoring::Plugin::Range->parse_range_string( $range_str ); | 
| 144 | 144 | ||
| 145 | # Returns true if the range is defined/non-empty | 145 | # Returns true if the range is defined/non-empty | 
| 146 | $r->is_set; | 146 | $r->is_set; | 
| @@ -151,17 +151,17 @@ Nagios::Plugin::Range - class for handling Nagios::Plugin range data. | |||
| 151 | 151 | ||
| 152 | =head1 DESCRIPTION | 152 | =head1 DESCRIPTION | 
| 153 | 153 | ||
| 154 | Internal Nagios::Plugin class for handling common range data. See | 154 | Internal Monitoring::Plugin class for handling common range data. See | 
| 155 | Nagios::Plugin for public interfaces. | 155 | Monitoring::Plugin for public interfaces. | 
| 156 | 156 | ||
| 157 | =head1 AUTHOR | 157 | =head1 AUTHOR | 
| 158 | 158 | ||
| 159 | This code is maintained by the Nagios Plugin Development Team: see | 159 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 160 | http://nagiosplug.sourceforge.net. | 160 | https://monitoring-plugins.org | 
| 161 | 161 | ||
| 162 | =head1 COPYRIGHT AND LICENSE | 162 | =head1 COPYRIGHT AND LICENSE | 
| 163 | 163 | ||
| 164 | Copyright (C) 2006-2007 Nagios Plugin Development Team | 164 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 165 | 165 | ||
| 166 | This library is free software; you can redistribute it and/or modify | 166 | This library is free software; you can redistribute it and/or modify | 
| 167 | it under the same terms as Perl itself. | 167 | it under the same terms as Perl itself. | 
| diff --git a/lib/Nagios/Plugin/Threshold.pm b/lib/Monitoring/Plugin/Threshold.pm index 95a089b..e71e21b 100644 --- a/lib/Nagios/Plugin/Threshold.pm +++ b/lib/Monitoring/Plugin/Threshold.pm | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | package Nagios::Plugin::Threshold; | 1 | package Monitoring::Plugin::Threshold; | 
| 2 | 2 | ||
| 3 | use 5.006; | 3 | use 5.006; | 
| 4 | 4 | ||
| @@ -8,11 +8,11 @@ use warnings; | |||
| 8 | use base qw(Class::Accessor::Fast); | 8 | use base qw(Class::Accessor::Fast); | 
| 9 | __PACKAGE__->mk_accessors(qw(warning critical)); | 9 | __PACKAGE__->mk_accessors(qw(warning critical)); | 
| 10 | 10 | ||
| 11 | use Nagios::Plugin::Range; | 11 | use Monitoring::Plugin::Range; | 
| 12 | use Nagios::Plugin::Functions qw(:codes nagios_die); | 12 | use Monitoring::Plugin::Functions qw(:codes plugin_die); | 
| 13 | our ($VERSION) = $Nagios::Plugin::Functions::VERSION; | 13 | our ($VERSION) = $Monitoring::Plugin::Functions::VERSION; | 
| 14 | 14 | ||
| 15 | sub get_status | 15 | sub get_status | 
| 16 | { | 16 | { | 
| 17 | my ($self, $value) = @_; | 17 | my ($self, $value) = @_; | 
| 18 | 18 | ||
| @@ -22,7 +22,7 @@ sub get_status | |||
| 22 | return CRITICAL if $self->critical->check_range($v); | 22 | return CRITICAL if $self->critical->check_range($v); | 
| 23 | } | 23 | } | 
| 24 | } | 24 | } | 
| 25 | foreach my $v (@$value) { | 25 | foreach my $v (@$value) { | 
| 26 | if ($self->warning->is_set) { | 26 | if ($self->warning->is_set) { | 
| 27 | return WARNING if $self->warning->check_range($v); | 27 | return WARNING if $self->warning->check_range($v); | 
| 28 | } | 28 | } | 
| @@ -35,21 +35,21 @@ sub _inflate | |||
| 35 | my ($self, $value, $key) = @_; | 35 | my ($self, $value, $key) = @_; | 
| 36 | 36 | ||
| 37 | # Return an undefined range if $value is undef | 37 | # Return an undefined range if $value is undef | 
| 38 | return Nagios::Plugin::Range->new if ! defined $value; | 38 | return Monitoring::Plugin::Range->new if ! defined $value; | 
| 39 | 39 | ||
| 40 | # For refs, check isa N::P::Range | 40 | # For refs, check isa N::P::Range | 
| 41 | if (ref $value) { | 41 | if (ref $value) { | 
| 42 | nagios_die("Invalid $key object: type " . ref $value) | 42 | plugin_die("Invalid $key object: type " . ref $value) | 
| 43 | unless $value->isa("Nagios::Plugin::Range"); | 43 | unless $value->isa("Monitoring::Plugin::Range"); | 
| 44 | return $value; | 44 | return $value; | 
| 45 | } | 45 | } | 
| 46 | 46 | ||
| 47 | # Another quick exit if $value is an empty string | 47 | # Another quick exit if $value is an empty string | 
| 48 | return Nagios::Plugin::Range->new if $value eq ""; | 48 | return Monitoring::Plugin::Range->new if $value eq ""; | 
| 49 | 49 | ||
| 50 | # Otherwise parse $value | 50 | # Otherwise parse $value | 
| 51 | my $range = Nagios::Plugin::Range->parse_range_string($value); | 51 | my $range = Monitoring::Plugin::Range->parse_range_string($value); | 
| 52 | nagios_die("Cannot parse $key range: '$value'") unless(defined($range)); | 52 | plugin_die("Cannot parse $key range: '$value'") unless(defined($range)); | 
| 53 | return $range; | 53 | return $range; | 
| 54 | } | 54 | } | 
| 55 | 55 | ||
| @@ -70,9 +70,9 @@ sub set | |||
| 70 | my ($key, $value) = @_; | 70 | my ($key, $value) = @_; | 
| 71 | $self->SUPER::set($key, $self->_inflate($value, $key)); | 71 | $self->SUPER::set($key, $self->_inflate($value, $key)); | 
| 72 | } | 72 | } | 
| 73 | 73 | ||
| 74 | # Constructor - inflate scalars to N::P::Range objects | 74 | # Constructor - inflate scalars to N::P::Range objects | 
| 75 | sub new | 75 | sub new | 
| 76 | { | 76 | { | 
| 77 | my ($self, %arg) = @_; | 77 | my ($self, %arg) = @_; | 
| 78 | $self->SUPER::new({ | 78 | $self->SUPER::new({ | 
| @@ -86,15 +86,15 @@ __END__ | |||
| 86 | 86 | ||
| 87 | =head1 NAME | 87 | =head1 NAME | 
| 88 | 88 | ||
| 89 | Nagios::Plugin::Threshold - class for handling Nagios::Plugin thresholds. | 89 | Monitoring::Plugin::Threshold - class for handling Monitoring::Plugin thresholds. | 
| 90 | 90 | ||
| 91 | =head1 SYNOPSIS | 91 | =head1 SYNOPSIS | 
| 92 | 92 | ||
| 93 | # NB: This is an internal Nagios::Plugin class. | 93 | # NB: This is an internal Monitoring::Plugin class. | 
| 94 | # See Nagios::Plugin itself for public interfaces. | 94 | # See Monitoring::Plugin itself for public interfaces. | 
| 95 | 95 | ||
| 96 | # Constructor | 96 | # Constructor | 
| 97 | $t = Nagios::Plugin::Threshold->set_thresholds( | 97 | $t = Monitoring::Plugin::Threshold->set_thresholds( | 
| 98 | warning => $warning_range_string, | 98 | warning => $warning_range_string, | 
| 99 | critical => $critical_range_string, | 99 | critical => $critical_range_string, | 
| 100 | ); | 100 | ); | 
| @@ -110,10 +110,10 @@ Nagios::Plugin::Threshold - class for handling Nagios::Plugin thresholds. | |||
| 110 | 110 | ||
| 111 | =head1 DESCRIPTION | 111 | =head1 DESCRIPTION | 
| 112 | 112 | ||
| 113 | Internal Nagios::Plugin class for handling threshold data. See | 113 | Internal Monitoring::Plugin class for handling threshold data. See | 
| 114 | Nagios::Plugin for public interfaces. | 114 | Monitoring::Plugin for public interfaces. | 
| 115 | 115 | ||
| 116 | A threshold object contains (typically) a pair of ranges, associated | 116 | A threshold object contains (typically) a pair of ranges, associated | 
| 117 | with a particular severity e.g. | 117 | with a particular severity e.g. | 
| 118 | 118 | ||
| 119 | warning => range1 | 119 | warning => range1 | 
| @@ -121,12 +121,12 @@ with a particular severity e.g. | |||
| 121 | 121 | ||
| 122 | =head1 AUTHOR | 122 | =head1 AUTHOR | 
| 123 | 123 | ||
| 124 | This code is maintained by the Nagios Plugin Development Team: see | 124 | This code is maintained by the Monitoring Plugin Development Team: see | 
| 125 | http://nagiosplug.sourceforge.net. | 125 | https://monitoring-plugins.org | 
| 126 | 126 | ||
| 127 | =head1 COPYRIGHT AND LICENSE | 127 | =head1 COPYRIGHT AND LICENSE | 
| 128 | 128 | ||
| 129 | Copyright (C) 2006-2007 Nagios Plugin Development Team | 129 | Copyright (C) 2006-2014 Monitoring Plugin Development Team | 
| 130 | 130 | ||
| 131 | This library is free software; you can redistribute it and/or modify | 131 | This library is free software; you can redistribute it and/or modify | 
| 132 | it under the same terms as Perl itself. | 132 | it under the same terms as Perl itself. | 
| diff --git a/lib/Nagios/Plugin/ExitResult.pm b/lib/Nagios/Plugin/ExitResult.pm deleted file mode 100644 index b161e9e..0000000 --- a/lib/Nagios/Plugin/ExitResult.pm +++ /dev/null | |||
| @@ -1,67 +0,0 @@ | |||
| 1 | # Tiny helper class to return both output and return_code when testing | ||
| 2 | |||
| 3 | package Nagios::Plugin::ExitResult; | ||
| 4 | |||
| 5 | use strict; | ||
| 6 | |||
| 7 | # Stringify to message | ||
| 8 | use overload '""' => sub { shift->{message} }; | ||
| 9 | |||
| 10 | # Constructor | ||
| 11 | sub new { | ||
| 12 | my $class = shift; | ||
| 13 | return bless { return_code => $_[0], message => $_[1] }, $class; | ||
| 14 | } | ||
| 15 | |||
| 16 | # Accessors | ||
| 17 | sub message { shift->{message} } | ||
| 18 | sub return_code { shift->{return_code} } | ||
| 19 | sub code { shift->{return_code} } | ||
| 20 | |||
| 21 | 1; | ||
| 22 | |||
| 23 | __END__ | ||
| 24 | |||
| 25 | =head1 NAME | ||
| 26 | |||
| 27 | Nagios::Plugin::ExitResult - Helper class for returning both output and | ||
| 28 | return codes when testing. | ||
| 29 | |||
| 30 | =head1 SYNOPSIS | ||
| 31 | |||
| 32 | use Test::More; | ||
| 33 | use Nagios::Plugin::Functions; | ||
| 34 | |||
| 35 | # In a test file somewhere | ||
| 36 | Nagios::Plugin::Functions::_fake_exit(1); | ||
| 37 | |||
| 38 | # Later ... | ||
| 39 | $e = nagios_exit( CRITICAL, 'aiiii ...' ); | ||
| 40 | print $e->message; | ||
| 41 | print $e->return_code; | ||
| 42 | |||
| 43 | # NP::ExitResult also stringifies to the message output | ||
| 44 | like(nagios_exit( WARNING, 'foobar'), qr/^foo/, 'matches!'); | ||
| 45 | |||
| 46 | |||
| 47 | |||
| 48 | =head1 DESCRIPTION | ||
| 49 | |||
| 50 | Nagios::Plugin::ExitResult is a tiny helper class intended for use | ||
| 51 | when testing other Nagios::Plugin modules. A Nagios::Plugin::ExitResult | ||
| 52 | object is returned by nagios_exit() and friends when | ||
| 53 | Nagios::Plugin::Functions::_fake_exit has been set, instead of doing a | ||
| 54 | conventional print + exit. | ||
| 55 | |||
| 56 | =head1 AUTHOR | ||
| 57 | |||
| 58 | Gavin Carr , E<lt>gavin@openfusion.com.auE<gt> | ||
| 59 | |||
| 60 | =head1 COPYRIGHT AND LICENSE | ||
| 61 | |||
| 62 | Copyright (C) 2006 by Nagios Plugin Development Team | ||
| 63 | |||
| 64 | This library is free software; you can redistribute it and/or modify | ||
| 65 | it under the same terms as Perl itself. | ||
| 66 | |||
| 67 | =cut | ||
| diff --git a/t/Nagios-Plugin-01.t b/t/Monitoring-Plugin-01.t index 947a704..f5882a5 100644 --- a/t/Nagios-Plugin-01.t +++ b/t/Monitoring-Plugin-01.t | |||
| @@ -1,32 +1,32 @@ | |||
| 1 | # Nagios::Plugin original test cases | 1 | # Monitoring::Plugin original test cases | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More tests => 15; | 4 | use Test::More tests => 15; | 
| 5 | 5 | ||
| 6 | BEGIN { use_ok('Nagios::Plugin') }; | 6 | BEGIN { use_ok('Monitoring::Plugin') }; | 
| 7 | 7 | ||
| 8 | use Nagios::Plugin::Functions; | 8 | use Monitoring::Plugin::Functions; | 
| 9 | Nagios::Plugin::Functions::_fake_exit(1); | 9 | Monitoring::Plugin::Functions::_fake_exit(1); | 
| 10 | 10 | ||
| 11 | diag "\nusing Nagios::Plugin revision ". $Nagios::Plugin::VERSION . "\n" | 11 | diag "\nusing Monitoring::Plugin revision ". $Monitoring::Plugin::VERSION . "\n" | 
| 12 | if $ENV{TEST_VERBOSE}; | 12 | if $ENV{TEST_VERBOSE}; | 
| 13 | 13 | ||
| 14 | my $p = Nagios::Plugin->new(); | 14 | my $p = Monitoring::Plugin->new(); | 
| 15 | isa_ok( $p, "Nagios::Plugin"); | 15 | isa_ok( $p, "Monitoring::Plugin"); | 
| 16 | 16 | ||
| 17 | $p->shortname("PAGESIZE"); | 17 | $p->shortname("PAGESIZE"); | 
| 18 | is($p->shortname, "PAGESIZE", "shortname explicitly set correctly"); | 18 | is($p->shortname, "PAGESIZE", "shortname explicitly set correctly"); | 
| 19 | 19 | ||
| 20 | $p = Nagios::Plugin->new(); | 20 | $p = Monitoring::Plugin->new(); | 
| 21 | is($p->shortname, "NAGIOS-PLUGIN-01", "shortname should default on new"); | 21 | is($p->shortname, "MONITORING-PLUGIN-01", "shortname should default on new"); | 
| 22 | 22 | ||
| 23 | $p = Nagios::Plugin->new( shortname => "SIZE", () ); | 23 | $p = Monitoring::Plugin->new( shortname => "SIZE", () ); | 
| 24 | is($p->shortname, "SIZE", "shortname set correctly on new"); | 24 | is($p->shortname, "SIZE", "shortname set correctly on new"); | 
| 25 | 25 | ||
| 26 | $p = Nagios::Plugin->new( plugin => "check_stuff", () ); | 26 | $p = Monitoring::Plugin->new( plugin => "check_stuff", () ); | 
| 27 | is($p->shortname, "STUFF", "shortname uses plugin name as default"); | 27 | is($p->shortname, "STUFF", "shortname uses plugin name as default"); | 
| 28 | 28 | ||
| 29 | $p = Nagios::Plugin->new( shortname => "SIZE", plugin => "check_stuff", () ); | 29 | $p = Monitoring::Plugin->new( shortname => "SIZE", plugin => "check_stuff", () ); | 
| 30 | is($p->shortname, "SIZE", "shortname is not overriden by default"); | 30 | is($p->shortname, "SIZE", "shortname is not overriden by default"); | 
| 31 | 31 | ||
| 32 | diag "warn if < 10, critical if > 25 " if $ENV{TEST_VERBOSE}; | 32 | diag "warn if < 10, critical if > 25 " if $ENV{TEST_VERBOSE}; | 
| @@ -37,10 +37,10 @@ use Data::Dumper; | |||
| 37 | #diag "dumping perfdata: ". Dumper $p->perfdata; | 37 | #diag "dumping perfdata: ". Dumper $p->perfdata; | 
| 38 | 38 | ||
| 39 | 39 | ||
| 40 | $p->add_perfdata( | 40 | $p->add_perfdata( | 
| 41 | label => "size", | 41 | label => "size", | 
| 42 | value => 1, | 42 | value => 1, | 
| 43 | uom => "kB", | 43 | uom => "kB", | 
| 44 | threshold => $t, | 44 | threshold => $t, | 
| 45 | ); | 45 | ); | 
| 46 | 46 | ||
| @@ -69,4 +69,3 @@ foreach (sort {$a<=>$b} keys %$expected) { | |||
| 69 | qr/$expected->{$_}/, | 69 | qr/$expected->{$_}/, | 
| 70 | "Output okay. $_ = $expected->{$_}" ; | 70 | "Output okay. $_ = $expected->{$_}" ; | 
| 71 | } | 71 | } | 
| 72 | |||
| diff --git a/t/Monitoring-Plugin-02.t b/t/Monitoring-Plugin-02.t new file mode 100644 index 0000000..6cc834d --- /dev/null +++ b/t/Monitoring-Plugin-02.t | |||
| @@ -0,0 +1,160 @@ | |||
| 1 | # Monitoring::Plugin test set 2, testing MP::Functions wrapping | ||
| 2 | |||
| 3 | use strict; | ||
| 4 | use Test::More tests => 103; | ||
| 5 | |||
| 6 | BEGIN { use_ok("Monitoring::Plugin") } | ||
| 7 | require Monitoring::Plugin::Functions; | ||
| 8 | Monitoring::Plugin::Functions::_fake_exit(1); | ||
| 9 | |||
| 10 | # Hardcoded checks of constants | ||
| 11 | my %ERRORS = %Monitoring::Plugin::Functions::ERRORS; | ||
| 12 | is(OK, $ERRORS{OK}, "OK => $ERRORS{OK}"); | ||
| 13 | is(WARNING, $ERRORS{WARNING}, "WARNING => $ERRORS{WARNING}"); | ||
| 14 | is(CRITICAL, $ERRORS{CRITICAL}, "CRITICAL => $ERRORS{CRITICAL}"); | ||
| 15 | is(UNKNOWN, $ERRORS{UNKNOWN}, "UNKNOWN => $ERRORS{UNKNOWN}"); | ||
| 16 | is(DEPENDENT, $ERRORS{DEPENDENT}, "DEPENDENT => $ERRORS{DEPENDENT}"); | ||
| 17 | |||
| 18 | my $plugin = 'TEST_PLUGIN'; | ||
| 19 | my $np = Monitoring::Plugin->new( shortname => $plugin ); | ||
| 20 | is($np->shortname, $plugin, "shortname() is $plugin"); | ||
| 21 | |||
| 22 | # Test plugin_exit( CONSTANT, $msg ), plugin_exit( $string, $msg ) | ||
| 23 | my $r; | ||
| 24 | my @ok = ( | ||
| 25 | [ OK, "OK", 'test the first', ], | ||
| 26 | [ WARNING, "WARNING", 'test the second', ], | ||
| 27 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 28 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 29 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 30 | ); | ||
| 31 | for (@ok) { | ||
| 32 | # CONSTANT | ||
| 33 | $r = $np->plugin_exit($_->[0], $_->[2]); | ||
| 34 | is($r->return_code, $_->[0], | ||
| 35 | sprintf('plugin_exit(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 36 | like($r->message, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 37 | sprintf('plugin_exit(%s, $msg) output matched "%s"', $_->[1], | ||
| 38 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 39 | |||
| 40 | # $string | ||
| 41 | $r = $np->plugin_exit($_->[1], $_->[2]); | ||
| 42 | is($r->return_code, $_->[0], | ||
| 43 | sprintf('plugin_exit("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 44 | like($r->message, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 45 | sprintf('plugin_exit("%s", $msg) output matched "%s"', $_->[1], | ||
| 46 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 47 | like($r, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 48 | sprintf('plugin_exit("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 49 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 50 | } | ||
| 51 | |||
| 52 | # plugin_exit code corner cases | ||
| 53 | my @ugly1 = ( | ||
| 54 | [ -1, 'testing code -1' ], | ||
| 55 | [ 7, 'testing code 7' ], | ||
| 56 | [ undef, 'testing code undef' ], | ||
| 57 | [ '', qq(testing code '') ], | ||
| 58 | [ 'string', qq(testing code 'string') ], | ||
| 59 | ); | ||
| 60 | for (@ugly1) { | ||
| 61 | $r = $np->plugin_exit($_->[0], $_->[1]); | ||
| 62 | my $display = defined $_->[0] ? "'$_->[0]'" : 'undef'; | ||
| 63 | is($r->return_code, UNKNOWN, "plugin_exit($display, \$msg) returned ". UNKNOWN); | ||
| 64 | like($r->message, qr/UNKNOWN\b.*\b$_->[1]$/, | ||
| 65 | sprintf('plugin_exit(%s, $msg) output matched "%s"', | ||
| 66 | $display, 'UNKNOWN.*' . $_->[1])); | ||
| 67 | } | ||
| 68 | |||
| 69 | # plugin_exit message corner cases | ||
| 70 | my @ugly2 = ( | ||
| 71 | [ '' ], | ||
| 72 | [ undef ], | ||
| 73 | [ UNKNOWN ], | ||
| 74 | ); | ||
| 75 | for (@ugly2) { | ||
| 76 | $r = $np->plugin_exit(CRITICAL, $_->[0]); | ||
| 77 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 78 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 79 | like($r->message, qr/CRITICAL\b.*\b$display2$/, | ||
| 80 | sprintf('plugin_exit(%s, $msg) output matched "%s"', | ||
| 81 | $display1, "CRITICAL.*$display2")); | ||
| 82 | } | ||
| 83 | |||
| 84 | # Test plugin_die( $msg ) | ||
| 85 | my @msg = ( | ||
| 86 | [ 'die you dog' ], | ||
| 87 | [ '' ], | ||
| 88 | [ undef ], | ||
| 89 | ); | ||
| 90 | for (@msg) { | ||
| 91 | $r = $np->plugin_die($_->[0]); | ||
| 92 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 93 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 94 | is($r->return_code, UNKNOWN, | ||
| 95 | sprintf('plugin_die(%s) returned UNKNOWN', $display1)); | ||
| 96 | like($r->message, qr/UNKNOWN\b.*\b$display2$/, | ||
| 97 | sprintf('plugin_die(%s) output matched "%s"', $display1, | ||
| 98 | "UNKNOWN.*$display2")); | ||
| 99 | } | ||
| 100 | |||
| 101 | # Test plugin_die( CONSTANT, $msg ), plugin_die( $msg, CONSTANT ), | ||
| 102 | # plugin_die( $string, $msg ), and plugin_die( $msg, $string ) | ||
| 103 | @ok = ( | ||
| 104 | [ OK, "OK", 'test the first', ], | ||
| 105 | [ WARNING, "WARNING", 'test the second', ], | ||
| 106 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 107 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 108 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 109 | ); | ||
| 110 | for (@ok) { | ||
| 111 | # CONSTANT, $msg | ||
| 112 | $r = $np->plugin_die($_->[0], $_->[2]); | ||
| 113 | is($r->return_code, $_->[0], | ||
| 114 | sprintf('plugin_die(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 115 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 116 | sprintf('plugin_die(%s, $msg) output matched "%s"', | ||
| 117 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 118 | |||
| 119 | # $msg, CONSTANT | ||
| 120 | $r = $np->plugin_die($_->[2], $_->[0]); | ||
| 121 | is($r->return_code, $_->[0], | ||
| 122 | sprintf('plugin_die($msg, %s) returned %s', $_->[1], $_->[0])); | ||
| 123 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 124 | sprintf('plugin_die($msg, %s) output matched "%s"', | ||
| 125 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 126 | |||
| 127 | # $string, $msg | ||
| 128 | $r = $np->plugin_die($_->[1], $_->[2]); | ||
| 129 | is($r->return_code, $_->[0], | ||
| 130 | sprintf('plugin_die("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 131 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 132 | sprintf('plugin_die("%s", $msg) output matched "%s"', $_->[1], | ||
| 133 | $_->[1] . '.*' . $_->[2])); | ||
| 134 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 135 | sprintf('plugin_die("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 136 | $_->[1] . '.*' . $_->[2])); | ||
| 137 | |||
| 138 | # $string, $msg | ||
| 139 | $r = $np->plugin_die($_->[2], $_->[1]); | ||
| 140 | is($r->return_code, $_->[0], | ||
| 141 | sprintf('plugin_die($msg, "%s") returned %s', $_->[1], $_->[0])); | ||
| 142 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 143 | sprintf('plugin_die($msg, "%s") output matched "%s"', $_->[1], | ||
| 144 | $_->[1] . '.*' . $_->[2])); | ||
| 145 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 146 | sprintf('plugin_die($msg, "%s") stringified matched "%s"', $_->[1], | ||
| 147 | $_->[1] . '.*' . $_->[2])); | ||
| 148 | } | ||
| 149 | |||
| 150 | |||
| 151 | # shortname testing | ||
| 152 | SKIP: { | ||
| 153 | skip "requires File::Basename", 2 unless eval { require File::Basename }; | ||
| 154 | $np = Monitoring::Plugin->new( version => "1"); | ||
| 155 | $plugin = uc File::Basename::basename($0); | ||
| 156 | $plugin =~ s/\..*$//; | ||
| 157 | is($np->shortname, $plugin, "shortname() is '$plugin'"); | ||
| 158 | $r = $np->plugin_exit(OK, "foobar"); | ||
| 159 | like($r->message, qr/^$plugin OK/, "message begins with '$plugin OK'"); | ||
| 160 | } | ||
| diff --git a/t/Nagios-Plugin-03.t b/t/Monitoring-Plugin-03.t index bc4f5e3..d419342 100644 --- a/t/Nagios-Plugin-03.t +++ b/t/Monitoring-Plugin-03.t | |||
| @@ -3,15 +3,15 @@ | |||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More tests => 61; | 4 | use Test::More tests => 61; | 
| 5 | 5 | ||
| 6 | BEGIN { | 6 | BEGIN { | 
| 7 | use_ok("Nagios::Plugin"); | 7 | use_ok("Monitoring::Plugin"); | 
| 8 | use_ok("Nagios::Plugin::Functions", ":all"); | 8 | use_ok("Monitoring::Plugin::Functions", ":all"); | 
| 9 | } | 9 | } | 
| 10 | Nagios::Plugin::Functions::_fake_exit(1); | 10 | Monitoring::Plugin::Functions::_fake_exit(1); | 
| 11 | 11 | ||
| 12 | my $plugin = 'NP_CHECK_MESSAGES_03'; | 12 | my $plugin = 'MP_CHECK_MESSAGES_03'; | 
| 13 | my $np = Nagios::Plugin->new( shortname => $plugin, () ); | 13 | my $np = Monitoring::Plugin->new( shortname => $plugin, () ); | 
| 14 | is($np->shortname, $plugin, "shortname() is $plugin"); | 14 | is($np->shortname, $plugin, "shortname() is $plugin"); | 
| 15 | 15 | ||
| 16 | my ($code, $message); | 16 | my ($code, $message); | 
| 17 | 17 | ||
| @@ -113,11 +113,11 @@ is($message, join(' ', @{$arrays{ok}}), "joined undef (ok) message is $message") | |||
| 113 | # ------------------------------------------------------------------------- | 113 | # ------------------------------------------------------------------------- | 
| 114 | # join_all messages | 114 | # join_all messages | 
| 115 | my $join_all = ' :: '; | 115 | my $join_all = ' :: '; | 
| 116 | my $msg_all_cwo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 116 | my $msg_all_cwo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 117 | qw(critical warning ok)); | 117 | qw(critical warning ok)); | 
| 118 | my $msg_all_cw = join($join_all, map { join(' ', @{$arrays{$_}}) } | 118 | my $msg_all_cw = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 119 | qw(critical warning)); | 119 | qw(critical warning)); | 
| 120 | my $msg_all_wo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 120 | my $msg_all_wo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 121 | qw(warning ok)); | 121 | qw(warning ok)); | 
| 122 | 122 | ||
| 123 | # critical, warning, ok | 123 | # critical, warning, ok | 
| @@ -172,33 +172,33 @@ is($message, 'D E F', "join_all '$join_all' (critical, warning) message is $mess | |||
| 172 | # add_messages | 172 | # add_messages | 
| 173 | 173 | ||
| 174 | # Constant codes | 174 | # Constant codes | 
| 175 | $np = Nagios::Plugin->new(); | 175 | $np = Monitoring::Plugin->new(); | 
| 176 | $np->add_message( CRITICAL, "A B C" ); | 176 | $np->add_message( CRITICAL, "A B C" ); | 
| 177 | $np->add_message( WARNING, "D E F" ); | 177 | $np->add_message( WARNING, "D E F" ); | 
| 178 | ($code, $message) = $np->check_messages(); | 178 | ($code, $message) = $np->check_messages(); | 
| 179 | is($code, CRITICAL, "(CRITICAL, WARNING) code is $STATUS_TEXT{$code}"); | 179 | is($code, CRITICAL, "(CRITICAL, WARNING) code is $STATUS_TEXT{$code}"); | 
| 180 | is($message, $messages{critical}, "(CRITICAL, WARNING) message is $message"); | 180 | is($message, $messages{critical}, "(CRITICAL, WARNING) message is $message"); | 
| 181 | 181 | ||
| 182 | $np = Nagios::Plugin->new(); | 182 | $np = Monitoring::Plugin->new(); | 
| 183 | $np->add_message( CRITICAL, "A B C" ); | 183 | $np->add_message( CRITICAL, "A B C" ); | 
| 184 | ($code, $message) = $np->check_messages(); | 184 | ($code, $message) = $np->check_messages(); | 
| 185 | is($code, CRITICAL, "(CRITICAL) code is $STATUS_TEXT{$code}"); | 185 | is($code, CRITICAL, "(CRITICAL) code is $STATUS_TEXT{$code}"); | 
| 186 | is($message, $messages{critical}, "(CRITICAL) message is $message"); | 186 | is($message, $messages{critical}, "(CRITICAL) message is $message"); | 
| 187 | 187 | ||
| 188 | $np = Nagios::Plugin->new(); | 188 | $np = Monitoring::Plugin->new(); | 
| 189 | $np->add_message( WARNING, "D E F" ); | 189 | $np->add_message( WARNING, "D E F" ); | 
| 190 | ($code, $message) = $np->check_messages(); | 190 | ($code, $message) = $np->check_messages(); | 
| 191 | is($code, WARNING, "(WARNING) code is $STATUS_TEXT{$code}"); | 191 | is($code, WARNING, "(WARNING) code is $STATUS_TEXT{$code}"); | 
| 192 | is($message, $messages{warning}, "(WARNING) message is $message"); | 192 | is($message, $messages{warning}, "(WARNING) message is $message"); | 
| 193 | 193 | ||
| 194 | $np = Nagios::Plugin->new(); | 194 | $np = Monitoring::Plugin->new(); | 
| 195 | $np->add_message( WARNING, "D E F" ); | 195 | $np->add_message( WARNING, "D E F" ); | 
| 196 | $np->add_message( OK, "G H I" ); | 196 | $np->add_message( OK, "G H I" ); | 
| 197 | ($code, $message) = $np->check_messages(); | 197 | ($code, $message) = $np->check_messages(); | 
| 198 | is($code, WARNING, "(WARNING, OK) code is $STATUS_TEXT{$code}"); | 198 | is($code, WARNING, "(WARNING, OK) code is $STATUS_TEXT{$code}"); | 
| 199 | is($message, $messages{warning}, "(WARNING, OK) message is $message"); | 199 | is($message, $messages{warning}, "(WARNING, OK) message is $message"); | 
| 200 | 200 | ||
| 201 | $np = Nagios::Plugin->new(); | 201 | $np = Monitoring::Plugin->new(); | 
| 202 | $np->add_message( OK, "G H I" ); | 202 | $np->add_message( OK, "G H I" ); | 
| 203 | ($code, $message) = $np->check_messages(); | 203 | ($code, $message) = $np->check_messages(); | 
| 204 | is($code, OK, "(OK) code is $STATUS_TEXT{$code}"); | 204 | is($code, OK, "(OK) code is $STATUS_TEXT{$code}"); | 
| @@ -206,33 +206,33 @@ is($message, $messages{ok}, "(OK) message is $message"); | |||
| 206 | 206 | ||
| 207 | 207 | ||
| 208 | # String codes | 208 | # String codes | 
| 209 | $np = Nagios::Plugin->new(); | 209 | $np = Monitoring::Plugin->new(); | 
| 210 | $np->add_message( critical => "A B C" ); | 210 | $np->add_message( critical => "A B C" ); | 
| 211 | $np->add_message( warning => "D E F" ); | 211 | $np->add_message( warning => "D E F" ); | 
| 212 | ($code, $message) = $np->check_messages(); | 212 | ($code, $message) = $np->check_messages(); | 
| 213 | is($code, CRITICAL, "(critical, warning) code is $STATUS_TEXT{$code}"); | 213 | is($code, CRITICAL, "(critical, warning) code is $STATUS_TEXT{$code}"); | 
| 214 | is($message, $messages{critical}, "(critical, warning) message is $message"); | 214 | is($message, $messages{critical}, "(critical, warning) message is $message"); | 
| 215 | 215 | ||
| 216 | $np = Nagios::Plugin->new(); | 216 | $np = Monitoring::Plugin->new(); | 
| 217 | $np->add_message( critical => "A B C" ); | 217 | $np->add_message( critical => "A B C" ); | 
| 218 | ($code, $message) = $np->check_messages(); | 218 | ($code, $message) = $np->check_messages(); | 
| 219 | is($code, CRITICAL, "(critical) code is $STATUS_TEXT{$code}"); | 219 | is($code, CRITICAL, "(critical) code is $STATUS_TEXT{$code}"); | 
| 220 | is($message, $messages{critical}, "(critical) message is $message"); | 220 | is($message, $messages{critical}, "(critical) message is $message"); | 
| 221 | 221 | ||
| 222 | $np = Nagios::Plugin->new(); | 222 | $np = Monitoring::Plugin->new(); | 
| 223 | $np->add_message( warning => "D E F" ); | 223 | $np->add_message( warning => "D E F" ); | 
| 224 | ($code, $message) = $np->check_messages(); | 224 | ($code, $message) = $np->check_messages(); | 
| 225 | is($code, WARNING, "(warning) code is $STATUS_TEXT{$code}"); | 225 | is($code, WARNING, "(warning) code is $STATUS_TEXT{$code}"); | 
| 226 | is($message, $messages{warning}, "(warning) message is $message"); | 226 | is($message, $messages{warning}, "(warning) message is $message"); | 
| 227 | 227 | ||
| 228 | $np = Nagios::Plugin->new(); | 228 | $np = Monitoring::Plugin->new(); | 
| 229 | $np->add_message( warning => "D E F" ); | 229 | $np->add_message( warning => "D E F" ); | 
| 230 | $np->add_message( ok => "G H I" ); | 230 | $np->add_message( ok => "G H I" ); | 
| 231 | ($code, $message) = $np->check_messages(); | 231 | ($code, $message) = $np->check_messages(); | 
| 232 | is($code, WARNING, "(warning, ok) code is $STATUS_TEXT{$code}"); | 232 | is($code, WARNING, "(warning, ok) code is $STATUS_TEXT{$code}"); | 
| 233 | is($message, $messages{warning}, "(warning, ok) message is $message"); | 233 | is($message, $messages{warning}, "(warning, ok) message is $message"); | 
| 234 | 234 | ||
| 235 | $np = Nagios::Plugin->new(); | 235 | $np = Monitoring::Plugin->new(); | 
| 236 | $np->add_message( ok => "G H I" ); | 236 | $np->add_message( ok => "G H I" ); | 
| 237 | ($code, $message) = $np->check_messages(); | 237 | ($code, $message) = $np->check_messages(); | 
| 238 | is($code, OK, "(ok) code is $STATUS_TEXT{$code}"); | 238 | is($code, OK, "(ok) code is $STATUS_TEXT{$code}"); | 
| @@ -240,7 +240,7 @@ is($message, $messages{ok}, "(ok) message is $message"); | |||
| 240 | 240 | ||
| 241 | 241 | ||
| 242 | # No add_message | 242 | # No add_message | 
| 243 | $np = Nagios::Plugin->new(); | 243 | $np = Monitoring::Plugin->new(); | 
| 244 | ($code, $message) = $np->check_messages(); | 244 | ($code, $message) = $np->check_messages(); | 
| 245 | is($code, OK, "() code is $STATUS_TEXT{$code}"); | 245 | is($code, OK, "() code is $STATUS_TEXT{$code}"); | 
| 246 | is($message, '', "() message is ''"); | 246 | is($message, '', "() message is ''"); | 
| @@ -250,14 +250,13 @@ is($message, '', "() message is ''"); | |||
| 250 | # Error conditions | 250 | # Error conditions | 
| 251 | 251 | ||
| 252 | # add_message errors | 252 | # add_message errors | 
| 253 | $np = Nagios::Plugin->new(); | 253 | $np = Monitoring::Plugin->new(); | 
| 254 | ok(! defined eval { $np->add_message( foobar => 'hi mum' ) }, | 254 | ok(! defined eval { $np->add_message( foobar => 'hi mum' ) }, | 
| 255 | 'add_message dies on invalid code'); | 255 | 'add_message dies on invalid code'); | 
| 256 | ok(! defined eval { $np->add_message( OKAY => 'hi mum' ) }, | 256 | ok(! defined eval { $np->add_message( OKAY => 'hi mum' ) }, | 
| 257 | 'add_message dies on invalid code'); | 257 | 'add_message dies on invalid code'); | 
| 258 | # UNKNOWN and DEPENDENT error codes | 258 | # UNKNOWN and DEPENDENT error codes | 
| 259 | ok(! defined eval { $np->add_message( unknown => 'hi mum' ) }, | 259 | ok(! defined eval { $np->add_message( unknown => 'hi mum' ) }, | 
| 260 | 'add_message dies on UNKNOWN code'); | 260 | 'add_message dies on UNKNOWN code'); | 
| 261 | ok(! defined eval { $np->add_message( dependent => 'hi mum' ) }, | 261 | ok(! defined eval { $np->add_message( dependent => 'hi mum' ) }, | 
| 262 | 'add_message dies on DEPENDENT code'); | 262 | 'add_message dies on DEPENDENT code'); | 
| 263 | |||
| diff --git a/t/Nagios-Plugin-04.t b/t/Monitoring-Plugin-04.t index e5eb3ab..41027f7 100644 --- a/t/Nagios-Plugin-04.t +++ b/t/Monitoring-Plugin-04.t | |||
| @@ -5,25 +5,25 @@ use strict; | |||
| 5 | #use Test::More 'no_plan'; | 5 | #use Test::More 'no_plan'; | 
| 6 | use Test::More tests=>30; | 6 | use Test::More tests=>30; | 
| 7 | 7 | ||
| 8 | BEGIN { use_ok('Nagios::Plugin') }; | 8 | BEGIN { use_ok('Monitoring::Plugin') }; | 
| 9 | use Nagios::Plugin::Functions; | 9 | use Monitoring::Plugin::Functions; | 
| 10 | Nagios::Plugin::Functions::_fake_exit(1); | 10 | Monitoring::Plugin::Functions::_fake_exit(1); | 
| 11 | 11 | ||
| 12 | 12 | ||
| 13 | eval { Nagios::Plugin->new(); }; | 13 | eval { Monitoring::Plugin->new(); }; | 
| 14 | ok(! $@, "constructor DOESN'T die without usage"); | 14 | ok(! $@, "constructor DOESN'T die without usage"); | 
| 15 | 15 | ||
| 16 | my $p = Nagios::Plugin->new(); | 16 | my $p = Monitoring::Plugin->new(); | 
| 17 | eval { $p->add_arg('warning', 'warning') }; | 17 | eval { $p->add_arg('warning', 'warning') }; | 
| 18 | ok($@, "add_arg() dies if you haven't instantiated with usage"); | 18 | ok($@, "add_arg() dies if you haven't instantiated with usage"); | 
| 19 | eval { $p->getopts }; | 19 | eval { $p->getopts }; | 
| 20 | ok($@, "getopts() dies if you haven't instantiated with usage"); | 20 | ok($@, "getopts() dies if you haven't instantiated with usage"); | 
| 21 | 21 | ||
| 22 | $p = Nagios::Plugin->new( usage => "dummy usage statement" ); | 22 | $p = Monitoring::Plugin->new( usage => "dummy usage statement" ); | 
| 23 | 23 | ||
| 24 | # option accessors work | 24 | # option accessors work | 
| 25 | can_ok $p, 'opts'; | 25 | can_ok $p, 'opts'; | 
| 26 | isa_ok $p->opts, 'Nagios::Plugin::Getopt', "Getopt object is defined"; | 26 | isa_ok $p->opts, 'Monitoring::Plugin::Getopt', "Getopt object is defined"; | 
| 27 | 27 | ||
| 28 | $p->add_arg('warning|w=s', "warning"); | 28 | $p->add_arg('warning|w=s', "warning"); | 
| 29 | $p->add_arg('critical|c=s', "critical"); | 29 | $p->add_arg('critical|c=s', "critical"); | 
| @@ -35,11 +35,11 @@ is $p->opts->critical, "10", "critical opt is accessible"; | |||
| 35 | 35 | ||
| 36 | 36 | ||
| 37 | can_ok $p, 'perfdata'; | 37 | can_ok $p, 'perfdata'; | 
| 38 | #isa_ok $p->perfdata, 'Nagios::Plugin::Performance', "perfdata object is defined"; | 38 | #isa_ok $p->perfdata, 'Monitoring::Plugin::Performance', "perfdata object is defined"; | 
| 39 | 39 | ||
| 40 | 40 | ||
| 41 | can_ok $p, 'threshold'; | 41 | can_ok $p, 'threshold'; | 
| 42 | #isa_ok $p->threshold, 'Nagios::Plugin::Threshold', "threshold object is defined"; | 42 | #isa_ok $p->threshold, 'Monitoring::Plugin::Threshold', "threshold object is defined"; | 
| 43 | 43 | ||
| 44 | 44 | ||
| 45 | eval { $p->check_threshold() }; | 45 | eval { $p->check_threshold() }; | 
| @@ -60,20 +60,20 @@ is $p->check_threshold(check=>[1,2,6,11]), CRITICAL, "check_threshold CRITICAL w | |||
| 60 | 60 | ||
| 61 | # thresholds set explicitly | 61 | # thresholds set explicitly | 
| 62 | is $p->check_threshold( | 62 | is $p->check_threshold( | 
| 63 | check => 2, | 63 | check => 2, | 
| 64 | warning => 50, | 64 | warning => 50, | 
| 65 | critical => 100 | 65 | critical => 100 | 
| 66 | ), OK, "check_threshold explicit OK"; | 66 | ), OK, "check_threshold explicit OK"; | 
| 67 | 67 | ||
| 68 | is $p->check_threshold( | 68 | is $p->check_threshold( | 
| 69 | check => 66, | 69 | check => 66, | 
| 70 | warning => 50, | 70 | warning => 50, | 
| 71 | critical => 100 | 71 | critical => 100 | 
| 72 | ), WARNING, "check_threshold explicit WARNING"; | 72 | ), WARNING, "check_threshold explicit WARNING"; | 
| 73 | 73 | ||
| 74 | 74 | ||
| 75 | is $p->check_threshold( | 75 | is $p->check_threshold( | 
| 76 | check => -1, | 76 | check => -1, | 
| 77 | warning => 5, | 77 | warning => 5, | 
| 78 | critical => '0:5', | 78 | critical => '0:5', | 
| 79 | ), CRITICAL, "check_threshold explicit CRITICAL"; | 79 | ), CRITICAL, "check_threshold explicit CRITICAL"; | 
| @@ -82,7 +82,7 @@ is $p->check_threshold( | |||
| 82 | 82 | ||
| 83 | # what happens if you forget to define warning or critical thresholds? | 83 | # what happens if you forget to define warning or critical thresholds? | 
| 84 | $p = undef; | 84 | $p = undef; | 
| 85 | $p = Nagios::Plugin->new(); | 85 | $p = Monitoring::Plugin->new(); | 
| 86 | 86 | ||
| 87 | is $p->check_threshold(2), UNKNOWN, "everything is now UNKNOWN"; | 87 | is $p->check_threshold(2), UNKNOWN, "everything is now UNKNOWN"; | 
| 88 | is $p->check_threshold(-200), UNKNOWN, "everything is now UNKNOWN"; | 88 | is $p->check_threshold(-200), UNKNOWN, "everything is now UNKNOWN"; | 
| diff --git a/t/Nagios-Plugin-05.t b/t/Monitoring-Plugin-05.t index cc602cc..d17464f 100644 --- a/t/Nagios-Plugin-05.t +++ b/t/Monitoring-Plugin-05.t | |||
| @@ -1,16 +1,15 @@ | |||
| 1 | # Check for exported vars | 1 | # Check for exported vars | 
| 2 | # Can't include Nagios::Plugin::Functions because it also exports %STATUS_TEXT | 2 | # Can't include Monitoring::Plugin::Functions because it also exports %STATUS_TEXT | 
| 3 | 3 | ||
| 4 | use strict; | 4 | use strict; | 
| 5 | use Test::More tests=>4; | 5 | use Test::More tests=>4; | 
| 6 | 6 | ||
| 7 | BEGIN { use_ok('Nagios::Plugin') }; | 7 | BEGIN { use_ok('Monitoring::Plugin') }; | 
| 8 | 8 | ||
| 9 | eval ' $_ = $STATUS_TEXT{0} '; | 9 | eval ' $_ = $STATUS_TEXT{0} '; | 
| 10 | like( $@, '/Global symbol "%STATUS_TEXT" requires explicit package name/' ); | 10 | like( $@, '/Global symbol "%STATUS_TEXT" requires explicit package name/' ); | 
| 11 | 11 | ||
| 12 | use_ok("Nagios::Plugin", qw(%STATUS_TEXT)); | 12 | use_ok("Monitoring::Plugin", qw(%STATUS_TEXT)); | 
| 13 | 13 | ||
| 14 | eval ' $_ = $STATUS_TEXT{0} '; | 14 | eval ' $_ = $STATUS_TEXT{0} '; | 
| 15 | is( $@, '' ); | 15 | is( $@, '' ); | 
| 16 | |||
| diff --git a/t/Monitoring-Plugin-Functions-01.t b/t/Monitoring-Plugin-Functions-01.t new file mode 100644 index 0000000..084ad28 --- /dev/null +++ b/t/Monitoring-Plugin-Functions-01.t | |||
| @@ -0,0 +1,161 @@ | |||
| 1 | |||
| 2 | use strict; | ||
| 3 | use Test::More tests => 113; | ||
| 4 | |||
| 5 | BEGIN { use_ok("Monitoring::Plugin::Functions", ":all"); } | ||
| 6 | Monitoring::Plugin::Functions::_fake_exit(1); | ||
| 7 | |||
| 8 | my $this_version=$Monitoring::Plugin::Functions::VERSION; | ||
| 9 | foreach my $m ("", qw(::Threshold ::Getopt ::Performance ::Range)) { | ||
| 10 | my $mod = "Monitoring::Plugin$m"; | ||
| 11 | use_ok($mod); | ||
| 12 | # Lots of hackery below. Easier to say $mod->VERSION, but this is probably a recent perl thing | ||
| 13 | my $v = "$mod"."::VERSION"; | ||
| 14 | my $a = eval "\$$v"; | ||
| 15 | is($a, $this_version, "Version number for $mod the same as Functions: $this_version"); | ||
| 16 | } | ||
| 17 | |||
| 18 | # check get_shortname | ||
| 19 | is(get_shortname, "MONITORING-PLUGIN-FUNCTIONS-01", "get_shortname ok"); | ||
| 20 | |||
| 21 | # Hardcoded checks of constants | ||
| 22 | ok(%ERRORS, '%ERRORS defined'); | ||
| 23 | is(OK, $ERRORS{OK}, "OK => $ERRORS{OK}"); | ||
| 24 | is(WARNING, $ERRORS{WARNING}, "WARNING => $ERRORS{WARNING}"); | ||
| 25 | is(CRITICAL, $ERRORS{CRITICAL}, "CRITICAL => $ERRORS{CRITICAL}"); | ||
| 26 | is(UNKNOWN, $ERRORS{UNKNOWN}, "UNKNOWN => $ERRORS{UNKNOWN}"); | ||
| 27 | is(DEPENDENT, $ERRORS{DEPENDENT}, "DEPENDENT => $ERRORS{DEPENDENT}"); | ||
| 28 | |||
| 29 | # Test plugin_exit( CONSTANT, $msg ), plugin_exit( $string, $msg ) | ||
| 30 | my $r; | ||
| 31 | my @ok = ( | ||
| 32 | [ OK, "OK", 'test the first', ], | ||
| 33 | [ WARNING, "WARNING", 'test the second', ], | ||
| 34 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 35 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 36 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 37 | ); | ||
| 38 | for (@ok) { | ||
| 39 | # CONSTANT | ||
| 40 | $r = plugin_exit($_->[0], $_->[2]); | ||
| 41 | is($r->return_code, $_->[0], | ||
| 42 | sprintf('plugin_exit(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 43 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 44 | sprintf('plugin_exit(%s, $msg) output matched "%s"', | ||
| 45 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 46 | |||
| 47 | # $string | ||
| 48 | $r = plugin_exit($_->[1], $_->[2]); | ||
| 49 | is($r->return_code, $_->[0], | ||
| 50 | sprintf('plugin_exit("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 51 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 52 | sprintf('plugin_exit("%s", $msg) output matched "%s"', $_->[1], | ||
| 53 | $_->[1] . '.*' . $_->[2])); | ||
| 54 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 55 | sprintf('plugin_exit("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 56 | $_->[1] . '.*' . $_->[2])); | ||
| 57 | } | ||
| 58 | |||
| 59 | # plugin_exit code corner cases | ||
| 60 | my @ugly1 = ( | ||
| 61 | [ -1, 'testing code -1' ], | ||
| 62 | [ 7, 'testing code 7' ], | ||
| 63 | [ undef, 'testing code undef' ], | ||
| 64 | [ '', qq(testing code '') ], | ||
| 65 | [ 'string', qq(testing code 'string') ], | ||
| 66 | ); | ||
| 67 | for (@ugly1) { | ||
| 68 | $r = plugin_exit($_->[0], $_->[1]); | ||
| 69 | my $display = defined $_->[0] ? "'$_->[0]'" : 'undef'; | ||
| 70 | is($r->return_code, UNKNOWN, "plugin_exit($display, \$msg) returned ". UNKNOWN); | ||
| 71 | like($r->message, qr/UNKNOWN\b.*\b$_->[1]$/, | ||
| 72 | sprintf('plugin_exit(%s, $msg) output matched "%s"', | ||
| 73 | $display, 'UNKNOWN.*' . $_->[1])); | ||
| 74 | } | ||
| 75 | |||
| 76 | # plugin_exit message corner cases | ||
| 77 | my @ugly2 = ( | ||
| 78 | [ '' ], | ||
| 79 | [ undef ], | ||
| 80 | [ UNKNOWN ], | ||
| 81 | ); | ||
| 82 | for (@ugly2) { | ||
| 83 | $r = plugin_exit(CRITICAL, $_->[0]); | ||
| 84 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 85 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 86 | like($r->message, qr/CRITICAL\b.*\b$display2$/, | ||
| 87 | sprintf('plugin_exit(%s, $msg) output matched "%s"', | ||
| 88 | $display1, "CRITICAL.*$display2")); | ||
| 89 | } | ||
| 90 | |||
| 91 | # Test plugin_die( $msg ) | ||
| 92 | my @msg = ( | ||
| 93 | [ 'die you dog' ], | ||
| 94 | [ '' ], | ||
| 95 | [ undef ], | ||
| 96 | ); | ||
| 97 | for (@msg) { | ||
| 98 | $r = plugin_die($_->[0]); | ||
| 99 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 100 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 101 | is($r->return_code, UNKNOWN, | ||
| 102 | sprintf('plugin_die(%s) returned UNKNOWN', $display1)); | ||
| 103 | like($r->message, qr/UNKNOWN\b.*\b$display2$/, | ||
| 104 | sprintf('plugin_die(%s) output matched "%s"', $display1, | ||
| 105 | "UNKNOWN.*$display2")); | ||
| 106 | } | ||
| 107 | |||
| 108 | # Test plugin_die( CONSTANT, $msg ), plugin_die( $msg, CONSTANT ), | ||
| 109 | # plugin_die( $string, $msg ), and plugin_die( $msg, $string ) | ||
| 110 | @ok = ( | ||
| 111 | [ OK, "OK", 'test the first', ], | ||
| 112 | [ WARNING, "WARNING", 'test the second', ], | ||
| 113 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 114 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 115 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 116 | ); | ||
| 117 | for (@ok) { | ||
| 118 | # CONSTANT, $msg | ||
| 119 | $r = plugin_die($_->[0], $_->[2]); | ||
| 120 | is($r->return_code, $_->[0], | ||
| 121 | sprintf('plugin_die(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 122 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 123 | sprintf('plugin_die(%s, $msg) output matched "%s"', | ||
| 124 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 125 | |||
| 126 | # $msg, CONSTANT | ||
| 127 | $r = plugin_die($_->[2], $_->[0]); | ||
| 128 | is($r->return_code, $_->[0], | ||
| 129 | sprintf('plugin_die($msg, %s) returned %s', $_->[1], $_->[0])); | ||
| 130 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 131 | sprintf('plugin_die($msg, %s) output matched "%s"', | ||
| 132 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 133 | |||
| 134 | # $string, $msg | ||
| 135 | $r = plugin_die($_->[1], $_->[2]); | ||
| 136 | is($r->return_code, $_->[0], | ||
| 137 | sprintf('plugin_die("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 138 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 139 | sprintf('plugin_die("%s", $msg) output matched "%s"', $_->[1], | ||
| 140 | $_->[1] . '.*' . $_->[2])); | ||
| 141 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 142 | sprintf('plugin_die("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 143 | $_->[1] . '.*' . $_->[2])); | ||
| 144 | |||
| 145 | # $string, $msg | ||
| 146 | $r = plugin_die($_->[2], $_->[1]); | ||
| 147 | is($r->return_code, $_->[0], | ||
| 148 | sprintf('plugin_die($msg, "%s") returned %s', $_->[1], $_->[0])); | ||
| 149 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 150 | sprintf('plugin_die($msg, "%s") output matched "%s"', $_->[1], | ||
| 151 | $_->[1] . '.*' . $_->[2])); | ||
| 152 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 153 | sprintf('plugin_die($msg, "%s") stringified matched "%s"', $_->[1], | ||
| 154 | $_->[1] . '.*' . $_->[2])); | ||
| 155 | } | ||
| 156 | |||
| 157 | # Check that _use_die set to 1 will catch exceptions correctly | ||
| 158 | Monitoring::Plugin::Functions::_fake_exit(0); | ||
| 159 | Monitoring::Plugin::Functions::_use_die(1); | ||
| 160 | eval { plugin_die("Using die") }; | ||
| 161 | is( $@, "MONITORING-PLUGIN-FUNCTIONS-01 UNKNOWN - Using die\n", "Caught exception"); | ||
| diff --git a/t/Nagios-Plugin-Functions-02.t b/t/Monitoring-Plugin-Functions-02.t index 1a9351b..3796210 100644 --- a/t/Nagios-Plugin-Functions-02.t +++ b/t/Monitoring-Plugin-Functions-02.t | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More tests => 37; | 4 | use Test::More tests => 37; | 
| 5 | 5 | ||
| 6 | BEGIN { use_ok("Nagios::Plugin::Functions", ":all") } | 6 | BEGIN { use_ok("Monitoring::Plugin::Functions", ":all") } | 
| 7 | 7 | ||
| 8 | my ($code, $message); | 8 | my ($code, $message); | 
| 9 | 9 | ||
| @@ -105,11 +105,11 @@ is($message, join(' ', @{$arrays{ok}}), "joined undef (ok) message is $message") | |||
| 105 | # ------------------------------------------------------------------------- | 105 | # ------------------------------------------------------------------------- | 
| 106 | # join_all messages | 106 | # join_all messages | 
| 107 | my $join_all = ' :: '; | 107 | my $join_all = ' :: '; | 
| 108 | my $msg_all_cwo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 108 | my $msg_all_cwo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 109 | qw(critical warning ok)); | 109 | qw(critical warning ok)); | 
| 110 | my $msg_all_cw = join($join_all, map { join(' ', @{$arrays{$_}}) } | 110 | my $msg_all_cw = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 111 | qw(critical warning)); | 111 | qw(critical warning)); | 
| 112 | my $msg_all_wo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 112 | my $msg_all_wo = join($join_all, map { join(' ', @{$arrays{$_}}) } | 
| 113 | qw(warning ok)); | 113 | qw(warning ok)); | 
| 114 | 114 | ||
| 115 | # critical, warning, ok | 115 | # critical, warning, ok | 
| @@ -175,4 +175,3 @@ ok(! defined eval { ($code, $message) = check_messages(critical => $arrays{criti | |||
| 175 | 175 | ||
| 176 | ok(defined eval { ($code, $message) = check_messages(critical => $arrays{critical}, warning => $arrays{warning}) }, | 176 | ok(defined eval { ($code, $message) = check_messages(critical => $arrays{critical}, warning => $arrays{warning}) }, | 
| 177 | "check_messages ok with 'critical' and 'warning' messages"); | 177 | "check_messages ok with 'critical' and 'warning' messages"); | 
| 178 | |||
| diff --git a/t/Nagios-Plugin-Functions-03.t b/t/Monitoring-Plugin-Functions-03.t index 3706e4c..9f0a62c 100644 --- a/t/Nagios-Plugin-Functions-03.t +++ b/t/Monitoring-Plugin-Functions-03.t | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More tests => 8; | 4 | use Test::More tests => 8; | 
| 5 | 5 | ||
| 6 | BEGIN { use_ok("Nagios::Plugin::Functions", ":all") } | 6 | BEGIN { use_ok("Monitoring::Plugin::Functions", ":all") } | 
| 7 | 7 | ||
| 8 | my $new_state = max_state( OK, WARNING ); | 8 | my $new_state = max_state( OK, WARNING ); | 
| 9 | 9 | ||
| diff --git a/t/Nagios-Plugin-Functions-04.t b/t/Monitoring-Plugin-Functions-04.t index d3ff05c..0a7c4e4 100644 --- a/t/Nagios-Plugin-Functions-04.t +++ b/t/Monitoring-Plugin-Functions-04.t | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More tests => 8; | 4 | use Test::More tests => 8; | 
| 5 | 5 | ||
| 6 | BEGIN { use_ok("Nagios::Plugin::Functions", ":all") } | 6 | BEGIN { use_ok("Monitoring::Plugin::Functions", ":all") } | 
| 7 | 7 | ||
| 8 | my $new_state = max_state_alt( OK, WARNING ); | 8 | my $new_state = max_state_alt( OK, WARNING ); | 
| 9 | 9 | ||
| diff --git a/t/Nagios-Plugin-Getopt-01.t b/t/Monitoring-Plugin-Getopt-01.t index 7076d75..36f1f55 100644 --- a/t/Nagios-Plugin-Getopt-01.t +++ b/t/Monitoring-Plugin-Getopt-01.t | |||
| @@ -1,33 +1,33 @@ | |||
| 1 | # Nagios::Plugin::Getopt basic tests | 1 | # Monitoring::Plugin::Getopt basic tests | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | 4 | ||
| 5 | use Test::More tests => 76; | 5 | use Test::More tests => 76; | 
| 6 | BEGIN { use_ok('Nagios::Plugin::Getopt') }; | 6 | BEGIN { use_ok('Monitoring::Plugin::Getopt') }; | 
| 7 | 7 | ||
| 8 | # Needed to get evals to work in testing | 8 | # Needed to get evals to work in testing | 
| 9 | Nagios::Plugin::Functions::_use_die(1); | 9 | Monitoring::Plugin::Functions::_use_die(1); | 
| 10 | 10 | ||
| 11 | my %PARAM = ( | 11 | my %PARAM = ( | 
| 12 | version => '0.01', | 12 | version => '0.01', | 
| 13 | url => 'http://www.openfusion.com.au/labs/nagios/', | 13 | url => 'http://www.openfusion.com.au/labs/nagios/', | 
| 14 | blurb => 'This plugin tests various stuff.', | 14 | blurb => 'This plugin tests various stuff.', | 
| 15 | usage => "Usage: %s -H <host> -w <warning_threshold> | 15 | usage => "Usage: %s -H <host> -w <warning_threshold> | 
| 16 | -c <critical threshold>", | 16 | -c <critical threshold>", | 
| 17 | plugin => 'test_plugin', | 17 | plugin => 'test_plugin', | 
| 18 | ); | 18 | ); | 
| 19 | 19 | ||
| 20 | sub setup | 20 | sub setup | 
| 21 | { | 21 | { | 
| 22 | # Instantiate object | 22 | # Instantiate object | 
| 23 | my $ng = Nagios::Plugin::Getopt->new(%PARAM); | 23 | my $ng = Monitoring::Plugin::Getopt->new(%PARAM); | 
| 24 | ok($ng, 'constructor ok'); | 24 | ok($ng, 'constructor ok'); | 
| 25 | 25 | ||
| 26 | # Add argument - short form - arg spec, help text, default, required? | 26 | # Add argument - short form - arg spec, help text, default, required? | 
| 27 | $ng->arg('warning|w=s' => | 27 | $ng->arg('warning|w=s' => | 
| 28 | qq(-w, --warning=INTEGER\n Exit with WARNING status if less than INTEGER foobars are free), | 28 | qq(-w, --warning=INTEGER\n Exit with WARNING status if less than INTEGER foobars are free), | 
| 29 | 5); | 29 | 5); | 
| 30 | 30 | ||
| 31 | # Add argument - named version | 31 | # Add argument - named version | 
| 32 | $ng->arg( | 32 | $ng->arg( | 
| 33 | spec => 'critical|c=i', | 33 | spec => 'critical|c=i', | 
| @@ -147,4 +147,3 @@ like($@, qr/--verbose/, 'help includes default options 2'); | |||
| 147 | like($@, qr/--warning/, 'help includes custom option 1'); | 147 | like($@, qr/--warning/, 'help includes custom option 1'); | 
| 148 | like($@, qr/-c, --critical=INTEGER/, 'help includes custom option 2, with expanded args'); | 148 | like($@, qr/-c, --critical=INTEGER/, 'help includes custom option 2, with expanded args'); | 
| 149 | unlike($@, qr/Missing arg/, 'no missing arguments'); | 149 | unlike($@, qr/Missing arg/, 'no missing arguments'); | 
| 150 | |||
| diff --git a/t/Nagios-Plugin-Getopt-02.t b/t/Monitoring-Plugin-Getopt-02.t index f83b180..c6c563e 100644 --- a/t/Nagios-Plugin-Getopt-02.t +++ b/t/Monitoring-Plugin-Getopt-02.t | |||
| @@ -1,27 +1,27 @@ | |||
| 1 | # Nagios::Plugin::Getopt timeout tests | 1 | # Monitoring::Plugin::Getopt timeout tests | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | 4 | ||
| 5 | use Test::More tests => 14; | 5 | use Test::More tests => 14; | 
| 6 | BEGIN { use_ok('Nagios::Plugin::Getopt') }; | 6 | BEGIN { use_ok('Monitoring::Plugin::Getopt') }; | 
| 7 | 7 | ||
| 8 | # Needed to get evals to work in testing | 8 | # Needed to get evals to work in testing | 
| 9 | Nagios::Plugin::Functions::_use_die(1); | 9 | Monitoring::Plugin::Functions::_use_die(1); | 
| 10 | 10 | ||
| 11 | my %PARAM = ( | 11 | my %PARAM = ( | 
| 12 | version => '0.01', | 12 | version => '0.01', | 
| 13 | url => 'http://www.openfusion.com.au/labs/nagios/', | 13 | url => 'http://www.openfusion.com.au/labs/nagios/', | 
| 14 | blurb => 'This plugin tests various stuff.', | 14 | blurb => 'This plugin tests various stuff.', | 
| 15 | usage => "Usage: %s -H <host> -w <warning_threshold> | 15 | usage => "Usage: %s -H <host> -w <warning_threshold> | 
| 16 | -c <critical threshold>", | 16 | -c <critical threshold>", | 
| 17 | plugin => 'test_plugin', | 17 | plugin => 'test_plugin', | 
| 18 | timeout => 18, | 18 | timeout => 18, | 
| 19 | ); | 19 | ); | 
| 20 | 20 | ||
| 21 | sub setup | 21 | sub setup | 
| 22 | { | 22 | { | 
| 23 | # Instantiate object | 23 | # Instantiate object | 
| 24 | my $ng = Nagios::Plugin::Getopt->new(%PARAM); | 24 | my $ng = Monitoring::Plugin::Getopt->new(%PARAM); | 
| 25 | ok($ng, 'constructor ok'); | 25 | ok($ng, 'constructor ok'); | 
| 26 | return $ng; | 26 | return $ng; | 
| 27 | } | 27 | } | 
| @@ -61,4 +61,3 @@ alarm($ng->timeout); | |||
| 61 | # Loop | 61 | # Loop | 
| 62 | ok(! defined eval { 1 while 1 }, 'loop timed out'); | 62 | ok(! defined eval { 1 while 1 }, 'loop timed out'); | 
| 63 | like($@, qr/UNKNOWN\b.*\btimed out/, 'default timeout handler ok'); | 63 | like($@, qr/UNKNOWN\b.*\btimed out/, 'default timeout handler ok'); | 
| 64 | |||
| diff --git a/t/Nagios-Plugin-Getopt-03.t b/t/Monitoring-Plugin-Getopt-03.t index 560b782..6490145 100644 --- a/t/Nagios-Plugin-Getopt-03.t +++ b/t/Monitoring-Plugin-Getopt-03.t | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | # Nagios::Plugin::Getopt --extra-opts tests | 1 | # Monitoring::Plugin::Getopt --extra-opts tests | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | use File::Spec; | 4 | use File::Spec; | 
| @@ -6,15 +6,15 @@ use File::Basename; | |||
| 6 | use IO::File; | 6 | use IO::File; | 
| 7 | 7 | ||
| 8 | use Test::More qw(no_plan); | 8 | use Test::More qw(no_plan); | 
| 9 | BEGIN { use_ok('Nagios::Plugin::Getopt') }; | 9 | BEGIN { use_ok('Monitoring::Plugin::Getopt') }; | 
| 10 | 10 | ||
| 11 | # Needed to get evals to work in testing | 11 | # Needed to get evals to work in testing | 
| 12 | Nagios::Plugin::Functions::_use_die(1); | 12 | Monitoring::Plugin::Functions::_use_die(1); | 
| 13 | 13 | ||
| 14 | my $tdir = 'npg03'; | 14 | my $tdir = 'npg03'; | 
| 15 | if (! -d $tdir) { | 15 | if (! -d $tdir) { | 
| 16 | my $ttdir = File::Spec->catdir('t', $tdir); | 16 | my $ttdir = File::Spec->catdir('t', $tdir); | 
| 17 | die "missing '$tdir' directory\n" unless -d $ttdir; | 17 | die "missing '$tdir' directory\n" unless -d $ttdir; | 
| 18 | $tdir = $ttdir; | 18 | $tdir = $ttdir; | 
| 19 | } | 19 | } | 
| 20 | 20 | ||
| @@ -30,22 +30,22 @@ for my $efile (glob File::Spec->catfile($tdir, 'expected', '*')) { | |||
| 30 | } | 30 | } | 
| 31 | } | 31 | } | 
| 32 | 32 | ||
| 33 | # Override NAGIOS_CONFIG_PATH to use our test plugins.ini file | 33 | # Override MONITORING_CONFIG_PATH to use our test plugins.ini file | 
| 34 | $ENV{NAGIOS_CONFIG_PATH} = "/random/bogus/path:$tdir"; | 34 | $ENV{MONITORING_CONFIG_PATH} = "/random/bogus/path:$tdir"; | 
| 35 | 35 | ||
| 36 | my %PARAM = ( | 36 | my %PARAM = ( | 
| 37 | version => '0.01', | 37 | version => '0.01', | 
| 38 | blurb => 'This plugin tests various stuff.', | 38 | blurb => 'This plugin tests various stuff.', | 
| 39 | usage => "Usage: %s -H <host> -w <warning_threshold> | 39 | usage => "Usage: %s -H <host> -w <warning_threshold> | 
| 40 | -c <critical threshold>", | 40 | -c <critical threshold>", | 
| 41 | ); | 41 | ); | 
| 42 | 42 | ||
| 43 | sub ng_setup | 43 | sub ng_setup | 
| 44 | { | 44 | { | 
| 45 | my $arg = shift; | 45 | my $arg = shift; | 
| 46 | 46 | ||
| 47 | # Instantiate object | 47 | # Instantiate object | 
| 48 | my $ng = Nagios::Plugin::Getopt->new(%PARAM); | 48 | my $ng = Monitoring::Plugin::Getopt->new(%PARAM); | 
| 49 | 49 | ||
| 50 | if (ref $arg eq 'ARRAY' && @$arg) { | 50 | if (ref $arg eq 'ARRAY' && @$arg) { | 
| 51 | $ng->arg(%$_) foreach @$arg; | 51 | $ng->arg(%$_) foreach @$arg; | 
| @@ -54,7 +54,7 @@ sub ng_setup | |||
| 54 | return $ng; | 54 | return $ng; | 
| 55 | } | 55 | } | 
| 56 | 56 | ||
| 57 | # Setup our Nagios::Plugin::Getopt object | 57 | # Setup our Monitoring::Plugin::Getopt object | 
| 58 | my $ng; | 58 | my $ng; | 
| 59 | my $arg = [ | 59 | my $arg = [ | 
| 60 | { spec => 'S', help => '-S' }, | 60 | { spec => 'S', help => '-S' }, | 
| @@ -85,9 +85,9 @@ for my $infile (glob File::Spec->catfile($tdir, 'input', $glob)) { | |||
| 85 | $cmd =~ s/^\s+//; | 85 | $cmd =~ s/^\s+//; | 
| 86 | my ($plugin, @args) = split /\s+/, $cmd; | 86 | my ($plugin, @args) = split /\s+/, $cmd; | 
| 87 | 87 | ||
| 88 | # Fake out the plugin name | 88 | # Fake out the plugin name | 
| 89 | $ng->{_attr}->{plugin} = $plugin; | 89 | $ng->{_attr}->{plugin} = $plugin; | 
| 90 | 90 | ||
| 91 | # Parse the options | 91 | # Parse the options | 
| 92 | SKIP: { | 92 | SKIP: { | 
| 93 | skip "Skipping ..." if $SKIP{$infile}; | 93 | skip "Skipping ..." if $SKIP{$infile}; | 
| @@ -99,10 +99,9 @@ for my $infile (glob File::Spec->catfile($tdir, 'input', $glob)) { | |||
| 99 | ok($infile =~ m/_(dies?|catch)$/, "$infile ($@)"); | 99 | ok($infile =~ m/_(dies?|catch)$/, "$infile ($@)"); | 
| 100 | is($@, $EXPECTED{$infile}, $infile) if ($infile =~ m/_catch$/); | 100 | is($@, $EXPECTED{$infile}, $infile) if ($infile =~ m/_catch$/); | 
| 101 | } | 101 | } | 
| 102 | else { | 102 | else { | 
| 103 | is($plugin . ' ' . $ng->_cmdline, $EXPECTED{$infile}, $infile); | 103 | is($plugin . ' ' . $ng->_cmdline, $EXPECTED{$infile}, $infile); | 
| 104 | } | 104 | } | 
| 105 | } | 105 | } | 
| 106 | } | 106 | } | 
| 107 | } | 107 | } | 
| 108 | |||
| diff --git a/t/Nagios-Plugin-Getopt-04.t b/t/Monitoring-Plugin-Getopt-04.t index 115f2a2..b6345d0 100644 --- a/t/Nagios-Plugin-Getopt-04.t +++ b/t/Monitoring-Plugin-Getopt-04.t | |||
| @@ -1,29 +1,29 @@ | |||
| 1 | # Nagios::Plugin::Getopt spec-to-help generation tests | 1 | # Monitoring::Plugin::Getopt spec-to-help generation tests | 
| 2 | 2 | ||
| 3 | use strict; | 3 | use strict; | 
| 4 | 4 | ||
| 5 | use Test::More tests => 11; | 5 | use Test::More tests => 11; | 
| 6 | BEGIN { use_ok('Nagios::Plugin::Getopt') }; | 6 | BEGIN { use_ok('Monitoring::Plugin::Getopt') }; | 
| 7 | 7 | ||
| 8 | # Needed to get evals to work in testing | 8 | # Needed to get evals to work in testing | 
| 9 | Nagios::Plugin::Functions::_use_die(1); | 9 | Monitoring::Plugin::Functions::_use_die(1); | 
| 10 | 10 | ||
| 11 | my %PARAM = ( | 11 | my %PARAM = ( | 
| 12 | version => '0.01', | 12 | version => '0.01', | 
| 13 | usage => "Don't use this plugin!", | 13 | usage => "Don't use this plugin!", | 
| 14 | ); | 14 | ); | 
| 15 | 15 | ||
| 16 | sub setup | 16 | sub setup | 
| 17 | { | 17 | { | 
| 18 | # Instantiate object | 18 | # Instantiate object | 
| 19 | my $ng = Nagios::Plugin::Getopt->new(%PARAM); | 19 | my $ng = Monitoring::Plugin::Getopt->new(%PARAM); | 
| 20 | ok($ng, 'constructor ok'); | 20 | ok($ng, 'constructor ok'); | 
| 21 | 21 | ||
| 22 | # Positional args, no short arguments, INTEGER | 22 | # Positional args, no short arguments, INTEGER | 
| 23 | $ng->arg('warning=i' => | 23 | $ng->arg('warning=i' => | 
| 24 | qq(Exit with WARNING status if less than INTEGER foobars are free), | 24 | qq(Exit with WARNING status if less than INTEGER foobars are free), | 
| 25 | 5); | 25 | 5); | 
| 26 | 26 | ||
| 27 | # Named args, long + short arguments, INTEGER | 27 | # Named args, long + short arguments, INTEGER | 
| 28 | $ng->arg( | 28 | $ng->arg( | 
| 29 | spec => 'critical|c=i', | 29 | spec => 'critical|c=i', | 
| @@ -35,7 +35,7 @@ sub setup | |||
| 35 | $ng->arg( | 35 | $ng->arg( | 
| 36 | spec => 'x|y|z=s', | 36 | spec => 'x|y|z=s', | 
| 37 | help => qq(Foobar. Default: %s), | 37 | help => qq(Foobar. Default: %s), | 
| 38 | default => "XYZ", | 38 | default => "XYZ", | 
| 39 | ); | 39 | ); | 
| 40 | 40 | ||
| 41 | # Named args, multiple mixed, no label | 41 | # Named args, multiple mixed, no label | 
| @@ -95,4 +95,3 @@ like($@, qr/\n --avatar=AVATAR\n Avatar\n/, 'avatar ok'); | |||
| 95 | like($@, qr/\n --disk=BYTES\n Disk limit in BYTES\n --disk=PERCENT%\n Disk limit in PERCENT\n --disk=STRING\n Disk limit in FOOBARS \(Default: 1024\)\n/, 'disk multiline ok'); | 95 | like($@, qr/\n --disk=BYTES\n Disk limit in BYTES\n --disk=PERCENT%\n Disk limit in PERCENT\n --disk=STRING\n Disk limit in FOOBARS \(Default: 1024\)\n/, 'disk multiline ok'); | 
| 96 | like($@, qr/\n --limit=STRING\n Limit in BYTES\n --limit=PERCENT%\n Limit in PERCENT\n/, 'limit multiline ok'); | 96 | like($@, qr/\n --limit=STRING\n Limit in BYTES\n --limit=PERCENT%\n Limit in PERCENT\n/, 'limit multiline ok'); | 
| 97 | #print $@; | 97 | #print $@; | 
| 98 | |||
| diff --git a/t/Monitoring-Plugin-Performance-02.t b/t/Monitoring-Plugin-Performance-02.t new file mode 100644 index 0000000..c024685 --- /dev/null +++ b/t/Monitoring-Plugin-Performance-02.t | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | |||
| 2 | use strict; | ||
| 3 | use Test::More tests => 3; | ||
| 4 | use_ok("Monitoring::Plugin::Performance", use_die => 1); | ||
| 5 | |||
| 6 | eval { Monitoring::Plugin::Functions::plugin_die("Testing") }; | ||
| 7 | is( $@, "MONITORING-PLUGIN-PERFORMANCE-02 UNKNOWN - Testing\n", "use_die correctly set on import"); | ||
| 8 | |||
| 9 | |||
| 10 | use_ok("Monitoring::Plugin::Performance"); | ||
| 11 | eval { Monitoring::Plugin::Functions::plugin_die("Test OK exit", 0) }; | ||
| 12 | |||
| 13 | fail("Should not get here if code works correctly because prior plugin_die should have exited"); | ||
| diff --git a/t/Nagios-Plugin-Performance.t b/t/Monitoring-Plugin-Performance.t index 8dce336..bedb2e2 100644 --- a/t/Nagios-Plugin-Performance.t +++ b/t/Monitoring-Plugin-Performance.t | |||
| @@ -2,61 +2,61 @@ | |||
| 2 | use warnings; | 2 | use warnings; | 
| 3 | use strict; | 3 | use strict; | 
| 4 | use Test::More; | 4 | use Test::More; | 
| 5 | use Nagios::Plugin::Functions; | 5 | use Monitoring::Plugin::Functions; | 
| 6 | Nagios::Plugin::Functions::_fake_exit(1); | 6 | Monitoring::Plugin::Functions::_fake_exit(1); | 
| 7 | 7 | ||
| 8 | 8 | ||
| 9 | my (@p, $p); | 9 | my (@p, $p); | 
| 10 | my @test = ( | 10 | my @test = ( | 
| 11 | { | 11 | { | 
| 12 | perfoutput => "/=382MB;15264;15269;0;32768", label => '/', rrdlabel => 'root', value => 382, uom => 'MB', warning => 15264, critical => 15269, min => 0, max => 32768, clean_label => "root", | 12 | perfoutput => "/=382MB;15264;15269;0;32768", label => '/', rrdlabel => 'root', value => 382, uom => 'MB', warning => 15264, critical => 15269, min => 0, max => 32768, clean_label => "root", | 
| 13 | }, { | 13 | }, { | 
| 14 | perfoutput => "/var=218MB;9443;9448", label => '/var', rrdlabel => 'var', value => '218', uom => 'MB', warning => 9443, critical => 9448, min => undef, max => undef, clean_label => "var", | 14 | perfoutput => "/var=218MB;9443;9448", label => '/var', rrdlabel => 'var', value => '218', uom => 'MB', warning => 9443, critical => 9448, min => undef, max => undef, clean_label => "var", | 
| 15 | }, { | 15 | }, { | 
| 16 | perfoutput => '/var/long@:-/filesystem/name/and/bad/chars=218MB;9443;9448', label => '/var/long@:-/filesystem/name/and/bad/chars', rrdlabel => 'var_long____filesys', value => '218', uom => 'MB', warning => 9443, critical => 9448, min => undef, max => undef, clean_label => 'var_long____filesystem_name_and_bad_chars', | 16 | perfoutput => '/var/long@:-/filesystem/name/and/bad/chars=218MB;9443;9448', label => '/var/long@:-/filesystem/name/and/bad/chars', rrdlabel => 'var_long____filesys', value => '218', uom => 'MB', warning => 9443, critical => 9448, min => undef, max => undef, clean_label => 'var_long____filesystem_name_and_bad_chars', | 
| 17 | }, { | 17 | }, { | 
| 18 | perfoutput => "'page file'=36%;80;90;", | 18 | perfoutput => "'page file'=36%;80;90;", | 
| 19 | expected_perfoutput => "'page file'=36%;80;90", | 19 | expected_perfoutput => "'page file'=36%;80;90", | 
| 20 | label => 'page file', | 20 | label => 'page file', | 
| 21 | rrdlabel => 'page_file', | 21 | rrdlabel => 'page_file', | 
| 22 | value => '36', | 22 | value => '36', | 
| 23 | uom => '%', | 23 | uom => '%', | 
| 24 | warning => 80, | 24 | warning => 80, | 
| 25 | critical => 90, | 25 | critical => 90, | 
| 26 | min => undef, | 26 | min => undef, | 
| 27 | max => undef, | 27 | max => undef, | 
| 28 | clean_label => 'page_file', | 28 | clean_label => 'page_file', | 
| 29 | }, { | 29 | }, { | 
| 30 | perfoutput => "'data'=5;;;;", | 30 | perfoutput => "'data'=5;;;;", | 
| 31 | expected_perfoutput => "data=5;;", | 31 | expected_perfoutput => "data=5;;", | 
| 32 | label => 'data', | 32 | label => 'data', | 
| 33 | rrdlabel => 'data', | 33 | rrdlabel => 'data', | 
| 34 | value => 5, | 34 | value => 5, | 
| 35 | uom => "", | 35 | uom => "", | 
| 36 | warning => undef, | 36 | warning => undef, | 
| 37 | critical => undef, | 37 | critical => undef, | 
| 38 | min => undef, | 38 | min => undef, | 
| 39 | max => undef, | 39 | max => undef, | 
| 40 | clean_label => 'data', | 40 | clean_label => 'data', | 
| 41 | }, | 41 | }, | 
| 42 | ); | 42 | ); | 
| 43 | 43 | ||
| 44 | plan tests => (11 * scalar @test) + 176; | 44 | plan tests => (11 * scalar @test) + 176; | 
| 45 | 45 | ||
| 46 | use_ok('Nagios::Plugin::Performance'); | 46 | use_ok('Monitoring::Plugin::Performance'); | 
| 47 | diag "\nusing Nagios::Plugin::Performance revision ". $Nagios::Plugin::Performance::VERSION . "\n" if $ENV{TEST_VERBOSE}; | 47 | diag "\nusing Monitoring::Plugin::Performance revision ". $Monitoring::Plugin::Performance::VERSION . "\n" if $ENV{TEST_VERBOSE}; | 
| 48 | 48 | ||
| 49 | # Round-trip tests | 49 | # Round-trip tests | 
| 50 | for my $t (@test) { | 50 | for my $t (@test) { | 
| 51 | # Parse to components | 51 | # Parse to components | 
| 52 | ($p) = Nagios::Plugin::Performance->parse_perfstring($t->{perfoutput}); | 52 | ($p) = Monitoring::Plugin::Performance->parse_perfstring($t->{perfoutput}); | 
| 53 | is ($p->value, $t->{value}, "value okay $t->{value}"); | 53 | is ($p->value, $t->{value}, "value okay $t->{value}"); | 
| 54 | is ($p->label, $t->{label}, "label okay $t->{label}"); | 54 | is ($p->label, $t->{label}, "label okay $t->{label}"); | 
| 55 | is ($p->uom, $t->{uom}, "uom okay $t->{uom}"); | 55 | is ($p->uom, $t->{uom}, "uom okay $t->{uom}"); | 
| 56 | 56 | ||
| 57 | # Construct from components | 57 | # Construct from components | 
| 58 | my @construct = qw(label value uom warning critical min max); | 58 | my @construct = qw(label value uom warning critical min max); | 
| 59 | $p = Nagios::Plugin::Performance->new(map { $_ => $t->{$_} } @construct); | 59 | $p = Monitoring::Plugin::Performance->new(map { $_ => $t->{$_} } @construct); | 
| 60 | my $expected_perfoutput = $t->{perfoutput}; | 60 | my $expected_perfoutput = $t->{perfoutput}; | 
| 61 | if (exists $t->{expected_perfoutput}) { | 61 | if (exists $t->{expected_perfoutput}) { | 
| 62 | $expected_perfoutput = $t->{expected_perfoutput}; | 62 | $expected_perfoutput = $t->{expected_perfoutput}; | 
| @@ -75,9 +75,9 @@ for my $t (@test) { | |||
| 75 | 75 | ||
| 76 | # Construct using threshold | 76 | # Construct using threshold | 
| 77 | @construct = qw(label value uom min max); | 77 | @construct = qw(label value uom min max); | 
| 78 | $p = Nagios::Plugin::Performance->new( | 78 | $p = Monitoring::Plugin::Performance->new( | 
| 79 | map({ $_ => $t->{$_} } @construct), | 79 | map({ $_ => $t->{$_} } @construct), | 
| 80 | threshold => Nagios::Plugin::Threshold->set_thresholds(warning => $t->{warning}, critical => $t->{critical}), | 80 | threshold => Monitoring::Plugin::Threshold->set_thresholds(warning => $t->{warning}, critical => $t->{critical}), | 
| 81 | ); | 81 | ); | 
| 82 | is($p->perfoutput, $expected_perfoutput, "perfoutput okay ($expected_perfoutput)"); | 82 | is($p->perfoutput, $expected_perfoutput, "perfoutput okay ($expected_perfoutput)"); | 
| 83 | # Check warning/critical accessors | 83 | # Check warning/critical accessors | 
| @@ -92,7 +92,7 @@ for my $t (@test) { | |||
| 92 | 92 | ||
| 93 | 93 | ||
| 94 | # Test multiple parse_perfstrings | 94 | # Test multiple parse_perfstrings | 
| 95 | @p = Nagios::Plugin::Performance->parse_perfstring("/=382MB;15264;15269;; /var=218MB;9443;9448"); | 95 | @p = Monitoring::Plugin::Performance->parse_perfstring("/=382MB;15264;15269;; /var=218MB;9443;9448"); | 
| 96 | cmp_ok( $p[0]->label, 'eq', "/", "label okay"); | 96 | cmp_ok( $p[0]->label, 'eq', "/", "label okay"); | 
| 97 | cmp_ok( $p[0]->rrdlabel, 'eq', "root", "rrd label okay"); | 97 | cmp_ok( $p[0]->rrdlabel, 'eq', "root", "rrd label okay"); | 
| 98 | cmp_ok( $p[0]->value, '==', 382, "value okay"); | 98 | cmp_ok( $p[0]->value, '==', 382, "value okay"); | 
| @@ -109,14 +109,14 @@ cmp_ok( $p[1]->uom, 'eq', "MB", "uom okay"); | |||
| 109 | cmp_ok( $p[1]->threshold->warning->end, "==", 9443, "warn okay"); | 109 | cmp_ok( $p[1]->threshold->warning->end, "==", 9443, "warn okay"); | 
| 110 | cmp_ok( $p[1]->threshold->critical->end, "==", 9448, "crit okay"); | 110 | cmp_ok( $p[1]->threshold->critical->end, "==", 9448, "crit okay"); | 
| 111 | 111 | ||
| 112 | @p = Nagios::Plugin::Performance->parse_perfstring("rubbish"); | 112 | @p = Monitoring::Plugin::Performance->parse_perfstring("rubbish"); | 
| 113 | ok( ! @p, "Errors correctly"); | 113 | ok( ! @p, "Errors correctly"); | 
| 114 | ok( ! Nagios::Plugin::Performance->parse_perfstring(""), "Errors on empty string"); | 114 | ok( ! Monitoring::Plugin::Performance->parse_perfstring(""), "Errors on empty string"); | 
| 115 | 115 | ||
| 116 | 116 | ||
| 117 | 117 | ||
| 118 | # Check 1 bad with 1 good format output | 118 | # Check 1 bad with 1 good format output | 
| 119 | @p = Nagios::Plugin::Performance->parse_perfstring("rta=&391ms;100,200;500,034;0; pl=0%;20;60 "); | 119 | @p = Monitoring::Plugin::Performance->parse_perfstring("rta=&391ms;100,200;500,034;0; pl=0%;20;60 "); | 
| 120 | is( scalar @p, 1, "One bad piece of data - only one returned" ); | 120 | is( scalar @p, 1, "One bad piece of data - only one returned" ); | 
| 121 | is( $p[0]->label, "pl", "label okay for different numeric"); | 121 | is( $p[0]->label, "pl", "label okay for different numeric"); | 
| 122 | is( $p[0]->value, 0, "value okay"); | 122 | is( $p[0]->value, 0, "value okay"); | 
| @@ -127,7 +127,7 @@ is( $p[0]->threshold->critical->is_set, 1, "Critical range has been set"); | |||
| 127 | is( $p[0]->threshold->critical, "60", "warn okay"); | 127 | is( $p[0]->threshold->critical, "60", "warn okay"); | 
| 128 | 128 | ||
| 129 | # Same as above, but order swapped | 129 | # Same as above, but order swapped | 
| 130 | @p = Nagios::Plugin::Performance->parse_perfstring(" pl=0%;20;60 rta=&391ms;100,200;500,034;0; "); | 130 | @p = Monitoring::Plugin::Performance->parse_perfstring(" pl=0%;20;60 rta=&391ms;100,200;500,034;0; "); | 
| 131 | is( scalar @p, 1, "One bad piece of data - only one returned" ); | 131 | is( scalar @p, 1, "One bad piece of data - only one returned" ); | 
| 132 | is( $p[0]->label, "pl", "label okay for different numeric"); | 132 | is( $p[0]->label, "pl", "label okay for different numeric"); | 
| 133 | is( $p[0]->value, 0, "value okay"); | 133 | is( $p[0]->value, 0, "value okay"); | 
| @@ -140,7 +140,7 @@ is( $p[0]->threshold->critical, "60", "warn okay"); | |||
| 140 | 140 | ||
| 141 | 141 | ||
| 142 | 142 | ||
| 143 | @p = Nagios::Plugin::Performance->parse_perfstring( | 143 | @p = Monitoring::Plugin::Performance->parse_perfstring( | 
| 144 | "time=0.001229s;0.000000;0.000000;0.000000;10.000000"); | 144 | "time=0.001229s;0.000000;0.000000;0.000000;10.000000"); | 
| 145 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 145 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 
| 146 | cmp_ok( $p[0]->value, "==", 0.001229, "value okay"); | 146 | cmp_ok( $p[0]->value, "==", 0.001229, "value okay"); | 
| @@ -150,27 +150,27 @@ cmp_ok( $p[0]->uom, "eq", "s", "uom okay"); | |||
| 150 | 150 | ||
| 151 | 151 | ||
| 152 | 152 | ||
| 153 | @p = Nagios::Plugin::Performance->parse_perfstring( | 153 | @p = Monitoring::Plugin::Performance->parse_perfstring( | 
| 154 | "load1=0.000;5.000;9.000;0; load5=0.000;5.000;9.000;0; load15=0.000;5.000;9.000;0;"); | 154 | "load1=0.000;5.000;9.000;0; load5=0.000;5.000;9.000;0; load15=0.000;5.000;9.000;0;"); | 
| 155 | cmp_ok( $p[0]->label, "eq", "load1", "label okay"); | 155 | cmp_ok( $p[0]->label, "eq", "load1", "label okay"); | 
| 156 | cmp_ok( $p[0]->value, "eq", "0", "value okay with 0 as string"); | 156 | cmp_ok( $p[0]->value, "eq", "0", "value okay with 0 as string"); | 
| 157 | cmp_ok( $p[0]->uom, "eq", "", "uom empty"); | 157 | cmp_ok( $p[0]->uom, "eq", "", "uom empty"); | 
| 158 | cmp_ok( $p[0]->threshold->warning, "eq", "5", "warn okay"); | 158 | cmp_ok( $p[0]->threshold->warning, "eq", "5", "warn okay"); | 
| 159 | cmp_ok( $p[0]->threshold->critical, "eq", "9", "crit okay"); | 159 | cmp_ok( $p[0]->threshold->critical, "eq", "9", "crit okay"); | 
| 160 | cmp_ok( $p[1]->label, "eq", "load5", "label okay"); | 160 | cmp_ok( $p[1]->label, "eq", "load5", "label okay"); | 
| 161 | cmp_ok( $p[2]->label, "eq", "load15", "label okay"); | 161 | cmp_ok( $p[2]->label, "eq", "load15", "label okay"); | 
| 162 | 162 | ||
| 163 | @p = Nagios::Plugin::Performance->parse_perfstring( "users=4;20;50;0" ); | 163 | @p = Monitoring::Plugin::Performance->parse_perfstring( "users=4;20;50;0" ); | 
| 164 | cmp_ok( $p[0]->label, "eq", "users", "label okay"); | 164 | cmp_ok( $p[0]->label, "eq", "users", "label okay"); | 
| 165 | cmp_ok( $p[0]->value, "==", 4, "value okay"); | 165 | cmp_ok( $p[0]->value, "==", 4, "value okay"); | 
| 166 | cmp_ok( $p[0]->uom, "eq", "", "uom empty"); | 166 | cmp_ok( $p[0]->uom, "eq", "", "uom empty"); | 
| 167 | cmp_ok( $p[0]->threshold->warning, 'eq', "20", "warn okay"); | 167 | cmp_ok( $p[0]->threshold->warning, 'eq', "20", "warn okay"); | 
| 168 | cmp_ok( $p[0]->threshold->critical, 'eq', "50", "crit okay"); | 168 | cmp_ok( $p[0]->threshold->critical, 'eq', "50", "crit okay"); | 
| 169 | 169 | ||
| 170 | @p = Nagios::Plugin::Performance->parse_perfstring( "users=4;20;50;0\n" ); | 170 | @p = Monitoring::Plugin::Performance->parse_perfstring( "users=4;20;50;0\n" ); | 
| 171 | ok( @p, "parse correctly with linefeed at end (nagiosgraph)"); | 171 | ok( @p, "parse correctly with linefeed at end (nagiosgraph)"); | 
| 172 | 172 | ||
| 173 | @p = Nagios::Plugin::Performance->parse_perfstring( | 173 | @p = Monitoring::Plugin::Performance->parse_perfstring( | 
| 174 | "time=0.215300s;5.000000;10.000000;0.000000 size=426B;;;0" ); | 174 | "time=0.215300s;5.000000;10.000000;0.000000 size=426B;;;0" ); | 
| 175 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 175 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 
| 176 | cmp_ok( $p[0]->value, "eq", "0.2153", "value okay"); | 176 | cmp_ok( $p[0]->value, "eq", "0.2153", "value okay"); | 
| @@ -184,21 +184,21 @@ cmp_ok( $p[1]->uom, "eq", "B", "uom okay"); | |||
| 184 | ok( ! $p[1]->threshold->critical->is_set, "crit okay"); | 184 | ok( ! $p[1]->threshold->critical->is_set, "crit okay"); | 
| 185 | 185 | ||
| 186 | # Edge cases | 186 | # Edge cases | 
| 187 | @p = Nagios::Plugin::Performance->parse_perfstring("/home/a-m=0;0;0 shared-folder:big=20 12345678901234567890=20"); | 187 | @p = Monitoring::Plugin::Performance->parse_perfstring("/home/a-m=0;0;0 shared-folder:big=20 12345678901234567890=20"); | 
| 188 | cmp_ok( $p[0]->rrdlabel, "eq", "home_a_m", "changing / to _"); | 188 | cmp_ok( $p[0]->rrdlabel, "eq", "home_a_m", "changing / to _"); | 
| 189 | ok( $p[0]->threshold->warning->is_set, "Warning range has been set"); | 189 | ok( $p[0]->threshold->warning->is_set, "Warning range has been set"); | 
| 190 | cmp_ok( $p[1]->rrdlabel, "eq", "shared_folder_big", "replacing bad characters"); | 190 | cmp_ok( $p[1]->rrdlabel, "eq", "shared_folder_big", "replacing bad characters"); | 
| 191 | cmp_ok( $p[2]->rrdlabel, "eq", "1234567890123456789", "shortening rrd label"); | 191 | cmp_ok( $p[2]->rrdlabel, "eq", "1234567890123456789", "shortening rrd label"); | 
| 192 | 192 | ||
| 193 | # turn off fake_exit and enable use_die so we pick up on errors via nagios_die | 193 | # turn off fake_exit and enable use_die so we pick up on errors via plugin_die | 
| 194 | Nagios::Plugin::Functions::_use_die(1); | 194 | Monitoring::Plugin::Functions::_use_die(1); | 
| 195 | Nagios::Plugin::Functions::_fake_exit(0); | 195 | Monitoring::Plugin::Functions::_fake_exit(0); | 
| 196 | 196 | ||
| 197 | @p = Nagios::Plugin::Performance->parse_perfstring("time=0.002722s;0.000000;0.000000;0.000000;10.000000"); | 197 | @p = Monitoring::Plugin::Performance->parse_perfstring("time=0.002722s;0.000000;0.000000;0.000000;10.000000"); | 
| 198 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 198 | cmp_ok( $p[0]->label, "eq", "time", "label okay"); | 
| 199 | cmp_ok( $p[0]->value, "eq", "0.002722", "value okay"); | 199 | cmp_ok( $p[0]->value, "eq", "0.002722", "value okay"); | 
| 200 | cmp_ok( $p[0]->uom, "eq", "s", "uom okay"); | 200 | cmp_ok( $p[0]->uom, "eq", "s", "uom okay"); | 
| 201 | ok( defined $p[0]->threshold->warning->is_set, "Warning range has been set"); | 201 | ok( defined $p[0]->threshold->warning->is_set, "Warning range has been set"); | 
| 202 | ok( defined $p[0]->threshold->critical->is_set, "Critical range has been set"); | 202 | ok( defined $p[0]->threshold->critical->is_set, "Critical range has been set"); | 
| 203 | # The two below used to be cmp_ok, but Test::More 0.86 appears to have a problem with a stringification | 203 | # The two below used to be cmp_ok, but Test::More 0.86 appears to have a problem with a stringification | 
| 204 | # of 0. See http://rt.cpan.org/Ticket/Display.html?id=41109 | 204 | # of 0. See http://rt.cpan.org/Ticket/Display.html?id=41109 | 
| @@ -206,7 +206,7 @@ cmp_ok( $p[0]->uom, "eq", "s", "uom okay"); | |||
| 206 | is( $p[0]->threshold->warning."", "0", "warn okay"); | 206 | is( $p[0]->threshold->warning."", "0", "warn okay"); | 
| 207 | is( $p[0]->threshold->critical."", "0", "crit okay"); | 207 | is( $p[0]->threshold->critical."", "0", "crit okay"); | 
| 208 | 208 | ||
| 209 | @p = Nagios::Plugin::Performance->parse_perfstring("pct_used=73.7%;90;95"); | 209 | @p = Monitoring::Plugin::Performance->parse_perfstring("pct_used=73.7%;90;95"); | 
| 210 | cmp_ok( $p[0]->label, "eq", "pct_used", "label okay"); | 210 | cmp_ok( $p[0]->label, "eq", "pct_used", "label okay"); | 
| 211 | cmp_ok( $p[0]->value, "eq", "73.7", "value okay"); | 211 | cmp_ok( $p[0]->value, "eq", "73.7", "value okay"); | 
| 212 | cmp_ok( $p[0]->uom, "eq", "%", "uom okay"); | 212 | cmp_ok( $p[0]->uom, "eq", "%", "uom okay"); | 
| @@ -216,7 +216,7 @@ cmp_ok( $p[0]->threshold->warning, 'eq', "90", "warn okay"); | |||
| 216 | cmp_ok( $p[0]->threshold->critical, 'eq', "95", "crit okay"); | 216 | cmp_ok( $p[0]->threshold->critical, 'eq', "95", "crit okay"); | 
| 217 | 217 | ||
| 218 | # Check ranges are parsed correctly | 218 | # Check ranges are parsed correctly | 
| 219 | @p = Nagios::Plugin::Performance->parse_perfstring("availability=93.8%;90:99;"); | 219 | @p = Monitoring::Plugin::Performance->parse_perfstring("availability=93.8%;90:99;"); | 
| 220 | is( $p[0]->label, "availability", "label okay"); | 220 | is( $p[0]->label, "availability", "label okay"); | 
| 221 | is( $p[0]->value, "93.8", "value okay"); | 221 | is( $p[0]->value, "93.8", "value okay"); | 
| 222 | is( $p[0]->uom, "%", "uom okay"); | 222 | is( $p[0]->uom, "%", "uom okay"); | 
| @@ -225,7 +225,7 @@ is( $p[0]->threshold->critical->is_set, 0, "Critical range has not been set"); | |||
| 225 | is( $p[0]->threshold->warning, "90:99", "warn okay"); | 225 | is( $p[0]->threshold->warning, "90:99", "warn okay"); | 
| 226 | 226 | ||
| 227 | # Check that negative values are parsed correctly in value and ranges | 227 | # Check that negative values are parsed correctly in value and ranges | 
| 228 | @p = Nagios::Plugin::Performance->parse_perfstring("offset=-0.004476s;-60.000000:-5;-120.000000:-3;"); | 228 | @p = Monitoring::Plugin::Performance->parse_perfstring("offset=-0.004476s;-60.000000:-5;-120.000000:-3;"); | 
| 229 | is( $p[0]->label, "offset", "label okay"); | 229 | is( $p[0]->label, "offset", "label okay"); | 
| 230 | is( $p[0]->value, "-0.004476", "value okay"); | 230 | is( $p[0]->value, "-0.004476", "value okay"); | 
| 231 | is( $p[0]->uom, "s", "uom okay"); | 231 | is( $p[0]->uom, "s", "uom okay"); | 
| @@ -235,7 +235,7 @@ is( $p[0]->threshold->warning, "-60:-5", "warn okay"); | |||
| 235 | is( $p[0]->threshold->critical, "-120:-3", "crit okay"); | 235 | is( $p[0]->threshold->critical, "-120:-3", "crit okay"); | 
| 236 | 236 | ||
| 237 | # Check infinity values are okay | 237 | # Check infinity values are okay | 
| 238 | @p = Nagios::Plugin::Performance->parse_perfstring("salary=52GBP;~:23.5;45.2:"); | 238 | @p = Monitoring::Plugin::Performance->parse_perfstring("salary=52GBP;~:23.5;45.2:"); | 
| 239 | is( $p[0]->label, "salary", "label okay"); | 239 | is( $p[0]->label, "salary", "label okay"); | 
| 240 | is( $p[0]->value, "52", "value okay"); | 240 | is( $p[0]->value, "52", "value okay"); | 
| 241 | is( $p[0]->uom, "GBP", "uom okay"); | 241 | is( $p[0]->uom, "GBP", "uom okay"); | 
| @@ -245,7 +245,7 @@ is( $p[0]->threshold->warning, "~:23.5", "warn okay"); | |||
| 245 | is( $p[0]->threshold->critical, "45.2:", "warn okay"); | 245 | is( $p[0]->threshold->critical, "45.2:", "warn okay"); | 
| 246 | 246 | ||
| 247 | # Check scientific notation | 247 | # Check scientific notation | 
| 248 | @p = Nagios::Plugin::Performance->parse_perfstring("offset=1.120567322e-05"); | 248 | @p = Monitoring::Plugin::Performance->parse_perfstring("offset=1.120567322e-05"); | 
| 249 | is( $p[0]->label, "offset", "label okay for scientific notation"); | 249 | is( $p[0]->label, "offset", "label okay for scientific notation"); | 
| 250 | is( $p[0]->value, 1.120567322e-05, "value okay"); | 250 | is( $p[0]->value, 1.120567322e-05, "value okay"); | 
| 251 | is( $p[0]->uom, "", "uom okay"); | 251 | is( $p[0]->uom, "", "uom okay"); | 
| @@ -254,7 +254,7 @@ ok( ! $p[0]->threshold->critical->is_set, "Critical range has not been set"); | |||
| 254 | 254 | ||
| 255 | 255 | ||
| 256 | # Check scientific notation with warnings and criticals | 256 | # Check scientific notation with warnings and criticals | 
| 257 | @p = Nagios::Plugin::Performance->parse_perfstring("offset=-1.120567322e-05unit;-1.1e-05:1.0e-03;4.3e+02:4.3e+25"); | 257 | @p = Monitoring::Plugin::Performance->parse_perfstring("offset=-1.120567322e-05unit;-1.1e-05:1.0e-03;4.3e+02:4.3e+25"); | 
| 258 | is( $p[0]->label, "offset", "label okay for scientific notation in warnings and criticals"); | 258 | is( $p[0]->label, "offset", "label okay for scientific notation in warnings and criticals"); | 
| 259 | is( $p[0]->value, -1.120567322e-05, "value okay"); | 259 | is( $p[0]->value, -1.120567322e-05, "value okay"); | 
| 260 | is( $p[0]->uom, "unit", "uom okay"); | 260 | is( $p[0]->uom, "unit", "uom okay"); | 
| @@ -266,7 +266,7 @@ is( $p[0]->threshold->critical, "430:4.3e+25", "warn okay"); | |||
| 266 | 266 | ||
| 267 | 267 | ||
| 268 | # Check different collation with commas instead of periods | 268 | # Check different collation with commas instead of periods | 
| 269 | @p = Nagios::Plugin::Performance->parse_perfstring("rta=1,391ms;100,200;500,034;0; pl=0%;20;60;;"); | 269 | @p = Monitoring::Plugin::Performance->parse_perfstring("rta=1,391ms;100,200;500,034;0; pl=0%;20;60;;"); | 
| 270 | is( $p[0]->label, "rta", "label okay for numeric with commas instead of periods"); | 270 | is( $p[0]->label, "rta", "label okay for numeric with commas instead of periods"); | 
| 271 | is( $p[0]->value, 1.391, "value okay"); | 271 | is( $p[0]->value, 1.391, "value okay"); | 
| 272 | is( $p[0]->uom, "ms", "uom okay"); | 272 | is( $p[0]->uom, "ms", "uom okay"); | 
| @@ -284,7 +284,7 @@ is( $p[1]->threshold->critical, "60", "warn okay"); | |||
| 284 | 284 | ||
| 285 | 285 | ||
| 286 | # Another set of comma separated stuff | 286 | # Another set of comma separated stuff | 
| 287 | @p = Nagios::Plugin::Performance->parse_perfstring("offset=-0,023545s;60,000000;120,000000;"); | 287 | @p = Monitoring::Plugin::Performance->parse_perfstring("offset=-0,023545s;60,000000;120,000000;"); | 
| 288 | is( $p[0]->label, "offset", "label okay for numeric with commas instead of periods"); | 288 | is( $p[0]->label, "offset", "label okay for numeric with commas instead of periods"); | 
| 289 | is( $p[0]->value, -0.023545, "value okay"); | 289 | is( $p[0]->value, -0.023545, "value okay"); | 
| 290 | is( $p[0]->uom, "s", "uom okay"); | 290 | is( $p[0]->uom, "s", "uom okay"); | 
| @@ -294,14 +294,14 @@ is( $p[0]->threshold->critical->is_set, 1, "Critical range has been set"); | |||
| 294 | is( $p[0]->threshold->critical, 120, "warn okay"); | 294 | is( $p[0]->threshold->critical, 120, "warn okay"); | 
| 295 | 295 | ||
| 296 | # Some values with funny commas | 296 | # Some values with funny commas | 
| 297 | @p = Nagios::Plugin::Performance->parse_perfstring("time=1800,600,300,0,3600 other=45.6"); | 297 | @p = Monitoring::Plugin::Performance->parse_perfstring("time=1800,600,300,0,3600 other=45.6"); | 
| 298 | is( $p[0]->label, "other", "Ignored time=1800,600,300,0,3600, but allowed other=45.6"); | 298 | is( $p[0]->label, "other", "Ignored time=1800,600,300,0,3600, but allowed other=45.6"); | 
| 299 | is( $p[0]->value, 45.6, "value okay"); | 299 | is( $p[0]->value, 45.6, "value okay"); | 
| 300 | is( $p[0]->uom, "", "uom okay"); | 300 | is( $p[0]->uom, "", "uom okay"); | 
| 301 | 301 | ||
| 302 | 302 | ||
| 303 | # Test labels with spaces (returned by nsclient++) | 303 | # Test labels with spaces (returned by nsclient++) | 
| 304 | @p = Nagios::Plugin::Performance->parse_perfstring("'C:\ Label: Serial Number bc22aa2e'=8015MB;16387;18435;0;20484 'D:\ Label: Serial Number XA22aa2e'=8015MB;16388;18436;1;2048"); | 304 | @p = Monitoring::Plugin::Performance->parse_perfstring("'C:\ Label: Serial Number bc22aa2e'=8015MB;16387;18435;0;20484 'D:\ Label: Serial Number XA22aa2e'=8015MB;16388;18436;1;2048"); | 
| 305 | is( $p[0]->label, "C:\ Label: Serial Number bc22aa2e"); | 305 | is( $p[0]->label, "C:\ Label: Serial Number bc22aa2e"); | 
| 306 | is( $p[0]->rrdlabel, "C__Label___Serial_N"); | 306 | is( $p[0]->rrdlabel, "C__Label___Serial_N"); | 
| 307 | is( $p[0]->value, 8015, "value okay"); | 307 | is( $p[0]->value, 8015, "value okay"); | 
| @@ -322,7 +322,7 @@ is( $p[1]->max, 2048, "max ok"); | |||
| 322 | 322 | ||
| 323 | 323 | ||
| 324 | # Mix labels with and without quotes | 324 | # Mix labels with and without quotes | 
| 325 | @p = Nagios::Plugin::Performance->parse_perfstring(" short=4 'C:\ Label: Serial Number bc22aa2e'=8015MB;16387;18435;0;20484 end=5 "); | 325 | @p = Monitoring::Plugin::Performance->parse_perfstring(" short=4 'C:\ Label: Serial Number bc22aa2e'=8015MB;16387;18435;0;20484 end=5 "); | 
| 326 | is( $p[0]->label, "short" ); | 326 | is( $p[0]->label, "short" ); | 
| 327 | is( $p[0]->rrdlabel, "short"); | 327 | is( $p[0]->rrdlabel, "short"); | 
| 328 | is( $p[0]->value, 4, "value okay"); | 328 | is( $p[0]->value, 4, "value okay"); | 
| @@ -351,7 +351,7 @@ is( $p[2]->min, undef, "min ok"); | |||
| 351 | is( $p[2]->max, undef, "max ok"); | 351 | is( $p[2]->max, undef, "max ok"); | 
| 352 | 352 | ||
| 353 | 353 | ||
| 354 | @p = Nagios::Plugin::Performance->parse_perfstring("processes=9;WKFLSV32.exe;9="); | 354 | @p = Monitoring::Plugin::Performance->parse_perfstring("processes=9;WKFLSV32.exe;9="); | 
| 355 | is_deeply( \@p, [], "Fails parsing correctly"); | 355 | is_deeply( \@p, [], "Fails parsing correctly"); | 
| 356 | 356 | ||
| 357 | # add_perfdata tests in t/Nagios-Plugin-01.t | 357 | # add_perfdata tests in t/Monitoring-Plugin-01.t | 
| diff --git a/t/Nagios-Plugin-Range.t b/t/Monitoring-Plugin-Range.t index 6fe080c..9a6e826 100644 --- a/t/Nagios-Plugin-Range.t +++ b/t/Monitoring-Plugin-Range.t | |||
| @@ -1,15 +1,15 @@ | |||
| 1 | 1 | ||
| 2 | use strict; | 2 | use strict; | 
| 3 | #use Test::More qw(no_plan); | 3 | #use Test::More qw(no_plan); | 
| 4 | use Test::More tests => 151; | 4 | use Test::More tests => 151; | 
| 5 | 5 | ||
| 6 | BEGIN { | 6 | BEGIN { | 
| 7 | use_ok('Nagios::Plugin::Range'); | 7 | use_ok('Monitoring::Plugin::Range'); | 
| 8 | # Silence warnings unless TEST_VERBOSE is set | 8 | # Silence warnings unless TEST_VERBOSE is set | 
| 9 | $SIG{__WARN__} = sub { warn $_[0] if $ENV{TEST_VERBOSE} }; | 9 | $SIG{__WARN__} = sub { warn $_[0] if $ENV{TEST_VERBOSE} }; | 
| 10 | }; | 10 | }; | 
| 11 | 11 | ||
| 12 | diag "\nusing Nagios::Plugin::Range revision ". $Nagios::Plugin::Range::VERSION . "\n" if $ENV{TEST_VERBOSE}; | 12 | diag "\nusing Monitoring::Plugin::Range revision ". $Monitoring::Plugin::Range::VERSION . "\n" if $ENV{TEST_VERBOSE}; | 
| 13 | 13 | ||
| 14 | my $r; | 14 | my $r; | 
| 15 | 15 | ||
| @@ -25,14 +25,14 @@ foreach (qw( | |||
| 25 | 25 | ||
| 26 | ), '1,10' # avoid warning about using , inside qw() | 26 | ), '1,10' # avoid warning about using , inside qw() | 
| 27 | ) { | 27 | ) { | 
| 28 | $r =Nagios::Plugin::Range->parse_range_string($_); | 28 | $r =Monitoring::Plugin::Range->parse_range_string($_); | 
| 29 | is $r, undef, "'$_' should not be a valid range" ; | 29 | is $r, undef, "'$_' should not be a valid range" ; | 
| 30 | } | 30 | } | 
| 31 | 31 | ||
| 32 | 32 | ||
| 33 | diag "range: 0..6 inclusive" if $ENV{TEST_VERBOSE}; | 33 | diag "range: 0..6 inclusive" if $ENV{TEST_VERBOSE}; | 
| 34 | $r = Nagios::Plugin::Range->parse_range_string("6"); | 34 | $r = Monitoring::Plugin::Range->parse_range_string("6"); | 
| 35 | isa_ok( $r, "Nagios::Plugin::Range"); | 35 | isa_ok( $r, "Monitoring::Plugin::Range"); | 
| 36 | ok( defined $r, "'6' is valid range"); | 36 | ok( defined $r, "'6' is valid range"); | 
| 37 | cmp_ok( $r->start, '==', 0, "Start correct"); | 37 | cmp_ok( $r->start, '==', 0, "Start correct"); | 
| 38 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 38 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -53,7 +53,7 @@ sub test_expected { | |||
| 53 | my $r = shift; | 53 | my $r = shift; | 
| 54 | my $expected = shift; | 54 | my $expected = shift; | 
| 55 | foreach (sort {$a<=>$b} keys %$expected) { | 55 | foreach (sort {$a<=>$b} keys %$expected) { | 
| 56 | is $r->check_range($_), $expected->{$_}, | 56 | is $r->check_range($_), $expected->{$_}, | 
| 57 | " $_ should " . ($expected->{$_} ? 'not ' : '') . "be in the range (line ".(caller)[2].")"; | 57 | " $_ should " . ($expected->{$_} ? 'not ' : '') . "be in the range (line ".(caller)[2].")"; | 
| 58 | } | 58 | } | 
| 59 | } | 59 | } | 
| @@ -61,7 +61,7 @@ sub test_expected { | |||
| 61 | test_expected( $r, $expected ); | 61 | test_expected( $r, $expected ); | 
| 62 | 62 | ||
| 63 | diag "range : -7..23, inclusive" if $ENV{TEST_VERBOSE}; | 63 | diag "range : -7..23, inclusive" if $ENV{TEST_VERBOSE}; | 
| 64 | $r = Nagios::Plugin::Range->parse_range_string("-7:23"); | 64 | $r = Monitoring::Plugin::Range->parse_range_string("-7:23"); | 
| 65 | ok( defined $r, "'-7:23' is valid range"); | 65 | ok( defined $r, "'-7:23' is valid range"); | 
| 66 | cmp_ok( $r->start, '==', -7, "Start correct"); | 66 | cmp_ok( $r->start, '==', -7, "Start correct"); | 
| 67 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 67 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -72,7 +72,7 @@ cmp_ok( $r, 'eq', "-7:23", "Stringification back to original"); | |||
| 72 | $expected = { | 72 | $expected = { | 
| 73 | -23 => 1, | 73 | -23 => 1, | 
| 74 | -7 => 0, | 74 | -7 => 0, | 
| 75 | -1 => 0, | 75 | -1 => 0, | 
| 76 | 0 => 0, | 76 | 0 => 0, | 
| 77 | 4 => 0, | 77 | 4 => 0, | 
| 78 | 23 => 0, | 78 | 23 => 0, | 
| @@ -83,7 +83,7 @@ test_expected( $r, $expected ); | |||
| 83 | 83 | ||
| 84 | 84 | ||
| 85 | diag "range : 0..5.75, inclusive" if $ENV{TEST_VERBOSE}; | 85 | diag "range : 0..5.75, inclusive" if $ENV{TEST_VERBOSE}; | 
| 86 | $r = Nagios::Plugin::Range->parse_range_string(":5.75"); | 86 | $r = Monitoring::Plugin::Range->parse_range_string(":5.75"); | 
| 87 | ok( defined $r, "':5.75' is valid range"); | 87 | ok( defined $r, "':5.75' is valid range"); | 
| 88 | cmp_ok( $r->start, '==', 0, "Start correct"); | 88 | cmp_ok( $r->start, '==', 0, "Start correct"); | 
| 89 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 89 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -105,7 +105,7 @@ test_expected( $r, $expected ); | |||
| 105 | 105 | ||
| 106 | 106 | ||
| 107 | diag "range : negative infinity .. -95.99, inclusive" if $ENV{TEST_VERBOSE}; | 107 | diag "range : negative infinity .. -95.99, inclusive" if $ENV{TEST_VERBOSE}; | 
| 108 | $r = Nagios::Plugin::Range->parse_range_string("~:-95.99"); | 108 | $r = Monitoring::Plugin::Range->parse_range_string("~:-95.99"); | 
| 109 | ok( defined $r, "'~:-95.99' is valid range"); | 109 | ok( defined $r, "'~:-95.99' is valid range"); | 
| 110 | cmp_ok( $r->start_infinity, '==', 1, "Using negative infinity"); | 110 | cmp_ok( $r->start_infinity, '==', 1, "Using negative infinity"); | 
| 111 | cmp_ok( $r->end, '==', -95.99, "End correct"); | 111 | cmp_ok( $r->end, '==', -95.99, "End correct"); | 
| @@ -126,7 +126,7 @@ test_expected( $r, $expected ); | |||
| 126 | 126 | ||
| 127 | diag "range 10..infinity , inclusive" if $ENV{TEST_VERBOSE}; | 127 | diag "range 10..infinity , inclusive" if $ENV{TEST_VERBOSE}; | 
| 128 | test_expected( $r, $expected ); | 128 | test_expected( $r, $expected ); | 
| 129 | $r = Nagios::Plugin::Range->parse_range_string("10:"); | 129 | $r = Monitoring::Plugin::Range->parse_range_string("10:"); | 
| 130 | ok( defined $r, "'10:' is valid range"); | 130 | ok( defined $r, "'10:' is valid range"); | 
| 131 | cmp_ok( $r->start, '==', 10, "Start correct"); | 131 | cmp_ok( $r->start, '==', 10, "Start correct"); | 
| 132 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 132 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -147,7 +147,7 @@ test_expected( $r, $expected ); | |||
| 147 | 147 | ||
| 148 | diag "range 123456789012345..infinity , inclusive" if $ENV{TEST_VERBOSE}; | 148 | diag "range 123456789012345..infinity , inclusive" if $ENV{TEST_VERBOSE}; | 
| 149 | test_expected( $r, $expected ); | 149 | test_expected( $r, $expected ); | 
| 150 | $r = Nagios::Plugin::Range->parse_range_string("123456789012345:"); | 150 | $r = Monitoring::Plugin::Range->parse_range_string("123456789012345:"); | 
| 151 | ok( defined $r, "'123456789012345:' is valid range"); | 151 | ok( defined $r, "'123456789012345:' is valid range"); | 
| 152 | cmp_ok( $r->start, '==', 123456789012345, "Start correct"); | 152 | cmp_ok( $r->start, '==', 123456789012345, "Start correct"); | 
| 153 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 153 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -159,7 +159,7 @@ $expected = { | |||
| 159 | 0 => 1, | 159 | 0 => 1, | 
| 160 | # The fractional values needs to be quoted, otherwise the hash rounds it up to ..345 | 160 | # The fractional values needs to be quoted, otherwise the hash rounds it up to ..345 | 
| 161 | # and there is one less test run. | 161 | # and there is one less test run. | 
| 162 | # I think some newer versions of perl use a higher precision value for the hash key. | 162 | # I think some newer versions of perl use a higher precision value for the hash key. | 
| 163 | # This doesn't appear to affect the actual plugin though | 163 | # This doesn't appear to affect the actual plugin though | 
| 164 | "123456789012344.91" => 1, | 164 | "123456789012344.91" => 1, | 
| 165 | 123456789012345 => 0, | 165 | 123456789012345 => 0, | 
| @@ -170,7 +170,7 @@ test_expected( $r, $expected ); | |||
| 170 | 170 | ||
| 171 | 171 | ||
| 172 | diag "range: <= zero " if $ENV{TEST_VERBOSE}; | 172 | diag "range: <= zero " if $ENV{TEST_VERBOSE}; | 
| 173 | $r = Nagios::Plugin::Range->parse_range_string("~:0"); | 173 | $r = Monitoring::Plugin::Range->parse_range_string("~:0"); | 
| 174 | ok( defined $r, "'~:0' is valid range"); | 174 | ok( defined $r, "'~:0' is valid range"); | 
| 175 | cmp_ok( $r->start_infinity, '==', 1, "Using negative infinity"); | 175 | cmp_ok( $r->start_infinity, '==', 1, "Using negative infinity"); | 
| 176 | cmp_ok( $r->end, '==', 0, "End correct"); | 176 | cmp_ok( $r->end, '==', 0, "End correct"); | 
| @@ -191,7 +191,7 @@ test_expected( $r, $expected ); | |||
| 191 | 191 | ||
| 192 | 192 | ||
| 193 | diag "range: OUTSIDE 0..657.8210567" if $ENV{TEST_VERBOSE}; | 193 | diag "range: OUTSIDE 0..657.8210567" if $ENV{TEST_VERBOSE}; | 
| 194 | $r = Nagios::Plugin::Range->parse_range_string('@0:657.8210567'); | 194 | $r = Monitoring::Plugin::Range->parse_range_string('@0:657.8210567'); | 
| 195 | ok( defined $r, '"@0:657.8210567" is a valid range'); | 195 | ok( defined $r, '"@0:657.8210567" is a valid range'); | 
| 196 | cmp_ok( $r->start, '==', 0, "Start correct"); | 196 | cmp_ok( $r->start, '==', 0, "Start correct"); | 
| 197 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 197 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -216,7 +216,7 @@ test_expected( $r, $expected ); | |||
| 216 | 216 | ||
| 217 | 217 | ||
| 218 | diag "range: 1..1 inclusive (equals one)" if $ENV{TEST_VERBOSE}; | 218 | diag "range: 1..1 inclusive (equals one)" if $ENV{TEST_VERBOSE}; | 
| 219 | $r = Nagios::Plugin::Range->parse_range_string('1:1'); | 219 | $r = Monitoring::Plugin::Range->parse_range_string('1:1'); | 
| 220 | ok( defined $r, '"1:1" is a valid range'); | 220 | ok( defined $r, '"1:1" is a valid range'); | 
| 221 | cmp_ok( $r->start, '==', 1, "Start correct"); | 221 | cmp_ok( $r->start, '==', 1, "Start correct"); | 
| 222 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 222 | cmp_ok( $r->start_infinity, '==', 0, "Not using negative infinity"); | 
| @@ -237,7 +237,7 @@ $expected = { | |||
| 237 | test_expected( $r, $expected ); | 237 | test_expected( $r, $expected ); | 
| 238 | 238 | ||
| 239 | 239 | ||
| 240 | $r = Nagios::Plugin::Range->parse_range_string('2:1'); | 240 | $r = Monitoring::Plugin::Range->parse_range_string('2:1'); | 
| 241 | ok( ! defined $r, '"2:1" is rejected'); | 241 | ok( ! defined $r, '"2:1" is rejected'); | 
| 242 | 242 | ||
| 243 | # TODO: Need more tests for invalid data | 243 | # TODO: Need more tests for invalid data | 
| diff --git a/t/Nagios-Plugin-Threshold.t b/t/Monitoring-Plugin-Threshold.t index 78d2189..8849464 100644 --- a/t/Nagios-Plugin-Threshold.t +++ b/t/Monitoring-Plugin-Threshold.t | |||
| @@ -1,32 +1,32 @@ | |||
| 1 | 1 | ||
| 2 | use strict; | 2 | use strict; | 
| 3 | use Test::More tests => 93; | 3 | use Test::More tests => 93; | 
| 4 | BEGIN { | 4 | BEGIN { | 
| 5 | use_ok('Nagios::Plugin::Threshold'); | 5 | use_ok('Monitoring::Plugin::Threshold'); | 
| 6 | use_ok('Nagios::Plugin::Functions', ':all' ); | 6 | use_ok('Monitoring::Plugin::Functions', ':all' ); | 
| 7 | # Silence warnings unless TEST_VERBOSE is set | 7 | # Silence warnings unless TEST_VERBOSE is set | 
| 8 | $SIG{__WARN__} = sub { warn $_[0] if $ENV{TEST_VERBOSE} }; | 8 | $SIG{__WARN__} = sub { warn $_[0] if $ENV{TEST_VERBOSE} }; | 
| 9 | } | 9 | } | 
| 10 | 10 | ||
| 11 | diag "\nusing Nagios::Plugin::Threshold revision ". $Nagios::Plugin::Threshold::VERSION . "\n" | 11 | diag "\nusing Monitoring::Plugin::Threshold revision ". $Monitoring::Plugin::Threshold::VERSION . "\n" | 
| 12 | if $ENV{TEST_VERBOSE}; | 12 | if $ENV{TEST_VERBOSE}; | 
| 13 | 13 | ||
| 14 | Nagios::Plugin::Functions::_fake_exit(1); | 14 | Monitoring::Plugin::Functions::_fake_exit(1); | 
| 15 | 15 | ||
| 16 | my $t; | 16 | my $t; | 
| 17 | 17 | ||
| 18 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => undef, critical => undef); | 18 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => undef, critical => undef); | 
| 19 | ok( defined $t, "two undefs" ); | 19 | ok( defined $t, "two undefs" ); | 
| 20 | ok( ! $t->warning->is_set, "warning not set" ); | 20 | ok( ! $t->warning->is_set, "warning not set" ); | 
| 21 | ok( ! $t->critical->is_set, "critical not set" ); | 21 | ok( ! $t->critical->is_set, "critical not set" ); | 
| 22 | 22 | ||
| 23 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => "", critical => ""); | 23 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "", critical => ""); | 
| 24 | ok( defined $t, "two empty strings" ); | 24 | ok( defined $t, "two empty strings" ); | 
| 25 | ok( ! $t->warning->is_set, "warning not set" ); | 25 | ok( ! $t->warning->is_set, "warning not set" ); | 
| 26 | ok( ! $t->critical->is_set, "critical not set" ); | 26 | ok( ! $t->critical->is_set, "critical not set" ); | 
| 27 | 27 | ||
| 28 | diag "threshold: critical if > 80" if $ENV{TEST_VERBOSE}; | 28 | diag "threshold: critical if > 80" if $ENV{TEST_VERBOSE}; | 
| 29 | my $t = Nagios::Plugin::Threshold->set_thresholds(critical => "80"); | 29 | my $t = Monitoring::Plugin::Threshold->set_thresholds(critical => "80"); | 
| 30 | ok( defined $t, "Threshold ('', '80') set"); | 30 | ok( defined $t, "Threshold ('', '80') set"); | 
| 31 | ok( ! $t->warning->is_set, "Warning not set"); | 31 | ok( ! $t->warning->is_set, "Warning not set"); | 
| 32 | cmp_ok( $t->critical->start, '==', 0, "Critical strat set correctly"); | 32 | cmp_ok( $t->critical->start, '==', 0, "Critical strat set correctly"); | 
| @@ -59,11 +59,11 @@ sub test_expected_statuses { | |||
| 59 | } | 59 | } | 
| 60 | test_expected_statuses( $t, $expected ); | 60 | test_expected_statuses( $t, $expected ); | 
| 61 | 61 | ||
| 62 | # GMC: this test seems bogus to me - either we've died, in which case internal | 62 | # GMC: this test seems bogus to me - either we've died, in which case internal | 
| 63 | # state is undefined (and untestable!), or we should be returning a non-fatal error | 63 | # state is undefined (and untestable!), or we should be returning a non-fatal error | 
| 64 | if (0) { | 64 | if (0) { | 
| 65 | diag "threshold: warn if less than 5 or more than 33." if $ENV{TEST_VERBOSE}; | 65 | diag "threshold: warn if less than 5 or more than 33." if $ENV{TEST_VERBOSE}; | 
| 66 | eval { $t = Nagios::Plugin::Threshold->set_thresholds(warning => "5:33", critical => "") }; | 66 | eval { $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "5:33", critical => "") }; | 
| 67 | ok( defined $t, "Threshold ('5:33', '') set"); | 67 | ok( defined $t, "Threshold ('5:33', '') set"); | 
| 68 | cmp_ok( $t->warning->start, '==', 5, "Warning start set"); | 68 | cmp_ok( $t->warning->start, '==', 5, "Warning start set"); | 
| 69 | cmp_ok( $t->warning->end, '==', 33, "Warning end set"); | 69 | cmp_ok( $t->warning->end, '==', 33, "Warning end set"); | 
| @@ -72,7 +72,7 @@ if (0) { | |||
| 72 | 72 | ||
| 73 | # GC: same as previous test, except critical is undef instead of '' | 73 | # GC: same as previous test, except critical is undef instead of '' | 
| 74 | diag "threshold: warn if less than 5 or more than 33." if $ENV{TEST_VERBOSE}; | 74 | diag "threshold: warn if less than 5 or more than 33." if $ENV{TEST_VERBOSE}; | 
| 75 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => "5:33", critical => undef); | 75 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "5:33", critical => undef); | 
| 76 | ok( defined $t, "Threshold ('5:33', '') set"); | 76 | ok( defined $t, "Threshold ('5:33', '') set"); | 
| 77 | cmp_ok( $t->warning->start, '==', 5, "Warning start set"); | 77 | cmp_ok( $t->warning->start, '==', 5, "Warning start set"); | 
| 78 | cmp_ok( $t->warning->end, '==', 33, "Warning end set"); | 78 | cmp_ok( $t->warning->end, '==', 33, "Warning end set"); | 
| @@ -91,7 +91,7 @@ $expected = { qw( | |||
| 91 | test_expected_statuses( $t, $expected ); | 91 | test_expected_statuses( $t, $expected ); | 
| 92 | 92 | ||
| 93 | diag "threshold: warn if more than 30; critical if > 60" if $ENV{TEST_VERBOSE}; | 93 | diag "threshold: warn if more than 30; critical if > 60" if $ENV{TEST_VERBOSE}; | 
| 94 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => "~:30", critical => "~:60"); | 94 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "~:30", critical => "~:60"); | 
| 95 | ok( defined $t, "Threshold ('~:30', '~:60') set"); | 95 | ok( defined $t, "Threshold ('~:30', '~:60') set"); | 
| 96 | cmp_ok( $t->warning->end, '==', 30, "Warning end set"); | 96 | cmp_ok( $t->warning->end, '==', 30, "Warning end set"); | 
| 97 | cmp_ok( $t->critical->end, '==',60, "Critical end set"); | 97 | cmp_ok( $t->critical->end, '==',60, "Critical end set"); | 
| @@ -118,23 +118,23 @@ test_expected_statuses( $t, $expected ); | |||
| 118 | goto SKIP_DEATH; | 118 | goto SKIP_DEATH; | 
| 119 | diag "threshold: test pure crap for arguments - default to OK." if $ENV{TEST_VERBOSE}; | 119 | diag "threshold: test pure crap for arguments - default to OK." if $ENV{TEST_VERBOSE}; | 
| 120 | diag "you should see one invalid range definition warning and an UNKNOWN line here:\n"; | 120 | diag "you should see one invalid range definition warning and an UNKNOWN line here:\n"; | 
| 121 | Nagios::Plugin::Functions->print_on_die(1); | 121 | Monitoring::Plugin::Functions->print_on_die(1); | 
| 122 | Nagios::Plugin::Functions->exit_on_die(1); | 122 | Monitoring::Plugin::Functions->exit_on_die(1); | 
| 123 | 123 | ||
| 124 | dies_ok( sub { | 124 | dies_ok( sub { | 
| 125 | $t = Nagios::Plugin::Threshold->set_thresholds( | 125 | $t = Monitoring::Plugin::Threshold->set_thresholds( | 
| 126 | warning => "total", | 126 | warning => "total", | 
| 127 | critical => "rubbish" | 127 | critical => "rubbish" | 
| 128 | ) | 128 | ) | 
| 129 | }, "bad thresholds cause death" | 129 | }, "bad thresholds cause death" | 
| 130 | ); | 130 | ); | 
| 131 | Nagios::Plugin::Functions->print_on_die(0); | 131 | Monitoring::Plugin::Functions->print_on_die(0); | 
| 132 | Nagios::Plugin::Functions->exit_on_die(0); | 132 | Monitoring::Plugin::Functions->exit_on_die(0); | 
| 133 | SKIP_DEATH: | 133 | SKIP_DEATH: | 
| 134 | 134 | ||
| 135 | 135 | ||
| 136 | diag "threshold: critical if > 25 " if $ENV{TEST_VERBOSE}; | 136 | diag "threshold: critical if > 25 " if $ENV{TEST_VERBOSE}; | 
| 137 | $t = Nagios::Plugin::Threshold->set_thresholds( critical => "~:25" ); | 137 | $t = Monitoring::Plugin::Threshold->set_thresholds( critical => "~:25" ); | 
| 138 | ok( defined $t, "Threshold ('', '~:25') set (".$t->critical.")" ); | 138 | ok( defined $t, "Threshold ('', '~:25') set (".$t->critical.")" ); | 
| 139 | ok( ! $t->warning->is_set, "Warning not set"); | 139 | ok( ! $t->warning->is_set, "Warning not set"); | 
| 140 | cmp_ok( $t->critical->end, '==',25, "Critical end set"); | 140 | cmp_ok( $t->critical->end, '==',25, "Critical end set"); | 
| @@ -145,14 +145,14 @@ $expected = { qw( | |||
| 145 | 4 OK | 145 | 4 OK | 
| 146 | 10 OK | 146 | 10 OK | 
| 147 | 14.21 OK | 147 | 14.21 OK | 
| 148 | 25 OK | 148 | 25 OK | 
| 149 | 25.01 CRITICAL | 149 | 25.01 CRITICAL | 
| 150 | 31001 CRITICAL | 150 | 31001 CRITICAL | 
| 151 | ) }; | 151 | ) }; | 
| 152 | test_expected_statuses( $t, $expected); | 152 | test_expected_statuses( $t, $expected); | 
| 153 | 153 | ||
| 154 | diag "threshold: warn if OUTSIDE {10..25} , critical if > 25 " if $ENV{TEST_VERBOSE}; | 154 | diag "threshold: warn if OUTSIDE {10..25} , critical if > 25 " if $ENV{TEST_VERBOSE}; | 
| 155 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => "10:25", critical => "~:25"); | 155 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "10:25", critical => "~:25"); | 
| 156 | ok( defined $t, "Threshold ('10:25', '~:25') set"); | 156 | ok( defined $t, "Threshold ('10:25', '~:25') set"); | 
| 157 | cmp_ok( $t->warning->start, '==', 10, "Warning start set"); | 157 | cmp_ok( $t->warning->start, '==', 10, "Warning start set"); | 
| 158 | cmp_ok( $t->warning->end, '==', 25, "Warning end set"); | 158 | cmp_ok( $t->warning->end, '==', 25, "Warning end set"); | 
| @@ -164,7 +164,7 @@ $expected = { qw( | |||
| 164 | 9.999999 WARNING | 164 | 9.999999 WARNING | 
| 165 | 10 OK | 165 | 10 OK | 
| 166 | 14.21 OK | 166 | 14.21 OK | 
| 167 | 25 OK | 167 | 25 OK | 
| 168 | 25.01 CRITICAL | 168 | 25.01 CRITICAL | 
| 169 | 31001 CRITICAL | 169 | 31001 CRITICAL | 
| 170 | ) }; | 170 | ) }; | 
| @@ -172,7 +172,7 @@ test_expected_statuses( $t, $expected ); | |||
| 172 | 172 | ||
| 173 | 173 | ||
| 174 | diag "warn if INSIDE {10..25} , critical if < 10 " if $ENV{TEST_VERBOSE}; | 174 | diag "warn if INSIDE {10..25} , critical if < 10 " if $ENV{TEST_VERBOSE}; | 
| 175 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => "\@10:25", critical => "10:"); | 175 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => "\@10:25", critical => "10:"); | 
| 176 | $expected = { qw( | 176 | $expected = { qw( | 
| 177 | -1 CRITICAL | 177 | -1 CRITICAL | 
| 178 | 4 CRITICAL | 178 | 4 CRITICAL | 
| @@ -187,7 +187,7 @@ test_expected_statuses( $t, $expected ); | |||
| 187 | 187 | ||
| 188 | 188 | ||
| 189 | # GMC: as of 0.16, set_thresholds can also be called as a mutator | 189 | # GMC: as of 0.16, set_thresholds can also be called as a mutator | 
| 190 | diag "threshold mutator: warn if more than 30; critical if > 60" | 190 | diag "threshold mutator: warn if more than 30; critical if > 60" | 
| 191 | if $ENV{TEST_VERBOSE}; | 191 | if $ENV{TEST_VERBOSE}; | 
| 192 | my $t1 = $t; | 192 | my $t1 = $t; | 
| 193 | $t->set_thresholds(warning => "0:45", critical => "0:90"); | 193 | $t->set_thresholds(warning => "0:45", critical => "0:90"); | 
| @@ -200,16 +200,16 @@ is( $t->critical->end, 90, "Critical end ok"); | |||
| 200 | 200 | ||
| 201 | 201 | ||
| 202 | # Also as of 0.16, accepts N::P::Range objects as arguments | 202 | # Also as of 0.16, accepts N::P::Range objects as arguments | 
| 203 | my $warning = Nagios::Plugin::Range->parse_range_string("50"); | 203 | my $warning = Monitoring::Plugin::Range->parse_range_string("50"); | 
| 204 | my $critical = Nagios::Plugin::Range->parse_range_string("70:90"); | 204 | my $critical = Monitoring::Plugin::Range->parse_range_string("70:90"); | 
| 205 | $t = Nagios::Plugin::Threshold->set_thresholds(warning => $warning, critical => $critical); | 205 | $t = Monitoring::Plugin::Threshold->set_thresholds(warning => $warning, critical => $critical); | 
| 206 | ok( defined $t, "Threshold from ranges ('50', '70:90') set"); | 206 | ok( defined $t, "Threshold from ranges ('50', '70:90') set"); | 
| 207 | is( $t->warning->start, 0, "Warning start ok"); | 207 | is( $t->warning->start, 0, "Warning start ok"); | 
| 208 | is( $t->warning->end, 50, "Warning end ok"); | 208 | is( $t->warning->end, 50, "Warning end ok"); | 
| 209 | is( $t->critical->start, 70, "Critical start ok"); | 209 | is( $t->critical->start, 70, "Critical start ok"); | 
| 210 | is( $t->critical->end, 90, "Critical end ok"); | 210 | is( $t->critical->end, 90, "Critical end ok"); | 
| 211 | 211 | ||
| 212 | $critical = Nagios::Plugin::Range->parse_range_string("90:"); | 212 | $critical = Monitoring::Plugin::Range->parse_range_string("90:"); | 
| 213 | $t->set_thresholds(warning => "~:20", critical => $critical); | 213 | $t->set_thresholds(warning => "~:20", critical => $critical); | 
| 214 | ok( defined $t, "Threshold from string + range ('~:20', '90:') set"); | 214 | ok( defined $t, "Threshold from string + range ('~:20', '90:') set"); | 
| 215 | ok( $t->warning->start_infinity, "Warning start ok (infinity)"); | 215 | ok( $t->warning->start_infinity, "Warning start ok (infinity)"); | 
| diff --git a/t/Nagios-Plugin-02.t b/t/Nagios-Plugin-02.t deleted file mode 100644 index f64fb6f..0000000 --- a/t/Nagios-Plugin-02.t +++ /dev/null | |||
| @@ -1,161 +0,0 @@ | |||
| 1 | # Nagios::Plugin test set 2, testing NP::Functions wrapping | ||
| 2 | |||
| 3 | use strict; | ||
| 4 | use Test::More tests => 103; | ||
| 5 | |||
| 6 | BEGIN { use_ok("Nagios::Plugin") } | ||
| 7 | require Nagios::Plugin::Functions; | ||
| 8 | Nagios::Plugin::Functions::_fake_exit(1); | ||
| 9 | |||
| 10 | # Hardcoded checks of constants | ||
| 11 | my %ERRORS = %Nagios::Plugin::Functions::ERRORS; | ||
| 12 | is(OK, $ERRORS{OK}, "OK => $ERRORS{OK}"); | ||
| 13 | is(WARNING, $ERRORS{WARNING}, "WARNING => $ERRORS{WARNING}"); | ||
| 14 | is(CRITICAL, $ERRORS{CRITICAL}, "CRITICAL => $ERRORS{CRITICAL}"); | ||
| 15 | is(UNKNOWN, $ERRORS{UNKNOWN}, "UNKNOWN => $ERRORS{UNKNOWN}"); | ||
| 16 | is(DEPENDENT, $ERRORS{DEPENDENT}, "DEPENDENT => $ERRORS{DEPENDENT}"); | ||
| 17 | |||
| 18 | my $plugin = 'TEST_PLUGIN'; | ||
| 19 | my $np = Nagios::Plugin->new( shortname => $plugin ); | ||
| 20 | is($np->shortname, $plugin, "shortname() is $plugin"); | ||
| 21 | |||
| 22 | # Test nagios_exit( CONSTANT, $msg ), nagios_exit( $string, $msg ) | ||
| 23 | my $r; | ||
| 24 | my @ok = ( | ||
| 25 | [ OK, "OK", 'test the first', ], | ||
| 26 | [ WARNING, "WARNING", 'test the second', ], | ||
| 27 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 28 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 29 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 30 | ); | ||
| 31 | for (@ok) { | ||
| 32 | # CONSTANT | ||
| 33 | $r = $np->nagios_exit($_->[0], $_->[2]); | ||
| 34 | is($r->return_code, $_->[0], | ||
| 35 | sprintf('nagios_exit(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 36 | like($r->message, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 37 | sprintf('nagios_exit(%s, $msg) output matched "%s"', $_->[1], | ||
| 38 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 39 | |||
| 40 | # $string | ||
| 41 | $r = $np->nagios_exit($_->[1], $_->[2]); | ||
| 42 | is($r->return_code, $_->[0], | ||
| 43 | sprintf('nagios_exit("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 44 | like($r->message, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 45 | sprintf('nagios_exit("%s", $msg) output matched "%s"', $_->[1], | ||
| 46 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 47 | like($r, qr/$plugin\b.*$_->[1]\b.*\b$_->[2]$/, | ||
| 48 | sprintf('nagios_exit("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 49 | $plugin . ' ' . $_->[1] . '.*' . $_->[2])); | ||
| 50 | } | ||
| 51 | |||
| 52 | # nagios_exit code corner cases | ||
| 53 | my @ugly1 = ( | ||
| 54 | [ -1, 'testing code -1' ], | ||
| 55 | [ 7, 'testing code 7' ], | ||
| 56 | [ undef, 'testing code undef' ], | ||
| 57 | [ '', qq(testing code '') ], | ||
| 58 | [ 'string', qq(testing code 'string') ], | ||
| 59 | ); | ||
| 60 | for (@ugly1) { | ||
| 61 | $r = $np->nagios_exit($_->[0], $_->[1]); | ||
| 62 | my $display = defined $_->[0] ? "'$_->[0]'" : 'undef'; | ||
| 63 | is($r->return_code, UNKNOWN, "nagios_exit($display, \$msg) returned ". UNKNOWN); | ||
| 64 | like($r->message, qr/UNKNOWN\b.*\b$_->[1]$/, | ||
| 65 | sprintf('nagios_exit(%s, $msg) output matched "%s"', | ||
| 66 | $display, 'UNKNOWN.*' . $_->[1])); | ||
| 67 | } | ||
| 68 | |||
| 69 | # nagios_exit message corner cases | ||
| 70 | my @ugly2 = ( | ||
| 71 | [ '' ], | ||
| 72 | [ undef ], | ||
| 73 | [ UNKNOWN ], | ||
| 74 | ); | ||
| 75 | for (@ugly2) { | ||
| 76 | $r = $np->nagios_exit(CRITICAL, $_->[0]); | ||
| 77 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 78 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 79 | like($r->message, qr/CRITICAL\b.*\b$display2$/, | ||
| 80 | sprintf('nagios_exit(%s, $msg) output matched "%s"', | ||
| 81 | $display1, "CRITICAL.*$display2")); | ||
| 82 | } | ||
| 83 | |||
| 84 | # Test nagios_die( $msg ) | ||
| 85 | my @msg = ( | ||
| 86 | [ 'die you dog' ], | ||
| 87 | [ '' ], | ||
| 88 | [ undef ], | ||
| 89 | ); | ||
| 90 | for (@msg) { | ||
| 91 | $r = $np->nagios_die($_->[0]); | ||
| 92 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 93 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 94 | is($r->return_code, UNKNOWN, | ||
| 95 | sprintf('nagios_die(%s) returned UNKNOWN', $display1)); | ||
| 96 | like($r->message, qr/UNKNOWN\b.*\b$display2$/, | ||
| 97 | sprintf('nagios_die(%s) output matched "%s"', $display1, | ||
| 98 | "UNKNOWN.*$display2")); | ||
| 99 | } | ||
| 100 | |||
| 101 | # Test nagios_die( CONSTANT, $msg ), nagios_die( $msg, CONSTANT ), | ||
| 102 | # nagios_die( $string, $msg ), and nagios_die( $msg, $string ) | ||
| 103 | @ok = ( | ||
| 104 | [ OK, "OK", 'test the first', ], | ||
| 105 | [ WARNING, "WARNING", 'test the second', ], | ||
| 106 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 107 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 108 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 109 | ); | ||
| 110 | for (@ok) { | ||
| 111 | # CONSTANT, $msg | ||
| 112 | $r = $np->nagios_die($_->[0], $_->[2]); | ||
| 113 | is($r->return_code, $_->[0], | ||
| 114 | sprintf('nagios_die(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 115 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 116 | sprintf('nagios_die(%s, $msg) output matched "%s"', | ||
| 117 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 118 | |||
| 119 | # $msg, CONSTANT | ||
| 120 | $r = $np->nagios_die($_->[2], $_->[0]); | ||
| 121 | is($r->return_code, $_->[0], | ||
| 122 | sprintf('nagios_die($msg, %s) returned %s', $_->[1], $_->[0])); | ||
| 123 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 124 | sprintf('nagios_die($msg, %s) output matched "%s"', | ||
| 125 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 126 | |||
| 127 | # $string, $msg | ||
| 128 | $r = $np->nagios_die($_->[1], $_->[2]); | ||
| 129 | is($r->return_code, $_->[0], | ||
| 130 | sprintf('nagios_die("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 131 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 132 | sprintf('nagios_die("%s", $msg) output matched "%s"', $_->[1], | ||
| 133 | $_->[1] . '.*' . $_->[2])); | ||
| 134 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 135 | sprintf('nagios_die("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 136 | $_->[1] . '.*' . $_->[2])); | ||
| 137 | |||
| 138 | # $string, $msg | ||
| 139 | $r = $np->nagios_die($_->[2], $_->[1]); | ||
| 140 | is($r->return_code, $_->[0], | ||
| 141 | sprintf('nagios_die($msg, "%s") returned %s', $_->[1], $_->[0])); | ||
| 142 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 143 | sprintf('nagios_die($msg, "%s") output matched "%s"', $_->[1], | ||
| 144 | $_->[1] . '.*' . $_->[2])); | ||
| 145 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 146 | sprintf('nagios_die($msg, "%s") stringified matched "%s"', $_->[1], | ||
| 147 | $_->[1] . '.*' . $_->[2])); | ||
| 148 | } | ||
| 149 | |||
| 150 | |||
| 151 | # shortname testing | ||
| 152 | SKIP: { | ||
| 153 | skip "requires File::Basename", 2 unless eval { require File::Basename }; | ||
| 154 | $np = Nagios::Plugin->new( version => "1"); | ||
| 155 | $plugin = uc File::Basename::basename($0); | ||
| 156 | $plugin =~ s/\..*$//; | ||
| 157 | is($np->shortname, $plugin, "shortname() is '$plugin'"); | ||
| 158 | $r = $np->nagios_exit(OK, "foobar"); | ||
| 159 | like($r->message, qr/^$plugin OK/, "message begins with '$plugin OK'"); | ||
| 160 | } | ||
| 161 | |||
| diff --git a/t/Nagios-Plugin-Functions-01.t b/t/Nagios-Plugin-Functions-01.t deleted file mode 100644 index 5268255..0000000 --- a/t/Nagios-Plugin-Functions-01.t +++ /dev/null | |||
| @@ -1,161 +0,0 @@ | |||
| 1 | |||
| 2 | use strict; | ||
| 3 | use Test::More tests => 113; | ||
| 4 | |||
| 5 | BEGIN { use_ok("Nagios::Plugin::Functions", ":all"); } | ||
| 6 | Nagios::Plugin::Functions::_fake_exit(1); | ||
| 7 | |||
| 8 | my $this_version=$Nagios::Plugin::Functions::VERSION; | ||
| 9 | foreach my $m ("", qw(::Threshold ::Getopt ::Performance ::Range)) { | ||
| 10 | my $mod = "Nagios::Plugin$m"; | ||
| 11 | use_ok($mod); | ||
| 12 | # Lots of hackery below. Easier to say $mod->VERSION, but this is probably a recent perl thing | ||
| 13 | my $v = "$mod"."::VERSION"; | ||
| 14 | my $a = eval "\$$v"; | ||
| 15 | is($a, $this_version, "Version number for $mod the same as Functions: $this_version"); | ||
| 16 | } | ||
| 17 | |||
| 18 | # check get_shortname | ||
| 19 | is(get_shortname, "NAGIOS-PLUGIN-FUNCTIONS-01", "get_shortname ok"); | ||
| 20 | |||
| 21 | # Hardcoded checks of constants | ||
| 22 | ok(defined %ERRORS, '%ERRORS defined'); | ||
| 23 | is(OK, $ERRORS{OK}, "OK => $ERRORS{OK}"); | ||
| 24 | is(WARNING, $ERRORS{WARNING}, "WARNING => $ERRORS{WARNING}"); | ||
| 25 | is(CRITICAL, $ERRORS{CRITICAL}, "CRITICAL => $ERRORS{CRITICAL}"); | ||
| 26 | is(UNKNOWN, $ERRORS{UNKNOWN}, "UNKNOWN => $ERRORS{UNKNOWN}"); | ||
| 27 | is(DEPENDENT, $ERRORS{DEPENDENT}, "DEPENDENT => $ERRORS{DEPENDENT}"); | ||
| 28 | |||
| 29 | # Test nagios_exit( CONSTANT, $msg ), nagios_exit( $string, $msg ) | ||
| 30 | my $r; | ||
| 31 | my @ok = ( | ||
| 32 | [ OK, "OK", 'test the first', ], | ||
| 33 | [ WARNING, "WARNING", 'test the second', ], | ||
| 34 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 35 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 36 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 37 | ); | ||
| 38 | for (@ok) { | ||
| 39 | # CONSTANT | ||
| 40 | $r = nagios_exit($_->[0], $_->[2]); | ||
| 41 | is($r->return_code, $_->[0], | ||
| 42 | sprintf('nagios_exit(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 43 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 44 | sprintf('nagios_exit(%s, $msg) output matched "%s"', | ||
| 45 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 46 | |||
| 47 | # $string | ||
| 48 | $r = nagios_exit($_->[1], $_->[2]); | ||
| 49 | is($r->return_code, $_->[0], | ||
| 50 | sprintf('nagios_exit("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 51 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 52 | sprintf('nagios_exit("%s", $msg) output matched "%s"', $_->[1], | ||
| 53 | $_->[1] . '.*' . $_->[2])); | ||
| 54 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 55 | sprintf('nagios_exit("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 56 | $_->[1] . '.*' . $_->[2])); | ||
| 57 | } | ||
| 58 | |||
| 59 | # nagios_exit code corner cases | ||
| 60 | my @ugly1 = ( | ||
| 61 | [ -1, 'testing code -1' ], | ||
| 62 | [ 7, 'testing code 7' ], | ||
| 63 | [ undef, 'testing code undef' ], | ||
| 64 | [ '', qq(testing code '') ], | ||
| 65 | [ 'string', qq(testing code 'string') ], | ||
| 66 | ); | ||
| 67 | for (@ugly1) { | ||
| 68 | $r = nagios_exit($_->[0], $_->[1]); | ||
| 69 | my $display = defined $_->[0] ? "'$_->[0]'" : 'undef'; | ||
| 70 | is($r->return_code, UNKNOWN, "nagios_exit($display, \$msg) returned ". UNKNOWN); | ||
| 71 | like($r->message, qr/UNKNOWN\b.*\b$_->[1]$/, | ||
| 72 | sprintf('nagios_exit(%s, $msg) output matched "%s"', | ||
| 73 | $display, 'UNKNOWN.*' . $_->[1])); | ||
| 74 | } | ||
| 75 | |||
| 76 | # nagios_exit message corner cases | ||
| 77 | my @ugly2 = ( | ||
| 78 | [ '' ], | ||
| 79 | [ undef ], | ||
| 80 | [ UNKNOWN ], | ||
| 81 | ); | ||
| 82 | for (@ugly2) { | ||
| 83 | $r = nagios_exit(CRITICAL, $_->[0]); | ||
| 84 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 85 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 86 | like($r->message, qr/CRITICAL\b.*\b$display2$/, | ||
| 87 | sprintf('nagios_exit(%s, $msg) output matched "%s"', | ||
| 88 | $display1, "CRITICAL.*$display2")); | ||
| 89 | } | ||
| 90 | |||
| 91 | # Test nagios_die( $msg ) | ||
| 92 | my @msg = ( | ||
| 93 | [ 'die you dog' ], | ||
| 94 | [ '' ], | ||
| 95 | [ undef ], | ||
| 96 | ); | ||
| 97 | for (@msg) { | ||
| 98 | $r = nagios_die($_->[0]); | ||
| 99 | my $display1 = defined $_->[0] ? "'$_->[0]'" : "undef"; | ||
| 100 | my $display2 = defined $_->[0] ? $_->[0] : ''; | ||
| 101 | is($r->return_code, UNKNOWN, | ||
| 102 | sprintf('nagios_die(%s) returned UNKNOWN', $display1)); | ||
| 103 | like($r->message, qr/UNKNOWN\b.*\b$display2$/, | ||
| 104 | sprintf('nagios_die(%s) output matched "%s"', $display1, | ||
| 105 | "UNKNOWN.*$display2")); | ||
| 106 | } | ||
| 107 | |||
| 108 | # Test nagios_die( CONSTANT, $msg ), nagios_die( $msg, CONSTANT ), | ||
| 109 | # nagios_die( $string, $msg ), and nagios_die( $msg, $string ) | ||
| 110 | @ok = ( | ||
| 111 | [ OK, "OK", 'test the first', ], | ||
| 112 | [ WARNING, "WARNING", 'test the second', ], | ||
| 113 | [ CRITICAL, "CRITICAL", 'test the third', ], | ||
| 114 | [ UNKNOWN, "UNKNOWN", 'test the fourth', ], | ||
| 115 | [ DEPENDENT, "DEPENDENT", 'test the fifth', ], | ||
| 116 | ); | ||
| 117 | for (@ok) { | ||
| 118 | # CONSTANT, $msg | ||
| 119 | $r = nagios_die($_->[0], $_->[2]); | ||
| 120 | is($r->return_code, $_->[0], | ||
| 121 | sprintf('nagios_die(%s, $msg) returned %s', $_->[1], $_->[0])); | ||
| 122 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 123 | sprintf('nagios_die(%s, $msg) output matched "%s"', | ||
| 124 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 125 | |||
| 126 | # $msg, CONSTANT | ||
| 127 | $r = nagios_die($_->[2], $_->[0]); | ||
| 128 | is($r->return_code, $_->[0], | ||
| 129 | sprintf('nagios_die($msg, %s) returned %s', $_->[1], $_->[0])); | ||
| 130 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 131 | sprintf('nagios_die($msg, %s) output matched "%s"', | ||
| 132 | $_->[1], $_->[1] . '.*' . $_->[2])); | ||
| 133 | |||
| 134 | # $string, $msg | ||
| 135 | $r = nagios_die($_->[1], $_->[2]); | ||
| 136 | is($r->return_code, $_->[0], | ||
| 137 | sprintf('nagios_die("%s", $msg) returned %s', $_->[1], $_->[0])); | ||
| 138 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 139 | sprintf('nagios_die("%s", $msg) output matched "%s"', $_->[1], | ||
| 140 | $_->[1] . '.*' . $_->[2])); | ||
| 141 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 142 | sprintf('nagios_die("%s", $msg) stringified matched "%s"', $_->[1], | ||
| 143 | $_->[1] . '.*' . $_->[2])); | ||
| 144 | |||
| 145 | # $string, $msg | ||
| 146 | $r = nagios_die($_->[2], $_->[1]); | ||
| 147 | is($r->return_code, $_->[0], | ||
| 148 | sprintf('nagios_die($msg, "%s") returned %s', $_->[1], $_->[0])); | ||
| 149 | like($r->message, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 150 | sprintf('nagios_die($msg, "%s") output matched "%s"', $_->[1], | ||
| 151 | $_->[1] . '.*' . $_->[2])); | ||
| 152 | like($r, qr/$_->[1]\b.*\b$_->[2]$/, | ||
| 153 | sprintf('nagios_die($msg, "%s") stringified matched "%s"', $_->[1], | ||
| 154 | $_->[1] . '.*' . $_->[2])); | ||
| 155 | } | ||
| 156 | |||
| 157 | # Check that _use_die set to 1 will catch exceptions correctly | ||
| 158 | Nagios::Plugin::Functions::_fake_exit(0); | ||
| 159 | Nagios::Plugin::Functions::_use_die(1); | ||
| 160 | eval { nagios_die("Using die") }; | ||
| 161 | is( $@, "NAGIOS-PLUGIN-FUNCTIONS-01 UNKNOWN - Using die\n", "Caught exception"); | ||
| diff --git a/t/Nagios-Plugin-Performance-02.t b/t/Nagios-Plugin-Performance-02.t deleted file mode 100644 index c0c5a71..0000000 --- a/t/Nagios-Plugin-Performance-02.t +++ /dev/null | |||
| @@ -1,13 +0,0 @@ | |||
| 1 | |||
| 2 | use strict; | ||
| 3 | use Test::More tests => 3; | ||
| 4 | use_ok("Nagios::Plugin::Performance", use_die => 1); | ||
| 5 | |||
| 6 | eval { Nagios::Plugin::Functions::nagios_die("Testing") }; | ||
| 7 | is( $@, "NAGIOS-PLUGIN-PERFORMANCE-02 UNKNOWN - Testing\n", "use_die correctly set on import"); | ||
| 8 | |||
| 9 | |||
| 10 | use_ok("Nagios::Plugin::Performance"); | ||
| 11 | eval { Nagios::Plugin::Functions::nagios_die("Test OK exit", 0) }; | ||
| 12 | |||
| 13 | fail("Should not get here if code works correctly because prior nagios_die should have exited"); | ||
| diff --git a/t/check_stuff.pl b/t/check_stuff.pl index 112a18a..4fc125c 100755 --- a/t/check_stuff.pl +++ b/t/check_stuff.pl | |||
| @@ -2,21 +2,21 @@ | |||
| 2 | 2 | ||
| 3 | ### check_stuff.pl | 3 | ### check_stuff.pl | 
| 4 | 4 | ||
| 5 | # an example Nagios plugin using the Nagios::Plugin modules. | 5 | # an example Monitoring plugin using the Monitoring::Plugin modules. | 
| 6 | 6 | ||
| 7 | # Originally by Nathan Vonnahme, n8v at users dot sourceforge | 7 | # Originally by Nathan Vonnahme, n8v at users dot sourceforge | 
| 8 | # dot net, July 19 2006 | 8 | # dot net, July 19 2006 | 
| 9 | 9 | ||
| 10 | # Please modify to your heart's content and use as the basis for all | 10 | # Please modify to your heart's content and use as the basis for all | 
| 11 | # the really cool Nagios monitoring scripts you're going to create. | 11 | # the really cool monitoring scripts you're going to create. | 
| 12 | # You rock. | 12 | # You rock. | 
| 13 | 13 | ||
| 14 | ############################################################################## | 14 | ############################################################################## | 
| 15 | # prologue | 15 | # prologue | 
| 16 | use strict; | 16 | use strict; | 
| 17 | use warnings; | 17 | use warnings; | 
| 18 | 18 | ||
| 19 | use Nagios::Plugin ; | 19 | use Monitoring::Plugin; | 
| 20 | 20 | ||
| 21 | use vars qw($VERSION $PROGNAME $verbose $warn $critical $timeout $result); | 21 | use vars qw($VERSION $PROGNAME $verbose $warn $critical $timeout $result); | 
| 22 | $VERSION = '1.0'; | 22 | $VERSION = '1.0'; | 
| @@ -28,18 +28,18 @@ $PROGNAME = basename($0); | |||
| 28 | 28 | ||
| 29 | ############################################################################## | 29 | ############################################################################## | 
| 30 | # define and get the command line options. | 30 | # define and get the command line options. | 
| 31 | # see the command line option guidelines at | 31 | # see the command line option guidelines at | 
| 32 | # http://nagiosplug.sourceforge.net/developer-guidelines.html#PLUGOPTIONS | 32 | # https://www.monitoring-plugins.org/doc/guidelines.html#PLUGOPTIONS | 
| 33 | 33 | ||
| 34 | 34 | ||
| 35 | # Instantiate Nagios::Plugin object (the 'usage' parameter is mandatory) | 35 | # Instantiate Monitoring::Plugin object (the 'usage' parameter is mandatory) | 
| 36 | my $p = Nagios::Plugin->new( | 36 | my $p = Monitoring::Plugin->new( | 
| 37 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] | 37 | usage => "Usage: %s [ -v|--verbose ] [-H <host>] [-t <timeout>] | 
| 38 | [ -c|--critical=<critical threshold> ] | 38 | [ -c|--critical=<critical threshold> ] | 
| 39 | [ -w|--warning=<warning threshold> ] | 39 | [ -w|--warning=<warning threshold> ] | 
| 40 | [ -r|--result = <INTEGER> ]", | 40 | [ -r|--result = <INTEGER> ]", | 
| 41 | version => $VERSION, | 41 | version => $VERSION, | 
| 42 | blurb => 'This plugin is an example of a Nagios plugin written in Perl using the Nagios::Plugin modules. It will generate a random integer between 1 and 20 (though you can specify the number with the -n option for testing), and will output OK, WARNING or CRITICAL if the resulting number is outside the specified thresholds.', | 42 | blurb => 'This plugin is an example of a monitoring plugin written in Perl using the Monitoring::Plugin modules. It will generate a random integer between 1 and 20 (though you can specify the number with the -n option for testing), and will output OK, WARNING or CRITICAL if the resulting number is outside the specified thresholds.', | 
| 43 | 43 | ||
| 44 | extra => " | 44 | extra => " | 
| 45 | 45 | ||
| @@ -47,11 +47,7 @@ THRESHOLDs for -w and -c are specified 'min:max' or 'min:' or ':max' | |||
| 47 | (or 'max'). If specified '\@min:max', a warning status will be generated | 47 | (or 'max'). If specified '\@min:max', a warning status will be generated | 
| 48 | if the count *is* inside the specified range. | 48 | if the count *is* inside the specified range. | 
| 49 | 49 | ||
| 50 | See more threshold examples at http | 50 | See more threshold examples at https://www.monitoring-plugins.org/doc/guidelines.html#THRESHOLDFORMAT | 
| 51 | : // nagiosplug | ||
| 52 | . sourceforge | ||
| 53 | . net / developer-guidelines | ||
| 54 | . html #THRESHOLDFORMAT | ||
| 55 | 51 | ||
| 56 | Examples: | 52 | Examples: | 
| 57 | 53 | ||
| @@ -75,7 +71,7 @@ See more threshold examples at http | |||
| 75 | $p->add_arg( | 71 | $p->add_arg( | 
| 76 | spec => 'warning|w=s', | 72 | spec => 'warning|w=s', | 
| 77 | 73 | ||
| 78 | help => | 74 | help => | 
| 79 | qq{-w, --warning=INTEGER:INTEGER | 75 | qq{-w, --warning=INTEGER:INTEGER | 
| 80 | Minimum and maximum number of allowable result, outside of which a | 76 | Minimum and maximum number of allowable result, outside of which a | 
| 81 | warning will be generated. If omitted, no warning is generated.}, | 77 | warning will be generated. If omitted, no warning is generated.}, | 
| @@ -86,7 +82,7 @@ qq{-w, --warning=INTEGER:INTEGER | |||
| 86 | 82 | ||
| 87 | $p->add_arg( | 83 | $p->add_arg( | 
| 88 | spec => 'critical|c=s', | 84 | spec => 'critical|c=s', | 
| 89 | help => | 85 | help => | 
| 90 | qq{-c, --critical=INTEGER:INTEGER | 86 | qq{-c, --critical=INTEGER:INTEGER | 
| 91 | Minimum and maximum number of the generated result, outside of | 87 | Minimum and maximum number of the generated result, outside of | 
| 92 | which a critical will be generated. }, | 88 | which a critical will be generated. }, | 
| @@ -94,7 +90,7 @@ qq{-c, --critical=INTEGER:INTEGER | |||
| 94 | 90 | ||
| 95 | $p->add_arg( | 91 | $p->add_arg( | 
| 96 | spec => 'result|r=f', | 92 | spec => 'result|r=f', | 
| 97 | help => | 93 | help => | 
| 98 | qq{-r, --result=INTEGER | 94 | qq{-r, --result=INTEGER | 
| 99 | Specify the result on the command line rather than generating a | 95 | Specify the result on the command line rather than generating a | 
| 100 | random number. For testing.}, | 96 | random number. For testing.}, | 
| @@ -106,11 +102,11 @@ $p->getopts; | |||
| 106 | 102 | ||
| 107 | # perform sanity checking on command line options | 103 | # perform sanity checking on command line options | 
| 108 | if ( (defined $p->opts->result) && ($p->opts->result < 0 || $p->opts->result > 20) ) { | 104 | if ( (defined $p->opts->result) && ($p->opts->result < 0 || $p->opts->result > 20) ) { | 
| 109 | $p->nagios_die( " invalid number supplied for the -r option " ); | 105 | $p->plugin_die( " invalid number supplied for the -r option " ); | 
| 110 | } | 106 | } | 
| 111 | 107 | ||
| 112 | unless ( defined $p->opts->warning || defined $p->opts->critical ) { | 108 | unless ( defined $p->opts->warning || defined $p->opts->critical ) { | 
| 113 | $p->nagios_die( " you didn't supply a threshold argument " ); | 109 | $p->plugin_die( " you didn't supply a threshold argument " ); | 
| 114 | } | 110 | } | 
| 115 | 111 | ||
| 116 | 112 | ||
| @@ -135,8 +131,7 @@ else { | |||
| 135 | ############################################################################## | 131 | ############################################################################## | 
| 136 | # check the result against the defined warning and critical thresholds, | 132 | # check the result against the defined warning and critical thresholds, | 
| 137 | # output the result and exit | 133 | # output the result and exit | 
| 138 | $p->nagios_exit( | 134 | $p->plugin_exit( | 
| 139 | return_code => $p->check_threshold($result), | 135 | return_code => $p->check_threshold($result), | 
| 140 | message => " sample result was $result" | 136 | message => " sample result was $result" | 
| 141 | ); | 137 | ); | 
| 142 | |||
| diff --git a/t/check_stuff.t b/t/check_stuff.t index 2815b76..6a1d845 100755 --- a/t/check_stuff.t +++ b/t/check_stuff.t | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | #!/usr/local/bin/perl | 1 | #!/usr/local/bin/perl | 
| 2 | # | 2 | # | 
| 3 | use strict; use warnings; | 3 | use strict; use warnings; | 
| 4 | #use Test::More qw(no_plan); | 4 | #use Test::More qw(no_plan); | 
| 5 | use Test::More tests => 14; | 5 | use Test::More tests => 14; | 
| @@ -10,7 +10,7 @@ $s = "$^X -Ilib $s"; | |||
| 10 | 10 | ||
| 11 | my $n = 'STUFF'; | 11 | my $n = 'STUFF'; | 
| 12 | 12 | ||
| 13 | # Nagios status strings and exit codes | 13 | # Monitoring status strings and exit codes | 
| 14 | my %e = qw( | 14 | my %e = qw( | 
| 15 | OK 0 | 15 | OK 0 | 
| 16 | WARNING 1 | 16 | WARNING 1 | 
| @@ -58,9 +58,3 @@ sub test_expected { | |||
| 58 | like $r, qr/^$n $expected->{$_}/i, "looks $expected->{$_} with $_"; | 58 | like $r, qr/^$n $expected->{$_}/i, "looks $expected->{$_} with $_"; | 
| 59 | } | 59 | } | 
| 60 | } | 60 | } | 
| 61 | |||
| 62 | |||
| 63 | |||
| 64 | |||
| 65 | |||
| 66 | |||
| diff --git a/t/npg03/README b/t/npg03/README index 3dbdaf8..541ece7 100644 --- a/t/npg03/README +++ b/t/npg03/README | |||
| @@ -1,15 +1,15 @@ | |||
| 1 | Nagios-Plugin-Getopt-03.t automatically tests all cases defined in | 1 | Monitoring-Plugin-Getopt-03.t automatically tests all cases defined in | 
| 2 | the 'input' directory and expects the output to match the | 2 | the 'input' directory and expects the output to match the | 
| 3 | corresponding file in the 'expected' directory. To define a new test | 3 | corresponding file in the 'expected' directory. To define a new test | 
| 4 | case, just create a new file in the 'input' directory containing the | 4 | case, just create a new file in the 'input' directory containing the | 
| 5 | input command line, and a corresponding file in the 'expected' | 5 | input command line, and a corresponding file in the 'expected' | 
| 6 | directory containing what you think the expanded command line should | 6 | directory containing what you think the expanded command line should | 
| 7 | be. Note that this expansion is normalised as follows: | 7 | be. Note that this expansion is normalised as follows: | 
| 8 | 8 | ||
| 9 | - command line arguments are reported in alphabetical order | 9 | - command line arguments are reported in alphabetical order | 
| 10 | - extraneous white space is removed | 10 | - extraneous white space is removed | 
| 11 | 11 | ||
| 12 | Also, if you use a completely new argument than those currently | 12 | Also, if you use a completely new argument than those currently | 
| 13 | defined in Nagios-Plugin-Getopt-03.t you will need to define it | 13 | defined in Monitoring-Plugin-Getopt-03.t you will need to define it | 
| 14 | there as well. | 14 | there as well. | 
| 15 | 15 | ||
