summaryrefslogtreecommitdiffstats
path: root/plugins/t/check_ssh.t
blob: 3e1824df96014fdfda464d752d51ee13e5777a6e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#! /usr/bin/perl -w -I ..
#
# check_ssh tests
#
#

use strict;
use Test::More;
use NPTest;

# Required parameters
my $ssh_host           = getTestParameter("NP_SSH_HOST",
                                          "A host providing SSH service",
                                          "localhost");
my $host_nonresponsive = getTestParameter("NP_HOST_NONRESPONSIVE",
                                          "The hostname of system not responsive to network requests",
                                          "10.0.0.1" );

my $hostname_invalid   = getTestParameter("NP_HOSTNAME_INVALID",
                                          "An invalid (not known to DNS) hostname",
                                          "nosuchhost" );

my $res;


plan tests => 18;
SKIP: {

	skip "No netcat available", 12 unless (system("which nc > /dev/null") == 0);

	my $nc_flags = "-l 5003 -i 1";
	#A valid protocol version control string has the form
	#       SSH-protoversion-softwareversion SP comments CR LF
	#
	# where `comments` is optional, protoversion is the SSH protocol version and
	# softwareversion is an arbitrary string representing the server software version
	open(NC, "echo 'SSH-2.0-nagiosplug.ssh.0.1' | nc ${nc_flags}|");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003" );
	cmp_ok( $res->return_code, '==', 0, "Got SSH protocol version control string");
	like( $res->output, '/^SSH OK - nagiosplug.ssh.0.1 \(protocol 2.0\)/', "Output OK");
	close NC;

	open(NC, "echo 'SSH-2.0-nagiosplug.ssh.0.1 this is a comment' | nc ${nc_flags} |");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003 -r nagiosplug.ssh.0.1" );
	cmp_ok( $res->return_code, '==', 0, "Got SSH protocol version control string, and parsed comment appropriately");
	like( $res->output, '/^SSH OK - nagiosplug.ssh.0.1 \(protocol 2.0\)/', "Output OK");
	close NC;


	open(NC, "echo 'SSH-' | nc ${nc_flags}|");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003" );
	cmp_ok( $res->return_code, '==', 2, "Got invalid SSH protocol version control string");
	like( $res->output, '/^SSH CRITICAL/', "Output OK");
	close NC;

	open(NC, "echo '' | nc ${nc_flags}|");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003" );
	cmp_ok( $res->return_code, '==', 2, "No version control string received");
	like( $res->output, '/^SSH CRITICAL - No version control string received/', "Output OK");
	close NC;

	open(NC, "echo 'Not a version control string' | nc ${nc_flags}|");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003" );
	cmp_ok( $res->return_code, '==', 2, "No version control string received");
	like( $res->output, '/^SSH CRITICAL - No version control string received/', "Output OK");
	close NC;


	#RFC 4253 permits servers to send any number of data lines prior to sending the protocol version control string
	open(NC, "echo 'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\n
		BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB\n
		CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC\n
		DDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDD\n
		Some\nPrepended\nData\nLines\nSSH-2.0-nagiosplug.ssh.0.2' | nc ${nc_flags}|");
	sleep 1;
	$res = NPTest->testCmd( "./check_ssh -H localhost -p 5003" );
	cmp_ok( $res->return_code, '==', 0, "Got delayed SSH protocol version control string");
	like( $res->output, '/^SSH OK - nagiosplug.ssh.0.2 \(protocol 2.0\)/', "Output OK");
	close NC;
}

SKIP {
	skip "SSH_HOST must be defined", 6 unless $ssh_host;
	$res = NPTest->testCmd(
	    "./check_ssh -H $ssh_host"
	    );
	cmp_ok($result->return_code, '==', 0, "Exit with return code 0 (OK)");
	like($result->output, '/^SSH OK - /', "Status text if command returned none (OK)");

	$res = NPTest->testCmd(
	    "./check_ssh -H $host_nonresponsive -t 2"
	    );
	cmp_ok($result->return_code, '==', 2, "Exit with return code 2 (CRITICAL)");
	like($result->output, '/^CRITICAL - Socket timeout after 2 seconds/', "Status text if command returned none (OK)");

	$res = NPTest->testCmd(
	    "./check_ssh -H $hostname_invalid -t 2"
	    );
	cmp_ok($result->return_code, '==', 3, "Exit with return code 3 (UNKNOWN)");
	like($result->output, '/^check_ssh: Invalid hostname/', "Status text if command returned none (OK)");

}