diff options
| -rw-r--r-- | plugins/check_dns.c | 51 | ||||
| -rw-r--r-- | plugins/t/check_dns.t | 75 | 
2 files changed, 63 insertions, 63 deletions
| diff --git a/plugins/check_dns.c b/plugins/check_dns.c index faa1e150..2a3e3760 100644 --- a/plugins/check_dns.c +++ b/plugins/check_dns.c | |||
| @@ -165,7 +165,7 @@ main (int argc, char **argv) | |||
| 165 | /* compare to expected address */ | 165 | /* compare to expected address */ | 
| 166 | if (result == STATE_OK && match_expected_address && strcmp(address, expected_address)) { | 166 | if (result == STATE_OK && match_expected_address && strcmp(address, expected_address)) { | 
| 167 | result = STATE_CRITICAL; | 167 | result = STATE_CRITICAL; | 
| 168 | asprintf(&msg, _("expected %s but got %s"), expected_address, address); | 168 | asprintf(&msg, _("expected '%s' but got '%s'"), expected_address, address); | 
| 169 | } | 169 | } | 
| 170 | 170 | ||
| 171 | /* check if authoritative */ | 171 | /* check if authoritative */ | 
| @@ -379,55 +379,24 @@ print_help (void) | |||
| 379 | printf (COPYRIGHT, copyright, email); | 379 | printf (COPYRIGHT, copyright, email); | 
| 380 | 380 | ||
| 381 | printf (_("This plugin uses the nslookup program to obtain the IP address for the given host/domain query.")); | 381 | printf (_("This plugin uses the nslookup program to obtain the IP address for the given host/domain query.")); | 
| 382 | |||
| 383 | printf ("\n"); | 382 | printf ("\n"); | 
| 384 | |||
| 385 | printf (_("An optional DNS server to use may be specified.")); | 383 | printf (_("An optional DNS server to use may be specified.")); | 
| 386 | |||
| 387 | printf ("\n"); | 384 | printf ("\n"); | 
| 388 | 385 | printf (_("If no DNS server is specified, the default server(s) specified in /etc/resolv.conf will be used.")); | |
| 389 | printf (_("If no DNS server is specified, the default server(s)specified in /etc/resolv.conf will be used.")); | ||
| 390 | |||
| 391 | printf ("\n\n"); | 386 | printf ("\n\n"); | 
| 392 | 387 | ||
| 393 | print_usage (); | 388 | print_usage (); | 
| 394 | |||
| 395 | printf (_(UT_HELP_VRSN)); | 389 | printf (_(UT_HELP_VRSN)); | 
| 396 | 390 | printf (" -H, --hostname=HOST\n"); | |
| 397 | printf (" -H, --hostname=HOST"); | 391 | printf (" %s\n", _("The name or address you want to query")); | 
| 398 | 392 | printf (" -s, --server=HOST\n"); | |
| 399 | printf ("\n"); | 393 | printf (" %s\n", _("Optional DNS server you want to use for the lookup")); | 
| 400 | 394 | printf (" -a, --expected-address=IP-ADDRESS|HOST\n"); | |
| 401 | printf (_("the name or address you want to query")); | 395 | printf (" %s\n", _("Optional IP-ADDRESS you expect the DNS server to return. HOST must end with .")); | 
| 402 | 396 | printf (" -A, --expect-authority\n"); | |
| 403 | printf ("\n"); | 397 | printf (" %s\n", _("Optionally expect the DNS server to be authoritative for the lookup")); | 
| 404 | |||
| 405 | printf (" -s, --server=HOST"); | ||
| 406 | |||
| 407 | printf ("\n"); | ||
| 408 | |||
| 409 | printf (_("optional DNS server you want to use for the lookup")); | ||
| 410 | |||
| 411 | printf ("\n"); | ||
| 412 | |||
| 413 | printf (" -a, --expected-address=IP-ADDRESS"); | ||
| 414 | |||
| 415 | printf ("\n"); | ||
| 416 | |||
| 417 | printf (_("optional IP address you expect the DNS server to return")); | ||
| 418 | |||
| 419 | printf ("\n"); | ||
| 420 | |||
| 421 | printf (" -A, --expect-authority"); | ||
| 422 | |||
| 423 | printf ("\n"); | ||
| 424 | |||
| 425 | printf (_("optionally expect the DNS server to be authoritative for the lookup")); | ||
| 426 | |||
| 427 | printf ("\n"); | ||
| 428 | 398 | ||
| 429 | printf (_(UT_TIMEOUT), DEFAULT_SOCKET_TIMEOUT); | 399 | printf (_(UT_TIMEOUT), DEFAULT_SOCKET_TIMEOUT); | 
| 430 | |||
| 431 | printf (_(UT_SUPPORT)); | 400 | printf (_(UT_SUPPORT)); | 
| 432 | } | 401 | } | 
| 433 | 402 | ||
| diff --git a/plugins/t/check_dns.t b/plugins/t/check_dns.t index fbaca794..5d750d3f 100644 --- a/plugins/t/check_dns.t +++ b/plugins/t/check_dns.t | |||
| @@ -6,37 +6,68 @@ | |||
| 6 | # | 6 | # | 
| 7 | 7 | ||
| 8 | use strict; | 8 | use strict; | 
| 9 | use Test; | 9 | use Test::More; | 
| 10 | use NPTest; | 10 | use NPTest; | 
| 11 | 11 | ||
| 12 | use vars qw($tests); | 12 | plan skip_all => "check_dns not compiled" unless (-x "check_dns"); | 
| 13 | BEGIN {$tests = 6; plan tests => $tests} | 13 | |
| 14 | plan tests => 11; | ||
| 14 | 15 | ||
| 15 | my $successOutput = '/DNS OK: [\.0-9]+ seconds response time/'; | 16 | my $successOutput = '/DNS OK: [\.0-9]+ seconds response time/'; | 
| 16 | 17 | ||
| 17 | my $hostname_valid = getTestParameter( "hostname_valid", "NP_HOSTNAME_VALID", "localhost", | 18 | my $hostname_valid = getTestParameter( | 
| 18 | "A valid (known to DNS) hostname" ); | 19 | "NP_HOSTNAME_VALID", | 
| 20 | "A valid (known to DNS) hostname", | ||
| 21 | "www.apple.com" | ||
| 22 | ); | ||
| 19 | 23 | ||
| 20 | my $hostname_invalid = getTestParameter( "hostname_invalid", "NP_HOSTNAME_INVALID", "nosuchhost", | 24 | my $hostname_valid_ip = getTestParameter( | 
| 21 | "An invalid (not known to DNS) hostname" ); | 25 | "NP_HOSTNAME_VALID_IP", | 
| 26 | "The IP address of the valid hostname $hostname_valid", | ||
| 27 | "17.112.152.32" | ||
| 28 | ); | ||
| 22 | 29 | ||
| 23 | my $dns_server = getTestParameter( "dns_server", "NP_DNS_SERVER", undef, | 30 | my $hostname_valid_reverse = getTestParameter( | 
| 24 | "A non default (remote) DNS server" ); | 31 | "NP_HOSTNAME_VALID_REVERSE", | 
| 32 | "The hostname of $hostname_valid_ip", | ||
| 33 | $hostname_valid | ||
| 34 | ); | ||
| 25 | 35 | ||
| 26 | my $t; | 36 | my $hostname_invalid = getTestParameter( | 
| 37 | "NP_HOSTNAME_INVALID", | ||
| 38 | "An invalid (not known to DNS) hostname", | ||
| 39 | "nosuchhost.altinity.com", | ||
| 40 | ); | ||
| 27 | 41 | ||
| 28 | # | 42 | my $dns_server = getTestParameter( | 
| 29 | # Default DNS Server | 43 | "NP_DNS_SERVER", | 
| 30 | # | 44 | "A non default (remote) DNS server", | 
| 31 | $t += checkCmd( "./check_dns -H $hostname_valid -t 5", 0, $successOutput ); | 45 | ); | 
| 32 | $t += checkCmd( "./check_dns -H $hostname_invalid -t 1", 2 ); | ||
| 33 | 46 | ||
| 34 | # | 47 | my $res; | 
| 35 | # Specified DNS Server | 48 | |
| 36 | # | 49 | $res = NPTest->testCmd("./check_dns -H $hostname_valid -t 5"); | 
| 37 | $t += checkCmd( "./check_dns -H $hostname_valid -s $dns_server -t 5", 0, $successOutput ); | 50 | cmp_ok( $res->return_code, '==', 0, "Found $hostname_valid"); | 
| 38 | $t += checkCmd( "./check_dns -H $hostname_invalid -s $dns_server -t 1", 2 ); | 51 | like ( $res->output, $successOutput, "Output OK" ); | 
| 52 | |||
| 53 | $res = NPTest->testCmd("./check_dns -H $hostname_invalid -t 1"); | ||
| 54 | cmp_ok( $res->return_code, '==', 2, "Invalid $hostname_invalid"); | ||
| 55 | |||
| 56 | $res = NPTest->testCmd("./check_dns -H $hostname_valid -s $dns_server -t 5"); | ||
| 57 | cmp_ok( $res->return_code, '==', 0, "Found $hostname_valid on $dns_server"); | ||
| 58 | like ( $res->output, $successOutput, "Output OK" ); | ||
| 59 | |||
| 60 | $res = NPTest->testCmd("./check_dns -H $hostname_invalid -s $dns_server -t 1"); | ||
| 61 | cmp_ok( $res->return_code, '==', 2, "Invalid $hostname_invalid on $dns_server"); | ||
| 62 | |||
| 63 | $res = NPTest->testCmd("./check_dns -H $hostname_valid -a $hostname_valid_ip -t 5"); | ||
| 64 | cmp_ok( $res->return_code, '==', 0, "Got expected address"); | ||
| 65 | |||
| 66 | $res = NPTest->testCmd("./check_dns -H $hostname_valid -a 10.10.10.10 -t 5"); | ||
| 67 | cmp_ok( $res->return_code, '==', 2, "Got wrong address"); | ||
| 68 | like ( $res->output, "/^DNS CRITICAL.*expected '10.10.10.10' but got '$hostname_valid_ip'".'$/', "Output OK"); | ||
| 39 | 69 | ||
| 40 | exit(0) if defined($Test::Harness::VERSION); | 70 | $res = NPTest->testCmd("./check_dns -H $hostname_valid_ip -a $hostname_valid_reverse -t 5"); | 
| 41 | exit($tests - $t); | 71 | cmp_ok( $res->return_code, '==', 0, "Got expected fqdn"); | 
| 72 | like ( $res->output, $successOutput, "Output OK"); | ||
| 42 | 73 | ||
