diff options
author | Steve Kemp <steve@steve.org.uk> | 2012-11-21 21:04:33 +0000 |
---|---|---|
committer | Steve Kemp <steve@steve.org.uk> | 2012-11-21 21:04:33 +0000 |
commit | 6dcdce8db04ccf45d95a46d92a4845c9b1a95397 (patch) | |
tree | 97dd5d02c3e400f602f17557a71635012f926fd9 /lib/custodian/protocoltest/ssh.rb | |
parent | ea4e48e4833fbb8eb2b52f3f9263a989b87a0a1f (diff) |
Updated so that we have a working tcp-primitive which the SSH test uses.
Diffstat (limited to 'lib/custodian/protocoltest/ssh.rb')
-rw-r--r-- | lib/custodian/protocoltest/ssh.rb | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/lib/custodian/protocoltest/ssh.rb b/lib/custodian/protocoltest/ssh.rb new file mode 100644 index 0000000..73f23da --- /dev/null +++ b/lib/custodian/protocoltest/ssh.rb @@ -0,0 +1,78 @@ +# +# The SSH-protocol test. +# +# This object is instantiated if the parser sees a line such as: +# +### +### foo.vm.bytemark.co.uk must run ssh on 22 otherwise 'ssh fail'. +### +# +# The specification of the port is mandatory. +# +class SSHTest < TCPTest + + # + # The host to test against. + # + attr_reader :host + + + # + # The port to connect to. + # + attr_reader :port + + + + # + # Constructor + # + # Ensure we received a port to run the test against. + # + def initialize( line ) + # + # Save the host + # + @host = line.split( /\s+/)[0] + + # + # Save the port + # + if ( line =~ /on\s+([0-9]+)/ ) + @port = $1.dup + else + @port = 22 + end + end + + + # + # Helper for development. + # + def to_s + "ssh-test of #{@host}:#{@port}." + end + + + # + # Run the TCP-protocol test. + # + def run_test + + # reset the error, in case we were previously executed. + @error = nil + + run_test_internal( @host, @port, "SSH" ) + end + + + # + # If the test fails then report the error. + # + def error + @error + end + + register_test_type "ssh" + +end |