check_ping.t 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. #! /usr/bin/perl -w -I ..
  2. #
  3. # Ping Response Tests via check_ping
  4. #
  5. # $Id$
  6. #
  7. use strict;
  8. use Test::More;
  9. use NPTest;
  10. plan tests => 20;
  11. my $successOutput = '/PING (ok|OK) - Packet loss = +[0-9]{1,2}\%, +RTA = [\.0-9]+ ms/';
  12. my $failureOutput = '/Packet loss = +[0-9]{1,2}\%, +RTA = [\.0-9]+ ms/';
  13. my $host_responsive = getTestParameter( "NP_HOST_RESPONSIVE",
  14. "The hostname of system responsive to network requests",
  15. "localhost" );
  16. my $host_nonresponsive = getTestParameter( "NP_HOST_NONRESPONSIVE",
  17. "The hostname of system not responsive to network requests",
  18. "10.0.0.1" );
  19. my $hostname_invalid = getTestParameter( "NP_HOSTNAME_INVALID",
  20. "An invalid (not known to DNS) hostname",
  21. "nosuchhost" );
  22. my $res;
  23. $res = NPTest->testCmd(
  24. "./check_ping -H $host_responsive -w 10,100% -c 10,100% -p 1"
  25. );
  26. is( $res->return_code, 0, "Syntax ok" );
  27. like( $res->output, $successOutput, "Output OK" );
  28. $res = NPTest->testCmd(
  29. "./check_ping -H $host_responsive -w 0,0% -c 10,100% -p 1"
  30. );
  31. is( $res->return_code, 1, "Syntax ok, with forced warning" );
  32. like( $res->output, $failureOutput, "Output OK" );
  33. $res = NPTest->testCmd(
  34. "./check_ping -H $host_responsive -w 0,0% -c 0,0% -p 1"
  35. );
  36. is( $res->return_code, 2, "Syntax ok, with forced critical" );
  37. like( $res->output, $failureOutput, "Output OK" );
  38. $res = NPTest->testCmd(
  39. "./check_ping $host_responsive 100 100 1000 1000 -p 1"
  40. );
  41. is( $res->return_code, 0, "Old syntax ok" );
  42. like( $res->output, $successOutput, "Output OK" );
  43. $res = NPTest->testCmd(
  44. "./check_ping $host_responsive 0 0 0 0 -p 1"
  45. );
  46. is( $res->return_code, 2, "Old syntax, with forced critical" );
  47. like( $res->output, $failureOutput, "Output OK" );
  48. # check_ping results will depend on whether the ping command discovered by
  49. # ./configure has a timeout option. If it does, then the timeout will
  50. # be set, so check_ping will always get a response. If it doesn't
  51. # then check_ping will timeout. We do 2 tests for check_ping's timeout
  52. # - 1 second
  53. # - 15 seconds
  54. # The latter should be higher than normal ping timeouts, so should always give a packet loss result
  55. open(F, "../config.h") or die "Cannot open ../config.h";
  56. @_ = grep /define PING_HAS_TIMEOUT 1|define PING_PACKETS_FIRST 1/, <F>;
  57. my $has_timeout;
  58. $has_timeout = 1 if (scalar @_ == 2); # Need both defined
  59. close F;
  60. $res = NPTest->testCmd(
  61. "./check_ping -H $host_nonresponsive -w 10,100% -c 10,100% -p 1 -t 1"
  62. );
  63. is( $res->return_code, 2, "Timeout 1 second - host nonresponsive" );
  64. if ($has_timeout) {
  65. like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
  66. } else {
  67. like( $res->output, '/timed out/', "Error contains 'timed out' string" );
  68. }
  69. $res = NPTest->testCmd(
  70. "./check_ping -H $host_nonresponsive -w 10,100% -c 10,100% -p 1 -t 15"
  71. );
  72. is( $res->return_code, 2, "Timeout 15 seconds - host nonresponsive" );
  73. like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
  74. $res = NPTest->testCmd(
  75. "./check_ping $host_nonresponsive -p 1 -t 1 100 100 1000 10000"
  76. );
  77. is( $res->return_code, 2, "Old syntax: Timeout - host nonresponsive" );
  78. like( $res->output, '/100%/', "Error contains '100%' string (for 100% packet loss)" );
  79. $res = NPTest->testCmd(
  80. "./check_ping $hostname_invalid 0 0 0 0 -p 1 -t 1"
  81. );
  82. is( $res->return_code, 3, "Invalid hostname" );
  83. like( $res->output, '/invalid hostname/i', "Error contains 'invalid hostname' string");
  84. $res = NPTest->testCmd(
  85. "./check_ping -w 100,10% -c 200,20%"
  86. );
  87. is( $res->return_code, 3, "No hostname" );
  88. like( $res->output, '/You must specify a server address or host name/', "Output with appropriate error message");