diff options
| -rw-r--r-- | NEWS | 1 | ||||
| -rw-r--r-- | lib/utils_base.h | 3 | ||||
| -rw-r--r-- | plugins/check_snmp.c | 250 | ||||
| -rw-r--r-- | plugins/t/check_snmp.t | 31 | 
4 files changed, 86 insertions, 199 deletions
| @@ -37,6 +37,7 @@ This file documents the major additions and syntax changes between releases. | |||
| 37 | check_http: Add SSL/TLS hostname extension support (SNI) - (#1939022 - Joe Presbrey) | 37 | check_http: Add SSL/TLS hostname extension support (SNI) - (#1939022 - Joe Presbrey) | 
| 38 | Fixed wrong perfdata label for output traffic in check_mrtgtraf (#2654308 - Gavin Williams) | 38 | Fixed wrong perfdata label for output traffic in check_mrtgtraf (#2654308 - Gavin Williams) | 
| 39 | Fixed check_by_ssh interpretation of quotes in -C parameter (#1985246, #2268675) | 39 | Fixed check_by_ssh interpretation of quotes in -C parameter (#1985246, #2268675) | 
| 40 | check_snmp now supports standard threshold ranges and doubles (floating numbers) in thresholds | ||
| 40 | 41 | ||
| 41 | 1.4.13 25th Sept 2008 | 42 | 1.4.13 25th Sept 2008 | 
| 42 | Fix Debian bug #460097: check_http --max-age broken (Hilko Bengen) | 43 | Fix Debian bug #460097: check_http --max-age broken (Hilko Bengen) | 
| diff --git a/lib/utils_base.h b/lib/utils_base.h index f40fdb0f..49e40a63 100644 --- a/lib/utils_base.h +++ b/lib/utils_base.h | |||
| @@ -35,6 +35,9 @@ void print_thresholds(const char *, thresholds *); | |||
| 35 | int check_range(double, range *); | 35 | int check_range(double, range *); | 
| 36 | int get_status(double, thresholds *); | 36 | int get_status(double, thresholds *); | 
| 37 | 37 | ||
| 38 | /* All possible characters in a threshold range */ | ||
| 39 | #define NP_THRESHOLDS_CHARS "0123456789.:@~" | ||
| 40 | |||
| 38 | char *np_escaped_string (const char *); | 41 | char *np_escaped_string (const char *); | 
| 39 | 42 | ||
| 40 | void die (int, const char *, ...) __attribute__((noreturn,format(printf, 2, 3))); | 43 | void die (int, const char *, ...) __attribute__((noreturn,format(printf, 2, 3))); | 
| diff --git a/plugins/check_snmp.c b/plugins/check_snmp.c index 94b75b9f..dff5bccd 100644 --- a/plugins/check_snmp.c +++ b/plugins/check_snmp.c | |||
| @@ -53,33 +53,14 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net"; | |||
| 53 | #define CRIT_PRESENT 1 | 53 | #define CRIT_PRESENT 1 | 
| 54 | #define CRIT_STRING 2 | 54 | #define CRIT_STRING 2 | 
| 55 | #define CRIT_REGEX 4 | 55 | #define CRIT_REGEX 4 | 
| 56 | #define CRIT_GT 8 | 56 | #define WARN_PRESENT 8 | 
| 57 | #define CRIT_LT 16 | 57 | #define WARN_STRING 16 | 
| 58 | #define CRIT_GE 32 | 58 | #define WARN_REGEX 32 | 
| 59 | #define CRIT_LE 64 | ||
| 60 | #define CRIT_EQ 128 | ||
| 61 | #define CRIT_NE 256 | ||
| 62 | #define CRIT_RANGE 512 | ||
| 63 | #define WARN_PRESENT 1024 | ||
| 64 | #define WARN_STRING 2048 | ||
| 65 | #define WARN_REGEX 4096 | ||
| 66 | #define WARN_GT 8192 | ||
| 67 | #define WARN_LT 16384 | ||
| 68 | #define WARN_GE 32768 | ||
| 69 | #define WARN_LE 65536 | ||
| 70 | #define WARN_EQ 131072 | ||
| 71 | #define WARN_NE 262144 | ||
| 72 | #define WARN_RANGE 524288 | ||
| 73 | 59 | ||
| 74 | #define MAX_OIDS 8 | 60 | #define MAX_OIDS 8 | 
| 75 | #define MAX_DELIM_LENGTH 8 | ||
| 76 | 61 | ||
| 77 | int process_arguments (int, char **); | 62 | int process_arguments (int, char **); | 
| 78 | int validate_arguments (void); | 63 | int validate_arguments (void); | 
| 79 | char *clarify_message (char *); | ||
| 80 | int check_num (int); | ||
| 81 | int llu_getll (unsigned long long *, char *); | ||
| 82 | int llu_getul (unsigned long long *, char *); | ||
| 83 | char *thisarg (char *str); | 64 | char *thisarg (char *str); | 
| 84 | char *nextarg (char *str); | 65 | char *nextarg (char *str); | 
| 85 | void print_usage (void); | 66 | void print_usage (void); | 
| @@ -89,7 +70,6 @@ void print_help (void); | |||
| 89 | char regex_expect[MAX_INPUT_BUFFER] = ""; | 70 | char regex_expect[MAX_INPUT_BUFFER] = ""; | 
| 90 | regex_t preg; | 71 | regex_t preg; | 
| 91 | regmatch_t pmatch[10]; | 72 | regmatch_t pmatch[10]; | 
| 92 | char timestamp[10] = ""; | ||
| 93 | char errbuf[MAX_INPUT_BUFFER] = ""; | 73 | char errbuf[MAX_INPUT_BUFFER] = ""; | 
| 94 | char perfstr[MAX_INPUT_BUFFER] = "| "; | 74 | char perfstr[MAX_INPUT_BUFFER] = "| "; | 
| 95 | int cflags = REG_EXTENDED | REG_NOSUB | REG_NEWLINE; | 75 | int cflags = REG_EXTENDED | REG_NOSUB | REG_NEWLINE; | 
| @@ -122,15 +102,12 @@ int numoids = 0; | |||
| 122 | int numauthpriv = 0; | 102 | int numauthpriv = 0; | 
| 123 | int verbose = FALSE; | 103 | int verbose = FALSE; | 
| 124 | int usesnmpgetnext = FALSE; | 104 | int usesnmpgetnext = FALSE; | 
| 125 | unsigned long long lower_warn_lim[MAX_OIDS]; | 105 | char *warning_thresholds = NULL; | 
| 126 | unsigned long long upper_warn_lim[MAX_OIDS]; | 106 | char *critical_thresholds = NULL; | 
| 127 | unsigned long long lower_crit_lim[MAX_OIDS]; | 107 | thresholds *thlds[MAX_OIDS]; | 
| 128 | unsigned long long upper_crit_lim[MAX_OIDS]; | 108 | double response_value[MAX_OIDS]; | 
| 129 | unsigned long long response_value[MAX_OIDS]; | ||
| 130 | int check_warning_value = FALSE; | ||
| 131 | int check_critical_value = FALSE; | ||
| 132 | int retries = 0; | 109 | int retries = 0; | 
| 133 | unsigned long long eval_method[MAX_OIDS]; | 110 | int eval_method[MAX_OIDS]; | 
| 134 | char *delimiter; | 111 | char *delimiter; | 
| 135 | char *output_delim; | 112 | char *output_delim; | 
| 136 | char *miblist = NULL; | 113 | char *miblist = NULL; | 
| @@ -140,7 +117,7 @@ int needmibs = FALSE; | |||
| 140 | int | 117 | int | 
| 141 | main (int argc, char **argv) | 118 | main (int argc, char **argv) | 
| 142 | { | 119 | { | 
| 143 | int i = 0; | 120 | int i; | 
| 144 | int iresult = STATE_UNKNOWN; | 121 | int iresult = STATE_UNKNOWN; | 
| 145 | int result = STATE_UNKNOWN; | 122 | int result = STATE_UNKNOWN; | 
| 146 | int return_code = 0; | 123 | int return_code = 0; | 
| @@ -152,6 +129,8 @@ main (int argc, char **argv) | |||
| 152 | char *outbuff; | 129 | char *outbuff; | 
| 153 | char *ptr = NULL; | 130 | char *ptr = NULL; | 
| 154 | char *show = NULL; | 131 | char *show = NULL; | 
| 132 | char *th_warn=NULL; | ||
| 133 | char *th_crit=NULL; | ||
| 155 | char type[8] = ""; | 134 | char type[8] = ""; | 
| 156 | output chld_out, chld_err; | 135 | output chld_out, chld_err; | 
| 157 | 136 | ||
| @@ -163,7 +142,6 @@ main (int argc, char **argv) | |||
| 163 | unitv = malloc (unitv_size); | 142 | unitv = malloc (unitv_size); | 
| 164 | for (i = 0; i < MAX_OIDS; i++) | 143 | for (i = 0; i < MAX_OIDS; i++) | 
| 165 | eval_method[i] = CHECK_UNDEF; | 144 | eval_method[i] = CHECK_UNDEF; | 
| 166 | i = 0; | ||
| 167 | 145 | ||
| 168 | label = strdup ("SNMP"); | 146 | label = strdup ("SNMP"); | 
| 169 | units = strdup (""); | 147 | units = strdup (""); | 
| @@ -171,7 +149,6 @@ main (int argc, char **argv) | |||
| 171 | outbuff = strdup (""); | 149 | outbuff = strdup (""); | 
| 172 | delimiter = strdup (" = "); | 150 | delimiter = strdup (" = "); | 
| 173 | output_delim = strdup (DEFAULT_OUTPUT_DELIMITER); | 151 | output_delim = strdup (DEFAULT_OUTPUT_DELIMITER); | 
| 174 | /* miblist = strdup (DEFAULT_MIBLIST); */ | ||
| 175 | timeout_interval = DEFAULT_TIMEOUT; | 152 | timeout_interval = DEFAULT_TIMEOUT; | 
| 176 | retries = DEFAULT_RETRIES; | 153 | retries = DEFAULT_RETRIES; | 
| 177 | 154 | ||
| @@ -181,6 +158,28 @@ main (int argc, char **argv) | |||
| 181 | if (process_arguments (argc, argv) == ERROR) | 158 | if (process_arguments (argc, argv) == ERROR) | 
| 182 | usage4 (_("Could not parse arguments")); | 159 | usage4 (_("Could not parse arguments")); | 
| 183 | 160 | ||
| 161 | /* Populate the thresholds */ | ||
| 162 | th_warn=warning_thresholds; | ||
| 163 | th_crit=critical_thresholds; | ||
| 164 | for (i=0; i<numoids; i++) { | ||
| 165 | char *w = th_warn ? strndup(th_warn, strcspn(th_warn, ",")) : NULL; | ||
| 166 | char *c = th_crit ? strndup(th_crit, strcspn(th_crit, ",")) : NULL; | ||
| 167 | /* Skip empty thresholds, while avoiding segfault */ | ||
| 168 | set_thresholds(&thlds[i], | ||
| 169 | w ? strpbrk(w, NP_THRESHOLDS_CHARS) : NULL, | ||
| 170 | c ? strpbrk(c, NP_THRESHOLDS_CHARS) : NULL); | ||
| 171 | if (w) { | ||
| 172 | th_warn=strchr(th_warn, ','); | ||
| 173 | if (th_warn) th_warn++; | ||
| 174 | free(w); | ||
| 175 | } | ||
| 176 | if (c) { | ||
| 177 | th_crit=strchr(th_crit, ','); | ||
| 178 | if (th_crit) th_crit++; | ||
| 179 | free(c); | ||
| 180 | } | ||
| 181 | } | ||
| 182 | |||
| 184 | /* Create the command array to execute */ | 183 | /* Create the command array to execute */ | 
| 185 | if(usesnmpgetnext == TRUE) { | 184 | if(usesnmpgetnext == TRUE) { | 
| 186 | snmpcmd = strdup (PATH_TO_SNMPGETNEXT); | 185 | snmpcmd = strdup (PATH_TO_SNMPGETNEXT); | 
| @@ -251,6 +250,8 @@ main (int argc, char **argv) | |||
| 251 | } | 250 | } | 
| 252 | 251 | ||
| 253 | for (i = 0; i < chld_out.lines; i++) { | 252 | for (i = 0; i < chld_out.lines; i++) { | 
| 253 | const char *conv = "%.0f"; | ||
| 254 | |||
| 254 | ptr = chld_out.line[i]; | 255 | ptr = chld_out.line[i]; | 
| 255 | oidname = strpcpy (oidname, ptr, delimiter); | 256 | oidname = strpcpy (oidname, ptr, delimiter); | 
| 256 | response = strstr (ptr, delimiter); | 257 | response = strstr (ptr, delimiter); | 
| @@ -274,32 +275,25 @@ main (int argc, char **argv) | |||
| 274 | } | 275 | } | 
| 275 | else if (strstr (response, "INTEGER: ")) | 276 | else if (strstr (response, "INTEGER: ")) | 
| 276 | show = strstr (response, "INTEGER: ") + 9; | 277 | show = strstr (response, "INTEGER: ") + 9; | 
| 277 | else if (strstr (response, "STRING: ")) | 278 | else if (strstr (response, "STRING: ")) { | 
| 278 | show = strstr (response, "STRING: ") + 8; | 279 | show = strstr (response, "STRING: ") + 8; | 
| 280 | conv = "%.10g"; | ||
| 281 | } | ||
| 282 | else if (strstr (response, "Timeticks: ")) | ||
| 283 | show = strstr (response, "Timeticks: "); | ||
| 279 | else | 284 | else | 
| 280 | show = response; | 285 | show = response; | 
| 281 | 286 | ||
| 282 | iresult = STATE_DEPENDENT; | 287 | iresult = STATE_DEPENDENT; | 
| 283 | 288 | ||
| 284 | /* Process this block for integer comparisons */ | 289 | /* Process this block for integer comparisons */ | 
| 285 | if (eval_method[i] & CRIT_GT || | 290 | if (thlds[i]->warning || thlds[i]->critical) { | 
| 286 | eval_method[i] & CRIT_LT || | ||
| 287 | eval_method[i] & CRIT_GE || | ||
| 288 | eval_method[i] & CRIT_LE || | ||
| 289 | eval_method[i] & CRIT_EQ || | ||
| 290 | eval_method[i] & CRIT_NE || | ||
| 291 | eval_method[i] & WARN_GT || | ||
| 292 | eval_method[i] & WARN_LT || | ||
| 293 | eval_method[i] & WARN_GE || | ||
| 294 | eval_method[i] & WARN_LE || | ||
| 295 | eval_method[i] & WARN_EQ || | ||
| 296 | eval_method[i] & WARN_NE) { | ||
| 297 | ptr = strpbrk (show, "0123456789"); | 291 | ptr = strpbrk (show, "0123456789"); | 
| 298 | if (ptr == NULL) | 292 | if (ptr == NULL) | 
| 299 | die (STATE_UNKNOWN,_("No valid data returned")); | 293 | die (STATE_UNKNOWN,_("No valid data returned")); | 
| 300 | response_value[i] = strtoul (ptr, NULL, 10); | 294 | response_value[i] = strtod (ptr, NULL); | 
| 301 | iresult = check_num (i); | 295 | iresult = get_status(response_value[i], thlds[i]); | 
| 302 | asprintf (&show, "%llu", response_value[i]); | 296 | asprintf (&show, conv, response_value[i]); | 
| 303 | } | 297 | } | 
| 304 | 298 | ||
| 305 | /* Process this block for string matching */ | 299 | /* Process this block for string matching */ | 
| @@ -363,9 +357,6 @@ main (int argc, char **argv) | |||
| 363 | } | 357 | } | 
| 364 | } | 358 | } | 
| 365 | 359 | ||
| 366 | /* if (nunits == 1 || i == 1) */ | ||
| 367 | /* printf ("%s %s -%s %s\n", label, state_text (result), outbuff, units); */ | ||
| 368 | /* else */ | ||
| 369 | printf ("%s %s -%s %s \n", label, state_text (result), outbuff, perfstr); | 360 | printf ("%s %s -%s %s \n", label, state_text (result), outbuff, perfstr); | 
| 370 | 361 | ||
| 371 | return result; | 362 | return result; | 
| @@ -488,27 +479,11 @@ process_arguments (int argc, char **argv) | |||
| 488 | break; | 479 | break; | 
| 489 | 480 | ||
| 490 | /* Test parameters */ | 481 | /* Test parameters */ | 
| 491 | case 'c': /* critical time threshold */ | 482 | case 'c': /* critical threshold */ | 
| 492 | if (strspn (optarg, "0123456789:,") < strlen (optarg)) | 483 | critical_thresholds = optarg; | 
| 493 | usage2 (_("Invalid critical threshold"), optarg); | ||
| 494 | for (ptr = optarg; ptr && jj < MAX_OIDS; jj++) { | ||
| 495 | if (llu_getll (&lower_crit_lim[jj], ptr) == 1) | ||
| 496 | eval_method[jj] |= CRIT_LT; | ||
| 497 | if (llu_getul (&upper_crit_lim[jj], ptr) == 1) | ||
| 498 | eval_method[jj] |= CRIT_GT; | ||
| 499 | (ptr = index (ptr, ',')) ? ptr++ : ptr; | ||
| 500 | } | ||
| 501 | break; | 484 | break; | 
| 502 | case 'w': /* warning time threshold */ | 485 | case 'w': /* warning threshold */ | 
| 503 | if (strspn (optarg, "0123456789:,") < strlen (optarg)) | 486 | warning_thresholds = optarg; | 
| 504 | usage2 (_("Invalid warning threshold"), optarg); | ||
| 505 | for (ptr = optarg; ptr && ii < MAX_OIDS; ii++) { | ||
| 506 | if (llu_getll (&lower_warn_lim[ii], ptr) == 1) | ||
| 507 | eval_method[ii] |= WARN_LT; | ||
| 508 | if (llu_getul (&upper_warn_lim[ii], ptr) == 1) | ||
| 509 | eval_method[ii] |= WARN_GT; | ||
| 510 | (ptr = index (ptr, ',')) ? ptr++ : ptr; | ||
| 511 | } | ||
| 512 | break; | 487 | break; | 
| 513 | case 'e': /* PRELIMINARY - may change */ | 488 | case 'e': /* PRELIMINARY - may change */ | 
| 514 | case 'E': /* PRELIMINARY - may change */ | 489 | case 'E': /* PRELIMINARY - may change */ | 
| @@ -758,117 +733,6 @@ validate_arguments () | |||
| 758 | 733 | ||
| 759 | 734 | ||
| 760 | 735 | ||
| 761 | char * | ||
| 762 | clarify_message (char *msg) | ||
| 763 | { | ||
| 764 | int i = 0; | ||
| 765 | int foo; | ||
| 766 | char tmpmsg_c[MAX_INPUT_BUFFER]; | ||
| 767 | char *tmpmsg = (char *) &tmpmsg_c; | ||
| 768 | tmpmsg = strcpy (tmpmsg, msg); | ||
| 769 | if (!strncmp (tmpmsg, " Hex:", 5)) { | ||
| 770 | tmpmsg = strtok (tmpmsg, ":"); | ||
| 771 | while ((tmpmsg = strtok (NULL, " "))) { | ||
| 772 | foo = strtol (tmpmsg, NULL, 16); | ||
| 773 | /* Translate chars that are not the same value in the printers | ||
| 774 | * character set. | ||
| 775 | */ | ||
| 776 | switch (foo) { | ||
| 777 | case 208: | ||
| 778 | { | ||
| 779 | foo = 197; | ||
| 780 | break; | ||
| 781 | } | ||
| 782 | case 216: | ||
| 783 | { | ||
| 784 | foo = 196; | ||
| 785 | break; | ||
| 786 | } | ||
| 787 | } | ||
| 788 | msg[i] = foo; | ||
| 789 | i++; | ||
| 790 | } | ||
| 791 | msg[i] = 0; | ||
| 792 | } | ||
| 793 | return (msg); | ||
| 794 | } | ||
| 795 | |||
| 796 | |||
| 797 | |||
| 798 | int | ||
| 799 | check_num (int i) | ||
| 800 | { | ||
| 801 | int result; | ||
| 802 | result = STATE_OK; | ||
| 803 | if (eval_method[i] & WARN_GT && eval_method[i] & WARN_LT && | ||
| 804 | lower_warn_lim[i] > upper_warn_lim[i]) { | ||
| 805 | if (response_value[i] <= lower_warn_lim[i] && | ||
| 806 | response_value[i] >= upper_warn_lim[i]) { | ||
| 807 | result = STATE_WARNING; | ||
| 808 | } | ||
| 809 | } | ||
| 810 | else if | ||
| 811 | ((eval_method[i] & WARN_GT && response_value[i] > upper_warn_lim[i]) || | ||
| 812 | (eval_method[i] & WARN_GE && response_value[i] >= upper_warn_lim[i]) || | ||
| 813 | (eval_method[i] & WARN_LT && response_value[i] < lower_warn_lim[i]) || | ||
| 814 | (eval_method[i] & WARN_LE && response_value[i] <= lower_warn_lim[i]) || | ||
| 815 | (eval_method[i] & WARN_EQ && response_value[i] == upper_warn_lim[i]) || | ||
| 816 | (eval_method[i] & WARN_NE && response_value[i] != upper_warn_lim[i])) { | ||
| 817 | result = STATE_WARNING; | ||
| 818 | } | ||
| 819 | |||
| 820 | if (eval_method[i] & CRIT_GT && eval_method[i] & CRIT_LT && | ||
| 821 | lower_crit_lim[i] > upper_crit_lim[i]) { | ||
| 822 | if (response_value[i] <= lower_crit_lim[i] && | ||
| 823 | response_value[i] >= upper_crit_lim[i]) { | ||
| 824 | result = STATE_CRITICAL; | ||
| 825 | } | ||
| 826 | } | ||
| 827 | else if | ||
| 828 | ((eval_method[i] & CRIT_GT && response_value[i] > upper_crit_lim[i]) || | ||
| 829 | (eval_method[i] & CRIT_GE && response_value[i] >= upper_crit_lim[i]) || | ||
| 830 | (eval_method[i] & CRIT_LT && response_value[i] < lower_crit_lim[i]) || | ||
| 831 | (eval_method[i] & CRIT_LE && response_value[i] <= lower_crit_lim[i]) || | ||
| 832 | (eval_method[i] & CRIT_EQ && response_value[i] == upper_crit_lim[i]) || | ||
| 833 | (eval_method[i] & CRIT_NE && response_value[i] != upper_crit_lim[i])) { | ||
| 834 | result = STATE_CRITICAL; | ||
| 835 | } | ||
| 836 | |||
| 837 | return result; | ||
| 838 | } | ||
| 839 | |||
| 840 | |||
| 841 | |||
| 842 | int | ||
| 843 | llu_getll (unsigned long long *ll, char *str) | ||
| 844 | { | ||
| 845 | char tmp[100]; | ||
| 846 | if (strchr (str, ':') == NULL) | ||
| 847 | return 0; | ||
| 848 | if (strchr (str, ',') != NULL && (strchr (str, ',') < strchr (str, ':'))) | ||
| 849 | return 0; | ||
| 850 | if (sscanf (str, "%llu%[:]", ll, tmp) == 2) | ||
| 851 | return 1; | ||
| 852 | return 0; | ||
| 853 | } | ||
| 854 | |||
| 855 | |||
| 856 | |||
| 857 | int | ||
| 858 | llu_getul (unsigned long long *ul, char *str) | ||
| 859 | { | ||
| 860 | char tmp[100]; | ||
| 861 | if (sscanf (str, "%llu%[^,]", ul, tmp) == 1) | ||
| 862 | return 1; | ||
| 863 | if (sscanf (str, ":%llu%[^,]", ul, tmp) == 1) | ||
| 864 | return 1; | ||
| 865 | if (sscanf (str, "%*u:%llu%[^,]", ul, tmp) == 1) | ||
| 866 | return 1; | ||
| 867 | return 0; | ||
| 868 | } | ||
| 869 | |||
| 870 | |||
| 871 | |||
| 872 | /* trim leading whitespace | 736 | /* trim leading whitespace | 
| 873 | if there is a leading quote, make sure it balances */ | 737 | if there is a leading quote, make sure it balances */ | 
| 874 | 738 | ||
| @@ -973,10 +837,10 @@ print_help (void) | |||
| 973 | printf (" %s\n", _("to be the data that should be used in the evaluation.")); | 837 | printf (" %s\n", _("to be the data that should be used in the evaluation.")); | 
| 974 | 838 | ||
| 975 | /* Tests Against Integers */ | 839 | /* Tests Against Integers */ | 
| 976 | printf (" %s\n", "-w, --warning=INTEGER_RANGE(s)"); | 840 | printf (" %s\n", "-w, --warning=THRESHOLD(s)"); | 
| 977 | printf (" %s\n", _("Range(s) which will not result in a WARNING status")); | 841 | printf (" %s\n", _("Warning threshold range(s)")); | 
| 978 | printf (" %s\n", "-c, --critical=INTEGER_RANGE(s)"); | 842 | printf (" %s\n", "-c, --critical=THRESHOLD(s)"); | 
| 979 | printf (" %s\n", _("Range(s) which will not result in a CRITICAL status")); | 843 | printf (" %s\n", _("Critical threshold range(s)")); | 
| 980 | 844 | ||
| 981 | /* Tests Against Strings */ | 845 | /* Tests Against Strings */ | 
| 982 | printf (" %s\n", "-s, --string=STRING"); | 846 | printf (" %s\n", "-s, --string=STRING"); | 
| @@ -1010,16 +874,8 @@ print_help (void) | |||
| 1010 | printf (" %s\n", _("- Multiple OIDs may be indicated by a comma- or space-delimited list (lists with")); | 874 | printf (" %s\n", _("- Multiple OIDs may be indicated by a comma- or space-delimited list (lists with")); | 
| 1011 | printf (" %s\n", _("internal spaces must be quoted) [max 8 OIDs]")); | 875 | printf (" %s\n", _("internal spaces must be quoted) [max 8 OIDs]")); | 
| 1012 | 876 | ||
| 1013 | printf (" %s\n", _("- Ranges are inclusive and are indicated with colons. When specified as")); | 877 | printf(" -%s", _(UT_THRESHOLDS_NOTES)); | 
| 1014 | printf (" %s\n", _("'min:max' a STATE_OK will be returned if the result is within the indicated")); | ||
| 1015 | printf (" %s\n", _("range or is equal to the upper or lower bound. A non-OK state will be")); | ||
| 1016 | printf (" %s\n", _("returned if the result is outside the specified range.")); | ||
| 1017 | |||
| 1018 | printf (" %s\n", _("- If specified in the order 'max:min' a non-OK state will be returned if the")); | ||
| 1019 | printf (" %s\n", _("result is within the (inclusive) range.")); | ||
| 1020 | 878 | ||
| 1021 | printf (" %s\n", _("- Upper or lower bounds may be omitted to skip checking the respective limit.")); | ||
| 1022 | printf (" %s\n", _("- Bare integers are interpreted as upper limits.")); | ||
| 1023 | printf (" %s\n", _("- When checking multiple OIDs, separate ranges by commas like '-w 1:10,1:,:20'")); | 879 | printf (" %s\n", _("- When checking multiple OIDs, separate ranges by commas like '-w 1:10,1:,:20'")); | 
| 1024 | printf (" %s\n", _("- Note that only one string and one regex may be checked at present")); | 880 | printf (" %s\n", _("- Note that only one string and one regex may be checked at present")); | 
| 1025 | printf (" %s\n", _("- All evaluation methods other than PR, STR, and SUBSTR expect that the value")); | 881 | printf (" %s\n", _("- All evaluation methods other than PR, STR, and SUBSTR expect that the value")); | 
| diff --git a/plugins/t/check_snmp.t b/plugins/t/check_snmp.t index 646cfa43..6cc97b6e 100644 --- a/plugins/t/check_snmp.t +++ b/plugins/t/check_snmp.t | |||
| @@ -8,7 +8,7 @@ use strict; | |||
| 8 | use Test::More; | 8 | use Test::More; | 
| 9 | use NPTest; | 9 | use NPTest; | 
| 10 | 10 | ||
| 11 | my $tests = 34; | 11 | my $tests = 44; | 
| 12 | plan tests => $tests; | 12 | plan tests => $tests; | 
| 13 | my $res; | 13 | my $res; | 
| 14 | 14 | ||
| @@ -44,7 +44,7 @@ SKIP: { | |||
| 44 | like( $res->output, "/check_snmp: Invalid SNMP version - 3c/" ); | 44 | like( $res->output, "/check_snmp: Invalid SNMP version - 3c/" ); | 
| 45 | 45 | ||
| 46 | SKIP: { | 46 | SKIP: { | 
| 47 | skip "no snmp host defined", 20 if ( ! $host_snmp ); | 47 | skip "no snmp host defined", 30 if ( ! $host_snmp ); | 
| 48 | 48 | ||
| 49 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o system.sysUpTime.0 -w 1: -c 1:"); | 49 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o system.sysUpTime.0 -w 1: -c 1:"); | 
| 50 | cmp_ok( $res->return_code, '==', 0, "Exit OK when querying uptime" ); | 50 | cmp_ok( $res->return_code, '==', 0, "Exit OK when querying uptime" ); | 
| @@ -85,6 +85,33 @@ SKIP: { | |||
| 85 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrStorage.hrMemorySize.0,host.hrSystem.hrSystemProcesses.0 -w 1:,1: -c 1:,1:"); | 85 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrStorage.hrMemorySize.0,host.hrSystem.hrSystemProcesses.0 -w 1:,1: -c 1:,1:"); | 
| 86 | cmp_ok( $res->return_code, '==', 0, "Exit OK when querying hrMemorySize and hrSystemProcesses"); | 86 | cmp_ok( $res->return_code, '==', 0, "Exit OK when querying hrMemorySize and hrSystemProcesses"); | 
| 87 | like($res->output, '/^SNMP OK - \d+ \d+/', "String contains hrMemorySize and hrSystemProcesses"); | 87 | like($res->output, '/^SNMP OK - \d+ \d+/', "String contains hrMemorySize and hrSystemProcesses"); | 
| 88 | |||
| 89 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrSWRun.hrSWRunTable.hrSWRunEntry.hrSWRunIndex.1 -w \@:0 -c \@0"); | ||
| 90 | cmp_ok( $res->return_code, '==', 0, "Exit OK with inside-range thresholds"); | ||
| 91 | like($res->output, '/^SNMP OK - 1\s.*$/', "String matches SNMP OK and output format"); | ||
| 92 | |||
| 93 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o enterprises.ucdavis.laTable.laEntry.laLoad.3"); | ||
| 94 | $res->output =~ m/^SNMP OK - (\d+\.\d{2})\s.*$/; | ||
| 95 | my $lower = $1 - 0.05; | ||
| 96 | my $higher = $1 + 0.05; | ||
| 97 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o enterprises.ucdavis.laTable.laEntry.laLoad.3 -w $lower -c $higher"); | ||
| 98 | cmp_ok( $res->return_code, '==', 1, "Exit WARNING with fractionnal arcuments"); | ||
| 99 | |||
| 100 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o system.sysUpTime.0,host.hrSWRun.hrSWRunTable.hrSWRunEntry.hrSWRunIndex.1 -w ,:0 -c ,:2"); | ||
| 101 | cmp_ok( $res->return_code, '==', 1, "Exit WARNING on 2nd threshold"); | ||
| 102 | like($res->output, '/^SNMP WARNING - Timeticks:\s\(\d+\)\s.*,\s.*\s\*1\*\s.*$/', "First OID returned as string, 2nd checked for thresholds"); | ||
| 103 | |||
| 104 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrSWRun.hrSWRunTable.hrSWRunEntry.hrSWRunIndex.1 -w '' -c ''"); | ||
| 105 | cmp_ok( $res->return_code, '==', 0, "Empty thresholds doesn't crash"); | ||
| 106 | |||
| 107 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrStorage.hrMemorySize.0,host.hrSystem.hrSystemProcesses.0 -w ,,1 -c ,,2"); | ||
| 108 | cmp_ok( $res->return_code, '==', 0, "Skipping first two thresholds on 2 OID check"); | ||
| 109 | like($res->output, '/^SNMP OK - \d+ \w+ \d+\s.*$/', "Skipping first two thresholds, result printed rather than parsed"); | ||
| 110 | |||
| 111 | $res = NPTest->testCmd( "./check_snmp -H $host_snmp -C $snmp_community -o host.hrStorage.hrMemorySize.0,host.hrSystem.hrSystemProcesses.0 -w ,, -c ,,"); | ||
| 112 | cmp_ok( $res->return_code, '==', 0, "Skipping all thresholds"); | ||
| 113 | like($res->output, '/^SNMP OK - \d+ \w+ \d+\s.*$/', "Skipping all thresholds, result printed rather than parsed"); | ||
| 114 | |||
| 88 | } | 115 | } | 
| 89 | 116 | ||
| 90 | SKIP: { | 117 | SKIP: { | 
